Sequences
A comic contains one or more sequences. In most cases, a sequence acts like a separate chapter of your comic.
Each sequence can define different settings for scroll direction and background color. Sequences can scroll manually (with the crank or arrows), or they can animate between panels automatically by pressing a button.
Table of contents
Properties
panels
required
A list of tables that define each panel in the sequence.
Usage:
panels = {
{
-- data for panel 1
}, {
-- data for panel 2
}, {
-- data for panel 3
}
},
title
default: nil
The sequence title is the text that will appear in the Chapters menu. Sequences without a title will not appear in the Chapters menu. This can be used as a method for having multiple sequences appear as a single chapter.
axis
default: Panels.ScrollAxis.HORIZONTAL
On which axis should this sequence scroll?
OPTIONS:
Panels.ScrollAxis.HORIZONTAL
Panels.ScrollAxis.VERTICAL
direction
default: Panels.ScrollDirection.LEFT_TO_RIGHT or TOP_DOWN
In which direction does this sequence scroll? By default horizontal sequences scroll left to right, vertical sequences scroll from top to bottom.
Setting the direction to NONE
creates a sequence where panels appear directly on top of each other with no animated transition.
OPTIONS:
Panels.ScrollDirection.LEFT_TO_RIGHT
Panels.ScrollDirection.RIGHT_TO_LEFT
Panels.ScrollDirection.TOP_DOWN
Panels.ScrollDirection.BOTTOM_UP
Panels.ScrollDirection.NONE
scrollType
default: Panels.ScrollType.MANUAL
A manually scrolling sequence moves incrementally as the user turns the crank or presses the d-pad.
An auto-scrolling sequence moves panel-by-panel as the user presses the panel’s advanceControl
button or triggers the panel’s advanceControlSequence
.
Auto-scrolling sequences can also be advanced with the crank by setting the autoAdvanceWithCrank
property.
OPTIONS:
Panels.ScrollType.MANUAL
Panels.ScrollType.AUTO
autoAdvanceWithCrank
default: false
When set to true
, the crank can be used to auto-advance panels (in addition to the buttons).
scrollType
must be set to Panels.ScrollType.AUTO
for this property to take effect.
Note that when crank auto-advance is enabled, the panel will scroll slightly before crossing the auto-scroll detent threshold (see autoAdvanceTicks). This can be used with or without snapToPanel
depending on the desired effect.
autoAdvanceTicks
default: 6
When autoAdvanceWithCrank
is enabled, this property sets the number of auto-advance detents per crank revolution, as used in playdate.getCrankTicks
. The larger the number, the less one must crank to trigger auto-scroll.
audio
default: nil
A table that defines background audio to play throughout all panels in this sequence.
Properties:
file
(string)loop
(boolean)continuePrevious
(boolean)volume
(number [0.0–1.0])
Note: the file
path should be relative to your comic’s audioFolder
setting.
Examples:
Set a looping background song:
audio = { file = "sequence1/bgSong", loop = true, volume = 0.6 },
The loop
property is false by default.
Continue audio from the previous sequence:
audio = { continuePrevious = true },
This will give you seamless background audio between sequence transitions.
It’s a good idea to define the audio file even when using continuePrevious
. This will be the file that plays if a user skips directly to this sequence from the chapter menu:
audio = { continuePrevious = true, file = "sequence1/bgSong", loop = true },
advanceControl
default: scroll direction (d-pad)
Specifies which control advances to the next sequence from the last panel in this sequence. By default the advance control will be the d-pad direction button pointing in the sequence’s scroll direction. Left-to-right scrolling sequence will advance with the right button, a bottom-up sequence will advance with the up button, and so on.
Options:
Panels.Input.UP
Panels.Input.RIGHT
Panels.Input.DOWN
Panels.Input.LEFT
Panels.Input.A
Panels.Input.B
advanceControlSize
default: Panels.ControlSize.LARGE
Set the size of the advance control indicator.
Options:
Panels.ControlSize.LARGE
(40 × 40)Panels.ControlSize.MEDIUM
(30 × 30)Panels.ControlSize.SMALL
(20 × 20)
showAdvanceControl
default: true
Set this property to false
to hide the advance control indicator on the last panel of the sequence.
Note that this might be confusing for users unless an indication of the control is included somewhere in the content of the final panel itself.
advanceControls
default: nil
FOR NONLINEAR COMICS ONLY
A table that defines a list of input controls with corresponding sequence targets (and optional position coordinates). These input/target pairs can be used to create a nonlinear branching storyline.
Properties:
input
(Panels.Input)target
(number [sequence index])x
(number)y
(number)
Example:
advanceControls = {
{ input = Panels.Input.A, target = 2, x = 180, y = 20},
{ input = Panels.Input.B, target = 4, x = 180, y = 180},
},
showAdvanceControls
default: true
FOR NONLINEAR COMICS ONLY
Set this property to false
to hide the advance options in your nonlinear comic.
Note that this might be confusing for users unless an indication of the controls is included somewhere in the content of the final panel.
backgroundColor
default: Panels.Color.WHITE
The background color of the screen outside the bounds of your panels. Changing this property also inverts the color of the panel borders.
OPTIONS:
Panels.Color.WHITE
Panels.Color.BLACK
endSequence
default: false
FOR NONLINEAR COMICS ONLY
Specify that a sequence is a dead end branch in your nonlinear comic. When a user advances past this sequence they will return to the main menu even if there are subsequent sequences listed in the comic data.
rapidAdvance
default: false
FOR AUTO-SCROLLING SEQUENCES ONLY
Normally, Panels will prevent the user from advancing to the next panel until the current panel has finished scrolling. This is helpful in preventing the user from accidentally skipping panels.
When this property is set to true
, the user can rapidly advance through the panels in this sequence without waiting for the scroll animation to complete. This is useful when the panels aren’t serving a narrative purpose, such as for an in-game manual or credits sequence.
transitionDuration
default: 500
FOR AUTO-SCROLLING SEQUENCES ONLY
The duration of the panel transition animation in milliseconds.
transitionEase
default: playdate.easingFunctions.inOutQuad
FOR AUTO-SCROLLING SEQUENCES ONLY
The easing function used for the panel transition animation. You can set this to any of the Playdate easing functions, or define your own.
id
default: nil
FOR NONLINEAR COMICS ONLY
Set a unique string to represent this sequence.
You can use this id to link to this sequence from a target sequence function, a target
property of an advance control, or a sequence’s nextSequence
property.
nextSequence
default: nil
FOR NONLINEAR COMICS ONLY
Set the id
of the sequence that should come after this one.
You might need this in your branching comic if your sequences appear out of order in your comicData table.