Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/idbrii/love-parallax
A utility library for LÖVE that adds parallax scrolling to your camera.
https://github.com/idbrii/love-parallax
love2d parallax parallax-scrolling
Last synced: 2 months ago
JSON representation
A utility library for LÖVE that adds parallax scrolling to your camera.
- Host: GitHub
- URL: https://github.com/idbrii/love-parallax
- Owner: idbrii
- License: mit
- Created: 2021-03-18T06:12:59.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2022-01-11T08:35:16.000Z (about 3 years ago)
- Last Synced: 2024-08-02T06:16:47.308Z (6 months ago)
- Topics: love2d, parallax, parallax-scrolling
- Language: Lua
- Homepage: https://idbrii.github.io/love-parallax/demo/
- Size: 2.16 MB
- Stars: 13
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-love2d - parallax - Parallax scrolling with any camera system; seamlessly tile background images. (Camera)
README
[![Tested on love2d 11.3+
](https://img.shields.io/badge/L%F6ve-11.3%2B-pink.svg)](https://love2d.org/) [![Lint status
](https://github.com/idbrii/love-parallax/actions/workflows/luacheck.yml/badge.svg?branch=main)
](https://github.com/idbrii/love-parallax/actions?query=branch%3Amain)# parallax
parallax is a camera utility library for [LÖVE](https://love2d.org) that
adds parallax scrolling when used with a camera library.parallax is not itself a camera system!
parallax was developed using LÖVE 11.3, but may work on earlier versions.
## Quick Start
This is a very minimal example of using parallax, but [there's a more involved
demo](#demo).![parallax-quick-start](https://user-images.githubusercontent.com/43559/111591121-3f28bf80-8784-11eb-9ffa-f8fb74d2f838.gif)
```lua
local gamera = require('gamera') -- https://github.com/kikito/gamera
local parallax = require('parallax')local layers = {}
local player = {}
local camerafunction love.load()
camera = gamera.new(0,0,2000,700)
layers.near = parallax.new(camera, 1.5)
layers.far = parallax.new(camera, 0.25)
player.x = camera.ww / 2
player.base_y = camera.wh * 2 / 3
player.jump = 100
player.y = 0
player.width = 10
player.half = player.width / 2
player.speed = 500
endfunction love.update(dt)
-- move the player around so we can see the layers move
player.x = player.x + player.speed * dt
if player.x <= 0 or camera.ww < player.x then
player.speed = player.speed * -1
end
player.y = player.base_y + math.cos(player.x / 100) * player.jump
camera:setPosition(player.x, player.y)
endlocal function draw_all(l,t,w,h)
local rect_w = 50
local offset = camera.ww * 2layers.far:draw(function()
-- Draw something distant from the camera here.
love.graphics.setColor(0,0.2,0.7,0.3)
for x=-offset,offset,rect_w do
local rh = love.math.noise(x/w) * 1200
love.graphics.rectangle('fill', x, -900, rect_w, rh)
end
end)-- Draw the game here
love.graphics.setColor(1,1,1,1)
love.graphics.rectangle('fill', player.x - player.half, player.y - player.half, player.width, player.width)
love.graphics.setColor(0,0.7,0.7,0.3)
love.graphics.rectangle('fill', -camera.ww, player.base_y + player.jump, camera.ww * 2, camera.wh)layers.near:draw(function()
-- Draw something near the camera here.
for x=-offset,offset,rect_w do
local rh = love.math.noise(x/w) * 150
love.graphics.rectangle('fill', x, camera.wh - 50, rect_w, -rh)
end
end)
endfunction love.draw()
love.graphics.clear()
camera:draw(draw_all)
end
```## Demo
There's a [demo branch](https://github.com/idbrii/love-parallax/tree/demo) that
demonstrates a more complex program using parallax. It uses
[gamera](https://github.com/kikito/gamera) for its camera and demonstrates
multiple ways the camera can be transformed while maintaining correct parallax
orientation.## Functions
### parallax.new(camera, scale, speed)
Creates a new parallax object.
- `camera`: _table_. A camera object containing x,y (camera position), w2,h2 (half camera width and height), angle (camera rotation), and scale (camera scaling factor). gamera provides all of these.
- `scale`: _number_. The scale for this layer. Larger numbers look closer and smaller look more distant.
- `speed`: _number_. Optional. A speed scale for this layer's movement. A number closer to zero makes it move slower (and look more distant) without changing its size.### layer:draw(f)
Draw input function on the parallax layer. Should be called inside love.draw.
- `f`: _function_ A function that does drawing operations.
### layer:setOffset(x,y)
Give the parallax layer an offset from the camera's position. If you have a
background layer, you may want to move it down to see more of the ceiling area.- `x, y`: _numbers_. This offset adjusts the position of the layer relative to the camera.
### layer:translateOffset(dx,dy)
Set incremental changes to the parallax layer's offset. Allows you to fine tune
how the layer is displayed.- `dx, dy`: _numbers_. Increment the offset by these values.
### layer:draw_tiled_xy(x, y, image)
Draw an image (or Canvas or Video) tiled using a minimal number of draws. Uses
inverseTransformPoint so transformations from your camera should ensure only
visible tiles are drawn.- `x, y`: _numbers_. Tune the positioning of the image.
- `image`: _Drawable_. A drawable (Image, Canvas) that provides getDimensions to draw tiled.- returns: _number_. The number of times the image was drawn.
### layer:draw_tiled_single_axis(x, y, image, axis)
Draw an image (or Canvas or Video) tiled using a minimal number of draws and
only along a single axis. See also draw_tiled_xy.- `x, y`: _numbers_. Tune the positioning of the image.
- `image`: _Drawable_. A drawable (Image, Canvas) that provides getDimensions to draw tiled.
- `axis`: _string_. Either `x` to tile horizontally or `y` to tile vertically.- returns: _number_. The number of times the image was drawn.
## Credits
* kikito for [gamera](https://github.com/kikito/gamera) which I built this library to work with.
* davisdude for [Brady](https://github.com/davisdude/brady) which was instrumental to figuring out how to make parallax work.## License
MIT