diff options
author | Indrajith K L | 2022-03-01 02:48:49 +0530 |
---|---|---|
committer | Indrajith K L | 2022-03-01 02:48:49 +0530 |
commit | f5eaa22a1c9598c9f7a55a41614d1ce4769dee4a (patch) | |
tree | afbb7585324e9efbfd5820f07d9a0239193d3e99 /utils/map.lua | |
parent | 05add67d6f95c51a3501bc15a742cf9fccc4b67e (diff) | |
download | YEAD-f5eaa22a1c9598c9f7a55a41614d1ce4769dee4a.tar.gz YEAD-f5eaa22a1c9598c9f7a55a41614d1ce4769dee4a.tar.bz2 YEAD-f5eaa22a1c9598c9f7a55a41614d1ce4769dee4a.zip |
* Adds Ambience SFX & Management
* Notification - In-Progress
* Collision Callbacks
* Interactive & Pickable entities - In-Progress
Diffstat (limited to 'utils/map.lua')
-rw-r--r-- | utils/map.lua | 126 |
1 files changed, 0 insertions, 126 deletions
diff --git a/utils/map.lua b/utils/map.lua deleted file mode 100644 index 1f06487..0000000 --- a/utils/map.lua +++ /dev/null @@ -1,126 +0,0 @@ -Class = require("libs.hump.class") -Gamestate = require("libs.hump.gamestate") -STI = require("libs.sti") -Moonshine = require("libs.moonshine") -Camera = require("libs.hump.camera") -Windfield = require("libs.windfield") - -zoomFactor = 2 -player = { - x=0, - y=0, - sprite=love.graphics.newImage("assets/images/player_demo.png"), - speed=100 -} - -windowWidth, windowHeight = love.graphics.getDimensions() -_w = windowWidth/zoomFactor -_h = windowHeight/zoomFactor - -Map = Class { - __include=Gamestate, - init = function(self, mapName) - _gameWorld = Windfield.newWorld(0,0) - effect = Moonshine(windowWidth, windowHeight, Moonshine.effects.crt) - .chain(Moonshine.effects.vignette) - .chain(Moonshine.effects.scanlines) - .chain(Moonshine.effects.chromasep) - effect.scanlines.thickness = .2 - effect.scanlines.opacity = .5 - effect.chromasep.angle = 1 - effect.chromasep.radius = 2 - - camera = Camera() - camera:zoom(zoomFactor) - currentMap = STI("assets/maps/"..mapName..".lua") - if currentMap.layers["entities"] then - for i,obj in pairs(currentMap.layers["entities"].objects) do - player.x = obj.x - player.y = obj.y - player.collider = _gameWorld:newBSGRectangleCollider(player.x, player.y, 8, 8, 0) - player.collider:setFixedRotation(true) - end - end - - if currentMap.layers["walls"] then - for i,obj in pairs(currentMap.layers["walls"].objects) do - local wall = _gameWorld:newRectangleCollider(obj.x, obj.y, obj.width, obj.height) - wall:setType("static") - end - end - end, - entities={} -} - -function Map:update(dt) - - local vx = 0 - local vy = 0 - - if love.keyboard.isDown("up") then - vy = player.speed * -1 - end - - if love.keyboard.isDown("down") then - vy = player.speed - end - - if love.keyboard.isDown("left") then - vx = player.speed * -1 - end - - if love.keyboard.isDown("right") then - vx = player.speed - end - - player.collider:setLinearVelocity(vx, vy) - - _gameWorld:update(dt) - player.x = player.collider:getX() - 4 - player.y = player.collider:getY() - 4 - - camera:lookAt(player.x, player.y) - currentMap:update(dt) - - if camera.x < _w/2 then - camera.x = _w/2 - end - - if camera.y < _h/2 then - camera.y = _h/2 - end - - local mapWidth = currentMap.width * currentMap.tilewidth - local mapHeight = currentMap.height * currentMap.tileheight - - if camera.x > (mapWidth - _w/2) then - camera.x = (mapWidth - _w/2) - end - - if camera.y > (mapHeight - _h/2) then - camera.y = (mapHeight - _h/2) - end -end - -function Map:draw() - effect(function() - camera:attach() - drawMapLayer("ground") - drawMapLayer("decorations") - love.graphics.draw(player.sprite, player.x, player.y) - drawMapLayer("foreground") - -- _gameWorld:draw() - camera:detach() - end) -end - -function Map:keypressed(key, scancode) -end - -function drawMapLayer(layerName) - if currentMap.layers[layerName].visible then - currentMap:drawLayer(currentMap.layers[layerName]) - end -end - -return Map
\ No newline at end of file |