Skip to content

A simple fluid simulation library for Playdate written in Lua.

License

Notifications You must be signed in to change notification settings

mierau/playdate-fluid

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fluid for Playdate

This library is written in Lua using the Playdate SDK. It provides a way to create, draw, animate, and interact with fluid. The library is a minimal simulation to keep it speedy on device, so it is constrained mostly to wave simulation. However, as this is open source, please feel free to add more functionality if you can keep it snappy.

fluid

Use

Create a fluid box.

local fluid = Fluid.new(0, 180, 400, 240-180)

Update fluid each frame to run simulation.

function playdate.update()
   fluid:update()
end

Draw the fluid using fill() or draw()

graphics.setColor(graphics.kColorBlack)
graphics.setDitherPattern(0.5)
fluid:fill()

Cause waves by providing an x coord along the surface of the fluid and a velocity to interact with. Negative velocity makes the fluid go up, positive makes the fluid go down.

fluid:touch(20, -4)

And some utility functions you can use.

fluid:getPointOnSurface(x) # returns an x,y pair of the x coord on the surface of the fluid polygon.
fluid:getWaveBounds() # returns the rect of the fluid currently taking into account the height of the tallest wave.
fluid:moveTo(x, y) # use to move the fluid rect to another location on screen and update the internal polygon.
fluid:moveBy(dx, dy) # use to move the fluid rect relatively to another location on screen and update the internal polygon.

About

A simple fluid simulation library for Playdate written in Lua.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages