This is a list of functions provided by PICO-8's Lua-based API .
Typically you run these functions by writing them in the code editor and using the Run command to run your program. You can also call API functions from the PICO-8 command prompt.
Calling functions[]
Some functions have optional arguments, indicated in this guide by square brackets around the argument name. To specify a value for an optional argument, you must specify values for all other arguments to the left in the argument list.
For example, the spr() function has three required arguments and four optional arguments:
spr( n, x, y, [w,] [h,] [flip_x,] [flip_y] )
This function can be called with three arguments, accepting the defaults for the others:
spr(1, 60, 60)
To specify a value for the flip_x
argument, you must also specify w
and h
, even if you're using their default values:
spr(1, 60, 60, 1, 1, true)
The game loop[]
If you define these functions in your code, PICO-8 will call them at specific times. See Game loop.
If your code doesn't use the game loop, you can call this function to copy the graphics buffer to the screen:
Graphics[]
camera([x,] [y])
circ(x, y, r, [col])
circfill(x, y, r, [col])
oval(x0, y0, x1, y1, [col])
ovalfill(x0, y0, x1, y1, [col])
clip([x,] [y,] [w,] [h])
cls([col])
color(col)
cursor([x,] [y,] [col])
fget(n, [f])
fillp([pat])
fset(n, [f,] [v])
line(x0, y0, x1, y1, [col])
pal([c0,] [c1,] [p])
palt([c,] [t])
pget(x, y)
print(str, [x,] [y,] [col])
pset(x, y, [c])
rect(x0, y0, x1, y1, [col])
rectfill(x0, y0, x1, y1, [col])
sget(x, y)
spr(n, x, y, [w,] [h,] [flip_x,] [flip_y])
sset(x, y, [c])
sspr(sx, sy, sw, sh, dx, dy, [dw,] [dh,] [flip_x,] [flip_y])
tline(x0, y0, x1, y1, mx, my, [mdx,] [mdy])
See also Graphics.
Tables[]
add(t, v, [i])
all(t)
count(t, [v])
del(t, v)
deli(t, i)
foreach(t, f)
ipairs(t)
pack(...)
pairs(t)
unpack(t, [i], [j])
next(t, [key])
Input[]
See also Stat: Mouse and Keyboard
Sound[]
See also Stat: PCM (undocumented)
Map[]
Memory[]
cstore(destaddr, sourceaddr, len, [filename])
memcpy(dest_addr, source_addr, len)
memset(dest_addr, val, len)
peek(addr, [n])
peek2(addr, [n])
peek4(addr, [n])
poke(addr, [value,] [...])
poke2(addr, [...])
poke4(addr, [...])
reload(destaddr, sourceaddr, len, [filename])
serial(channel, sourceaddr, size)
Math[]
abs(x)
atan2(dx, dy)
band(x, y)
bnot(x)
bor(x, y)
bxor(x, y)
ceil(x)
cos(x)
flr(x)
lshr(num, bits)
max(x, y)
mid(x, y, z)
min(x, y)
rnd(x)
rotl(num, bits)
rotr(num, bits)
sgn(x)
shl(x, y)
shr(x, y)
sin(x)
sqrt(x)
srand(x)
See also Math.
Cartridge data[]
Coroutines[]
Strings[]
split(str, [separator, ] [convert_numbers])
sub(str, from, [to])
chr(num)
ord(str, [index])
tonum(val, [format_flags])
tostr(val, [usehex])
Values and objects[]
setmetatable(tbl, metatbl)
getmetatable(tbl)
rawequal(t1, t2)
rawget(t, n)
rawlen(t)
rawset(t, n, v)
select(i, ...)
type(v)
See also Lua, Strings, Tables, Metatables.
Time[]
See also Stat: Time of Day
System[]
Debugging[]
assert(cond, [message])
printh(str, [filename], [overwrite])
stat(n)
stop()
(undocumented)trace()
(undocumented)