Skip to content

idbrii/love-parallax

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Tested on love2d 11.3+ Lint status

parallax

parallax is a camera utility library for LÖVE 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.

parallax-quick-start

local gamera = require('gamera') -- https://github.com/kikito/gamera
local parallax = require('parallax')

local layers = {}
local player = {}
local camera

function 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
end

function 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)
end

local function draw_all(l,t,w,h)
    local rect_w = 50
    local offset = camera.ww * 2

    layers.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)
end

function love.draw()
    love.graphics.clear()
    camera:draw(draw_all)
end

Demo

There's a demo branch that demonstrates a more complex program using parallax. It uses 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 which I built this library to work with.
  • davisdude for Brady which was instrumental to figuring out how to make parallax work.

License

MIT

About

A utility library for LÖVE that adds parallax scrolling to your camera.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Languages