70
101
if self.falling then self.jumping = false end
71
102
--print(self.jumping, self.falling)
73
if not self.onGround then
104
if (not self.onGround) and (not self.onWall) then
78
108
self.acceleration.y = 800
111
self.acceleration.y = 0
113
if self.onWall == 'right' then
114
self:play('climbRight')
115
elseif self.onWall == 'left' then
116
self:play('climbLeft')
119
if the.keys:pressed('up') then
120
self.velocity.y = -200
121
elseif the.keys:pressed('down') then
122
self.velocity.y = 200
125
self:freeze(self.sequences[self.currentName].frames[1])
80
129
if the.keys:pressed('left') then
81
130
self.velocity.x = -200
82
131
if self.onGround then self:play('walk') end
132
if self.onWall == 'right' then
134
self.leftWallAt = love.timer.getTime()
83
136
elseif the.keys:pressed('right') then
84
137
self.velocity.x = 200
85
138
if self.onGround then self:play('walk') end
139
if self.onWall == 'left' then
141
self.leftWallAt = love.timer.getTime()
87
if self.onGround then self:play('stand') end
144
if not self.onWall then
145
if self.onGround then self:play('stand') end
90
if the.keys:justPressed('up') and self.onGround then
150
if the.keys:justPressed('up') and
151
(self.onGround or the.console.visible or
152
(love.timer.getTime() - self.leftWallAt < .1) ) then
91
153
self.velocity.y = -400
92
154
self.jumping = true
96
158
-- NOTE: this is an override, not a callback
98
160
self:doPhysics('x', elapsed)
161
self:collide(the.view.map)
163
-- handle X collisions
165
for _, col in ipairs(self.collisions) do
166
col.other:displaceDir(self, 'x')
167
if self.velocity.x > 0 then
168
self.onWall = 'right'
169
elseif self.velocity.x < 0 then
100
176
self.onGround = false -- right before Y collision callbacks
101
177
self:doPhysics('y', elapsed)
103
178
self:collide(the.view.map)
180
-- handle Y collisions
181
for _, col in ipairs(self.collisions) do
182
if self.velocity.y > 0 then
186
col.other:displaceDir(self, 'y')
192
if not self.text then
193
self.text = Text:new{wordWrap = true, width = 50, tint = {0,0,0}}
194
self.textfill = Fill:new{width = 54, border = {0,0,255}}
195
--the.view:add(self.textfill)
196
--the.view:add(self.text)
198
self.text.text = "Blah blah big text etc etc wrapping"
199
self.text:centerAround(self.x+16, self.y+16, 'horizontal')
200
_, texth = self.text:getSize()
201
self.text.y = self.y - texth - 4
202
self.textfill.x = self.text.x - 2
203
self.textfill.y = self.text.y - 2
204
self.textfill.height = texth + 4
206
Animation.update(self, elapsed)
208
collide = function (self, ...)
210
Animation.collide(self, ...)
211
-- I could return a true/false value here if I wanted to...
105
213
onCollide = function (self, other, xOverlap, yOverlap)
106
-- seriously, why does this even fire?
107
214
if other == the.view.map then return end
109
--print(string.format('col s{x=%i y=%i w=%i h=%i} %s', self.x, self.y, self.width, self.height, tostring(other)))
110
--print('vel.x:'..self.velocity.x.." vel.y:"..self.velocity.y)
112
-- assumption: any other collision is with a solid map tile
113
if yOverlap > xOverlap then
116
if self.velocity.x > 0 then
117
self.onWall = 'right'
118
elseif self.velocity.x < 0 then
123
elseif xOverlap > yOverlap then
124
-- check if we've moved since collisions were generated
125
local xov, yov = self:overlap(other.x, other.y,
126
other.width, other.height)
127
if xov ~= 0 and yov ~= 0 then
128
--print('y collision')
129
if self.velocity.y > 0 then
216
table.insert(self.collisions, {other = other,
218
yOverlap = yOverlap })
222
-- displace on a specific axis (monkey patch Sprite)
223
function Sprite:displaceDir(other, dir)
224
if not self.solid or self == other or not other.solid then return end
225
if STRICT then assert(other:instanceOf(Sprite), 'asked to displace a non-sprite') end
227
if other.sprites then
230
for _, spr in pairs(other.sprites) do
231
self:displace(spr, dir)
235
local dim = util.dim(dir)
237
local negMove = (other[dir] - self[dir]) + other[dim]
238
local posMove = (self[dir] + self[dim]) - other[dir]
240
-- TODO: re-add hinting?
241
if negMove < posMove then
248
other[dir] = other[dir] + chg
251
-- don't use zoetrope physics
252
function Sprite:update (elapsed)
253
if self.onUpdate then self:onUpdate(elapsed) end
144
256
GameView = View:extend {
145
257
onNew = function (self)
146
258
self:loadLayers('data/map.lua')
147
259
self.focus = the.player
148
260
self:clampTo(self.map)
262
the.recorder = Recorder:new{mousePosInterval = 9999}
263
the.app.meta:add(the.recorder)
264
if the.app.record then
265
the.recorder:startRecording()
266
elseif the.app.playback then
267
local storage = Storage:new{filename = 'record.lua'}
269
--print(inspect(storage.data))
270
the.recorder.record = storage.data
271
the.recorder:startPlaying()
150
274
onUpdate = function (self)
275
--print('drawTook: ', the.drawTook)
152
277
--the.player:collide(self.map)
153
278
--self.map:collide(the.player)
280
-- draw = function (self, x, y)
281
-- View.draw(self, x, y)
283
-- love.graphics.print('FPS:' .. love.timer.getFPS(), 20, 20)
157
287
the.app = App:new {
158
289
onRun = function (self)
159
290
self.view = GameView:new()
160
--print(inspect(_(the.app):keys()))
161
291
self.console:watch('onGround', 'the.player.onGround')
162
292
self.console:watch('onWall', 'the.player.onWall')
293
self.console:watch('updateTook', 'the.updateTook')
294
self.console:watch('drawTook', 'the.drawTook')
295
self.console:watch('recorder state', 'the.recorder.state')
297
--the.profiler = newProfiler('time', 2000)
298
--the.profiler = newProfiler()
299
--the.profiler:start()
164
301
onUpdate = function (self, dt)
165
if the.keys:justPressed('escape') and
166
not self.console.visible then
302
if the.keys:justPressed('escape') then
305
local outfile = io.open( "profile.txt", "w+" )
306
the.profiler:report( outfile )
311
if not love.filesystem.remove('record.lua') then
312
print('could not remove record.lua')
314
local storage = Storage:new{
315
data = the.recorder.record,
316
filename = 'record.lua'
319
--print(inspect(the.recorder.record))
b'\\ No newline at end of file'
325
update = function (self, dt)
326
the.updateStart = love.timer.getMicroTime()
328
if the.updateStart then
329
the.updateTook = love.timer.getMicroTime() - the.updateStart
334
function love.load (arg)
335
opts = getopt(arg, '')
337
the.app.playback = true
338
the.app.record = false
339
elseif opts['r'] then
340
the.app.record = true
b'\\ No newline at end of file'