9
image = 'data/player.png',
10
onNew = function (self)
13
onStartFrame = function (self)
14
-- this is all in startframe so it happens before
15
-- physics calc at beginning of update
18
-- TODO: this can be replaced with sprite.maxVel.y
19
if self.velocity.y >= TERM_VEL then
20
self.velocity.y = TERM_VEL
21
self.acceleration.y = 0
23
self.acceleration.y = 800
26
if the.keys:pressed('left') then
27
self.velocity.x = -200
28
elseif the.keys:pressed('right') then
32
if the.keys:justPressed('up') then
33
self.velocity.y = -400
36
onUpdate = function (self)
37
-- this is called after physics, so this makes sense here
38
the.view.map:subdisplace(self)
5
__ = require 'underscore'
6
--inspect = require 'inspect'
19
elseif dir == 'y' then
22
if STRICT then error('dir '..dir) end
42
27
GameView = View:extend {
44
29
self:loadLayers('data/map.lua')
45
30
self.focus = the.player
46
31
self:clampTo(self.map)
33
the.recorder = Recorder:new{mousePosInterval = 9999}
34
the.app.meta:add(the.recorder)
35
if the.app.record then
36
the.recorder:startRecording()
37
elseif the.app.playback then
38
local storage = Storage:new{filename = 'record.lua'}
40
--print(inspect(storage.data))
41
the.recorder.record = storage.data
42
the.recorder:startPlaying()
45
onUpdate = function (self)
46
--print('drawTook: ', the.drawTook)
48
--the.player:collide(self.map)
49
--self.map:collide(the.player)
51
-- draw = function (self, x, y)
52
-- View.draw(self, x, y)
54
-- love.graphics.print('FPS:' .. love.timer.getFPS(), 20, 20)
50
58
the.app = App:new {
51
60
onRun = function (self)
52
61
self.view = GameView:new()
63
self.console:watch('onGround', 'the.player.onGround')
64
self.console:watch('onWall', 'the.player.onWall')
65
self.console:watch('updateTook', 'the.updateTook')
66
self.console:watch('drawTook', 'the.drawTook')
67
self.console:watch('recorder state', 'the.recorder.state')
70
--the.profiler = newProfiler('time', 2000)
71
--the.profiler = newProfiler()
72
--the.profiler:start()
54
74
onUpdate = function (self, dt)
55
75
if the.keys:justPressed('escape') then
78
local outfile = io.open( "profile.txt", "w+" )
79
the.profiler:report( outfile )
84
if not love.filesystem.remove('record.lua') then
85
print('could not remove record.lua')
87
local storage = Storage:new{
88
data = the.recorder.record,
89
filename = 'record.lua'
92
--print(inspect(the.recorder.record))
b'\\ No newline at end of file'
98
update = function (self, dt)
99
the.updateStart = love.timer.getMicroTime()
101
if the.updateStart then
102
the.updateTook = love.timer.getMicroTime() - the.updateStart
107
function love.load (arg)
108
opts = getopt(arg, '')
110
the.app.playback = true
111
the.app.record = false
112
elseif opts['r'] then
113
the.app.record = true
b'\\ No newline at end of file'