Skip to content

API Graphics

THE_ORONCO edited this page May 21, 2022 · 3 revisions

Graphics

PICO-8 has a fixed capacity of 128 8x8 sprites, plus another 128 that overlap with the bottom half of the map data ("shared data"). These 256 sprites are collectively called the sprite sheet, and can be thought of as a 128x128 pixel image.

All of PICO-8's drawing operations are subject to the current draw state. The draw state includes a camera position (for adding an offset to all coordinates), palette mapping (for recolouring sprites), clipping rectangle, a drawing colour, and a fill pattern.

The draw state is reset each time a program is run, or by calling RESET().

Colour indexes:

0  black   1  dark_blue   2  dark_purple   3  dark_green  
4  brown   5  dark_gray   6  light_gray    7  white
8  red     9  orange      10 yellow        11 green       
12 blue    13 indigo      14 pink          15 peach

CLIP(X, Y, W, H, [CLIP_PREVIOUS])

Sets the screen's clipping region in pixels CLIP() to reset When clip_previous is true, clip the new clipping region by the old one.

PSET(X, Y, [COL])

Sets the pixel at x, y to colour index COL (0..15).

When COL is not specified, the current draw colour is used.

FOR Y=0,127 DO
    FOR X=0,127 DO
        PSET(X, Y, X*Y/8)
    END
END

PGET(X, Y)

Returns the colour of a pixel at (X, Y), or 0 when (X, Y) is outside the clipping region.

WHILE (TRUE) DO
    X, Y = RND(128), RND(128)
    DX, DY = RND(4)-2, RND(4)-2
    PSET(X, Y, PGET(DX+X, DY+Y))
END

SGET(X, Y)

SSET(X, Y, [COL])

Get or set the colour (COL) of a sprite sheet pixel.

FGET(N, [F])

FSET(N, [F], VAL)

Get or set the value (VAL) of sprite N's flag F.

F is the flag index 0โ€ฆ7.

VAL is TRUE or FALSE.

The initial state of flags 0โ€ฆ7 are settable in the sprite editor, so can be used to create custom sprite attributes. It is also possible to draw only a subset of map tiles by providing a mask in MAP().

When F is omitted, all flags are retrieved/set as a single bitfield.

FSET(2, 1 | 2 | 8)   -- SETS BITS 0,1 AND 3
FSET(2, 4, TRUE)     -- SETS BIT 4
PRINT(FGET(2))       -- 27 (1 | 2 | 8 | 16)

PRINT(STR, X, Y, [COL])

PRINT(STR, [COL])

Print a string STR and optionally set the draw colour to COL.

Shortcut: written on a single line, "?" can be used to call print without brackets:

?"HI"

When X, Y are not specified, a newline is automatically appended. This can be omitted by ending the string with an explicit termination control character:

?"THE QUICK BROWN FOX\0"

Additionally, when X, Y are not specified, printing text below 122 causes the console to scroll. This can be disabled during runtime with POKE(0x5f36,0x40).

PRINT returns the right-most x position that occurred while printing. This can be used to find out the width of some text by printing it off-screen:

W = PRINT("HOGE", 0, -20) -- returns 16

See Appendix A (P8SCII) for information about control codes and custom fonts.

CURSOR(X, Y, [COL])

Set the cursor position.
If COL is specified, also set the current colour.

COLOR([COL])

Set the current colour to be used by drawing functions.
If COL is not specified, the current colour is set to 6

CLS([COL])

Clear the screen and reset the clipping rectangle.
COL defaults to 0 (black)

CAMERA([X, Y])

Set a screen offset of -x, -y for all drawing operations
CAMERA() to reset

CIRC(X, Y, R, [COL])

CIRCFILL(X, Y, R, [COL])

Draw a circle or filled circle at x, y with radius r
If r is negative, the circle is not drawn

OVAL(X0, Y0, X1, Y1, [COL])

OVALFILL(X0, Y0, X1, Y1, [COL])

Draw an oval that is symmetrical in x and y (an ellipse), with the given bounding rectangle.

LINE(X0, Y0, [X1, Y1, [COL]])

Draw a line from (X0, Y0) to (X1, Y1)
If (X1, Y1) are not given, the end of the last drawn line is used.

RECT(X0, Y0, X1, Y1, [COL])

RECTFILL(X0, Y0, X1, Y1, [COL])

Draw a rectangle or filled rectangle with corners at (X0, Y0), (X1, Y1).

PAL(C0, C1, [P])

PAL() swaps colour c0 for c1 for one of three palette re-mappings (p defaults to 0):

  1. Draw Palette The draw palette re-maps colours when they are drawn. For example, an orange flower sprite can be drawn as a red flower by setting the 9th palette value to 8:

    PAL(9,8)     -- draw subsequent orange (colour 9) pixels as red (colour 8) SPR(1,70,60) 
    -- any orange pixels in the sprite will be drawn with red instead

    Changing the draw palette does not affect anything that was already drawn to the screen.

  2. Display Palette The display palette re-maps the whole screen when it is displayed at the end of a frame. For example, if you boot PICO-8 and then type PAL(6,14,1), you can see all of the gray (colour 6) text immediate change to pink (colour 14) even though it has already been drawn. This is useful for screen-wide effects such as fading in/out.

  3. Secondary Palette Used by FILLP() for drawing sprites. This provides a mapping from a single 4-bit colour index to two 4-bit colour indexes.

