16
13
objects = function() return {
17
14
Tile:new{image = 'data/forest1-bg.png'},
18
Player:new{x = 200, y = 380,
19
minY = 330, maxY = 500,
20
image = 'data/forest1-player.png'},
15
Player:new{x = 200, y = 370, image = 'data/forest1-player.png'},
21
16
Tile:new{image = 'data/forest1-fg.png'}
25
20
objects = function() return {
26
21
Tile:new{image = 'data/shore-bg.png'},
27
Player:new{x = 145, y = 133,
28
minY = 133, maxY = 133,
29
image = 'data/shore-player.png'},
30
Tile:new{image = 'data/shore-fg.png'},
31
Transition:new{x = 10, y = 133, target = 'forest1',
32
targetX = 735, targetY = 370}
22
Player:new{x = 145, y = 133, image = 'data/shore-player.png'},
23
Tile:new{image = 'data/shore-fg.png'}
37
28
GameView = View:extend {
38
level = 'forest1', --default level
39
29
onNew = function (self)
40
--print('loading level: '..self.level)
41
for _, obj in ipairs(levels[self.level].objects()) do
44
for _, obj in ipairs(svg_objects[self.level]) do
30
self:newLevel('forest1')
32
--self:loadLayers('data/map.lua')
50
33
--self.focus = the.player
51
34
--self:clampTo(self.map)
58
41
onUpdate = function (self, dt)
59
42
if the.keys:justPressed('a') then
60
the.app.view = GameView:new{level = 'forest1'}
43
self:newLevel('forest1')
61
44
elseif the.keys:justPressed('b') then
62
the.app.view = GameView:new{level = 'shore'}
45
self:newLevel('shore')
48
newLevel = function (self, level)
49
self.sprites = levels[level].objects()
71
57
self.console:watch('VERSION', 'VERSION')
72
58
self.console:watch('updateTook', 'the.updateTook')
73
self.console:watch('view.tween.status', 'the.app.view.tween.status()')
74
self.console:watch('view.tween.active', 'the.app.view.tween.active')
75
59
--self.console:watch('drawTook', 'the.drawTook')
77
-- back off that dark overlay a bit
78
self.console.fill.fill[4] = 75
81
62
onUpdate = function (self, dt)