Global namespace ($SE
)
The global namespace for this API is $SE
. Most Stipple Effect functions that are not called on an object are called on the global namespace.
Constants
Constants are bound to primitive data values like int
or bool
. Thus, they can technically be avoided and replaced by their literal values. However, using constants makes scripts more readable and maintainable, and most importantly ensures that scripts do not break if the value assigned to a constant changes in a future update.
Scope constants
These constants are used to specify a scope for program operations like palettization, for example.
$SE.PROJECT = 0 // The entire project
$SE.LAYER = 1 // All cels on the currently selected layer
$SE.FRAME = 2 // All cels at the currently frame index
$SE.CEL = 3 // The cel on the current layer at the current frame index
Save type constants
These constants are used to specify a save type for a save_config
object. Save types are essentially the type of file that the save_config
object will save projects as, though there are multiple save types that save projects to the same type of file, albeit differently.
$SE.NATIVE = 0 // The native file type (.stip)
$SE.PNG_SHEET = 1 // The project as a single PNG image/sprite sheet
$SE.PNG_SEPARATE = 2 // Separate PNG images for each frame of the project
$SE.GIF = 3 // An animated GIF
$SE.MP4 = 4 // MP4 video
Dimension constants
$SE.HORZ = true // Horizontal sequencing order; L to R, T to B
$SE.VERT = false // Vertical sequencing order; T to B, L to R
Functions of the form $SE.func_name(parameters) -> return_type
are value-returning functions, while functions of the form $SE.func_name(parameters);
are void functions, which perform an action but return nothing.
Project functions
get_projects
$SE.get_projects() -> project[]
Returns an array of the projects that are currently opened in Stipple Effect.
get_project
$SE.get_project() -> project
Returns the current active project in Stipple Effect.
new_project
-
$SE.new_project(int w, int h, bool open_in_se) -> project
Creates a new project with a canvas size specified by
w
xh
pixels and returns its reference.If
open_in_se
istrue
, the new project is opened in Stipple Effect and set as the active project.Fails:
Any of the following will cause the function not to execute:
w < 0
w > 1920
h < 0
h > 1080
-
$SE.new_project(int w, int h) -> project
Equivalent to
$SE.new_project(w, h, true)
-
$SE.new_project(int w, int h);
Like (2), but does not return the reference to the newly created project.
Miscellaneous functions
new_save_config
$SE.new_save_config(string[] folder, string filename, int save_type) -> save_config
Instantiates a new save_config
object with the parent folder path folder
, base file name filename
, and save type specified by the int
enumeration value save_type
.
Throws:
Any of the following will result in runtime errors:
- An invalid
save_type
value - If
folder
is empty - If
folder
is not a valid directory in the file system - If
filename
is""
or contains any of the following characters:{ '/', '\\', ':', '*', '?', '"', '<', '>', '|', '{', '}' }
Reading material:
read_script
$SE.read_script(string filepath) -> script
Reads, builds and returns a Stipple Effect child script from filepath
.
Throws:
Any of the following will result in runtime errors:
- If the interpreter cannot read a file at
filepath
- If the file at
filepath
cannot be compiled into a Stipple Effect script due to syntax errors
Script execution will terminate if the child script fails its semantic error check.
Reading material:
transform
-
$SE.transform(project source, script transformer, bool open_in_se, bool run_per_layer) -> project
Transforms the contents of the project
source
into a new project with the preview scripttransformer
.source
is not modified by this operation.The flag
open_in_se
will open the resultant project in Stipple Effect and set it as the active project.The flag
run_per_layer
will applytransformer
to the contents of each layer ofsource
, as opposed to applyingtransformer
to the flattened contents ofsource
. This way,run_per_layer
preserves the layers ofsource
.Note:
Depending on
transformer
, the flattened contents of a project created withtransform()
with therun_per_layer
flag may not match the contents of a project created without therun_per_layer
flag. -
$SE.transform(project source, script transformer) -> project
Equivalent to
$SE.transform(source, transformer, true, false)
Runs (1) with the
open_in_se
flag set totrue
and therun_per_layer
flag set tofalse
.
Color functions
get_primary
$SE.get_primary() -> color
Returns the current Stipple Effect system primary color.
set_primary
$SE.set_primary(color c);
Sets the Stipple Effect primary color to c
.
get_secondary
$SE.get_secondary() -> color
Returns the current Stipple Effect system secondary color.
set_secondary
$SE.set_secondary(color c);
Sets the Stipple Effect secondary color to c
.
get_pal
$SE.get_pal() -> palette
Returns the currently selected Stipple Effect system palette.
has_pal
$SE.has_pal() -> bool
Returns true
if there is at least one palette in Stipple Effect at the time of the call, false
otherwise.
new_pal
$SE.new_pal(color{} cs, string name);
Creates a new palette in Stipple Effect from the set of colors cs
with the name name
.
hsv
-
$SE.hsv(float h, float s, float v, int a) -> color
Returns a color built from its hue, saturation, value and alpha components. Unlike
rgba()
, which takes as arguments integer values ranging from 0 to 255, each of the HSV component arguments (h
,s
andv
) is a float ranging from 0.0 to 1.0.a
, however, is still an integer ranging from 0 to 255.Throws:
Any of the following will result in a runtime exception:
- For any
comp
ofh
,s
,v
;comp < 0.0
- For any
comp
ofh
,s
,v
;comp > 1.0
a > 255
a < 0
- For any
-
$SE.hsv(float h, float s, float v) -> color
Equivalent to
$SE.hsv(h, s, v, 255)
Outline functions
get_side_mask
$SE.get_side_mask() -> int[]
Returns the current system outline side mask. This is an eight-element integer array. The indices correspond to the following directions:
0 = TOP
1 = LEFT
2 = RIGHT
3 = BOTTOM
4 = TL
5 = TR
6 = BL
7 = BR
set_side_mask
$SE.set_side_mask(int[] side_mask);
Sets the Stipple Effect outline side mask to side_mask
.
Fails:
Any of the following will cause the function not to execute:
#|side_mask != 8
- For any
i
,side_mask[i] < -10
- For any
i
,side_mask[i] > 10
outline
$SE.outline(int[]{} selection, int[] side_mask) -> int[]{}
Returns the outline of the initial selection selection
when outlined with the side mask side_mask
. The outlining algorithm can be found here.
Throws:
Any of the following will result in runtime errors:
#|side_mask != 8
- For any
i
,side_mask[i] < -10
- For any
i
,side_mask[i] > 10
single_outline
$SE.single_outline(int[]{} selection, int border_px) -> int[]{}
Returns the outline of the initial selection selection
when outlined with the single outline side mask with a border thickness of border_px
pixels. A single outline outlines along the cardinal directional borders of the selection only.
Throws:
Any of the following will result in runtime errors:
border_px < -10
border_px > 10
double_outline
$SE.double_outline(int[]{} selection, int border_px) -> int[]{}
Returns the outline of the initial selection selection
when outlined with the double outline side mask with a border thickness of border_px
pixels. A double outline outlines along the cardinal directional borders of the selection as well as the diagonal borders.
Throws:
Any of the following will result in runtime errors:
border_px < -10
border_px > 10
Tool functions
wand
$SE.wand(image img, int x, int y, float tolerance, bool global, bool diag) -> int[]{}
Returns a set of ordered pairs that represent the pixel coordinates of the result of a wand tool operation on the image img
.
Parameters:
img
- Image upon which the wand operation is performed(x, y)
- Initial position from which the wand searches; equivalent to the pixel that is clicked when the wand tool is used from within the Stipple Effect UItolerance
- value from 0.0 (exact match) to 1.0 (maximally permissive) that determines how permissive of differences in color the wand is between the initial pixel and pixels being processed for inclusionglobal
(flag)- if
true
, wand searches the entire canvas irrespective of adjacency - if
false
, the wand iteratively searches from among the frontier of pixels adjacent to selection inclusions
- if
diag
(flag)- if
true
, adjacency is defined as cardinal adjacency + diagonal adjacency - if
false
, pixels must be cardinally adjacent in order to be considered
- if
Reading material:
fill
$SE.fill(image img, color c, int x, int y, float tolerance, bool global, bool diag) -> image
Returns the resultant image of a fill operation applied to the image img
. fill()
performs the exact same search and computation as wand()
. However, instead of returning a selection as a int[]{}
, fill()
takes that selection and sets every pixel in that selection to the color c
in img
.
fill_selection
-
$SE.fill_selection(image img, color c, int[]{} selection) -> image
Returns the resultant image of a fill operation applied to the image
img
where all the pixels inselection
are set toc
inimg
. -
$SE.fill_selection(image img, color c) -> image
Returns the resultant image of a fill operation applied to the image
img
where all the pixels in the current selection in the active Stipple Effect project are set toc
inimg
.