PAL() resets all palettes to system defaults (including transparency values) PAL(P) resets a particular palette (0โ€ฆ2) to system defaults

PAL(TBL, [P])

When the first parameter of pal is a table, colours are assigned for each entry. For example, to re-map colour 12 and 14 to red:

PAL({[12]=9, [14]=8})

Or to re-colour the whole screen shades of gray (including everything that is already drawn):

PAL({1,1,5,5,5,6,7,13,6,7,7,6,13,6,7,1}, 1)

Because table indexes start at 1, colour 0 is given at the end in this case.

PALT(C, [T])

Set transparency for colour index to T (boolean) Transparency is observed by SPR(), SSPR(), MAP() and TLINE()

PALT(8, TRUE) -- RED PIXELS NOT DRAWN IN SUBSEQUENT SPRITE/TLINE DRAW CALLS

PALT() resets to default: all colours opaque except colour 0
When C is the only parameter, it is treated as a bitfield used to set all 16 values. For example: to set colours 0 and 1 as transparent:

PALT(0B1100000000000000)

SPR(N, X, Y, [W, H], [FLIP_X], [FLIP_Y])

Draw sprite N (0โ€ฆ255) at position X, Y
W (width) and H (height) are 1, 1 by default and specify how many sprites wide to blit.
Colour 0 drawn as transparent by default (see PALT())
When FLIP_X is TRUE, flip horizontally.
When FLIP_Y is TRUE, flip vertically.

SSPR(SX, SY, SW, SH, DX, DY, [DW, DH], [FLIP_X], [FLIP_Y]]

Stretch a rectangle of the sprite sheet (sx, sy, sw, sh) to a destination rectangle on the screen (sx, sy, dw, dh). In both cases, the x and y values are coordinates (in pixels) of the rectangle's top left corner, with a width of w, h.
Colour 0 drawn as transparent by default (see PALT())
dw, dh defaults to sw, sh
When FLIP_X is TRUE, flip horizontally.
When FLIP_Y is TRUE, flip vertically.

FILLP(P)

The PICO-8 fill pattern is a 4x4 2-colour tiled pattern observed by:

P is a bitfield in reading order starting from the highest bit. To calculate the value of P for a desired pattern, add the bit values together:

.-----------------------.
|32768|16384| 8192| 4096|
|-----|-----|-----|-----|
| 2048| 1024| 512 | 256 |
|-----|-----|-----|-----|
| 128 |  64 |  32 |  16 |
|-----|-----|-----|-----|
|  8  |  4  |  2  |  1  |
'-----------------------'

For example, FILLP(4+8+64+128+ 256+512+4096+8192) would create a checkerboard pattern.
This can be more neatly expressed in binary: FILLP(0b0011001111001100).
The default fill pattern is 0, which means a single solid colour is drawn.
To specify a second colour for the pattern, use the high bits of any colour parameter:

FILLP(0b0011010101101000)
CIRCFILL(64,64,20, 0x4E) -- brown and pink

Additional settings are given in bits 0b0.111:

0b0.100 Transparency

When this bit is set, the second colour is not drawn

-- checkboard with transparent squares
FILLP(0b0011001111001100.1) 

0b0.010 Apply to Sprites

When set, the fill pattern is applied to sprites (spr, sspr, map, tline), using a colour mapping provided by the secondary palette.

Each pixel value in the sprite (after applying the draw palette as usual) is taken to be an index into the secondary palette. Each entry in the secondary palette contains the two colours used to render the fill pattern. For example, to draw a white and red (7 and 8) checkerboard pattern for only blue pixels (colour 12) in a sprite:

FOR I=0,15 DO PAL(I, I+I*16, 2) END  --  all other colours map to themselves
PAL(12, 0x87, 2)                     --  remap colour 12 in the secondary palette
    
FILLP(0b0011001111001100.01)         --  checkerboard palette, applied to sprites
SPR(1, 64,64)                        --  draw the sprite

0b0.001 Apply Secondary Palette Globally

When set, the secondary palette mapping is also applied by all draw functions that respect fill patterns (circfill, line etc). This can be useful when used in conjunction with sprite drawing functions, so that the colour index of each sprite pixel means the same thing as the colour index supplied to the drawing functions.

FILLP(0b0011001111001100.001)
PAL(12, 0x87, 2)
CIRCFILL(64,64,20,12)                -- red and white checkerboard circle

The secondary palette mapping is applied after the regular draw palette mapping. So the following would also draw a red and white checkered circle:

PAL(3,12)
CIRCFILL(64,64,20,3)

The fill pattern can also be set by setting bits in any colour parameter:

POKE(0x5F34, 1) -- sets integrated fillpattern + colour mode 
CIRCFILL(64,64,20, 0x114E.ABCD) -- sets fill pattern to ABCD
  • bit 0x1000.0000 means the non-colour bits should be observed
  • bit 0x0700.0000 0x1 transparency, 0x2 apply to sprites, 0x4 apply secondary palette
  • bits 0x00FF.0000 are the usual colour bits
  • bits 0x0000.FFFF are interpreted as the fill pattern

The fill pattern can be applied to sprites (spr, sspr, map, tline) using bit 0b0.01

FILLP(0b0011001111001100.011)
Clone this wiki locally