5
_ = require 'underscore'
5
6
--inspect = require 'inspect'
6
--_ = require 'underscore'
8
8
Player = Animation:extend {
9
9
image = 'data/player.png',
18
18
self.velocity.y = 0
19
19
self.maxVelocity.y = 400
21
doPhysics = function (self, dir, elapsed)
22
local vel = self.velocity
23
local acc = self.acceleration
24
local drag = self.drag
25
local minVel = self.minVelocity
26
local maxVel = self.maxVelocity
28
-- check existence of properties
31
assert(vel, 'active sprite has no velocity property')
32
assert(acc, 'active sprite has no acceleration property')
33
assert(drag, 'active sprite has no drag property')
34
assert(minVel, 'active sprite has no minVelocity property')
35
assert(maxVel, 'active sprite has no maxVelocity property')
36
assert(_.include({'x','y','rotation'}, dir), 'direction should be x, y, or rotation')
41
vel.rotation = vel.rotation or 0
45
if acc[dir] and acc[dir] ~= 0 then
46
vel[dir] = vel[dir] + acc[dir] * elapsed
50
vel[dir] = vel[dir] - drag[dir] * elapsed
51
if vel[dir] < 0 then vel[dir] = 0 end
52
elseif vel[dir] < 0 then
53
vel[dir] = vel[dir] + drag[dir] * elapsed
54
if vel[dir] > 0 then vel[dir] = 0 end
59
if minVel[dir] and vel[dir] < minVel[dir] then vel[dir] = minVel[dir] end
60
if maxVel[dir] and vel[dir] > maxVel[dir] then vel[dir] = maxVel[dir] end
62
if vel[dir] ~= 0 then self[dir] = self[dir] + vel[dir] * elapsed end
21
64
onStartFrame = function (self)
22
65
-- this is all in startframe so it happens before
23
66
-- physics calc at beginning of update
27
70
if self.falling then self.jumping = false end
28
71
--print(self.jumping, self.falling)
30
if not self:onGround() then
73
if not self.onGround then
37
80
if the.keys:pressed('left') then
38
81
self.velocity.x = -200
39
if self:onGround() then self:play('walk') end
82
if self.onGround then self:play('walk') end
40
83
elseif the.keys:pressed('right') then
41
84
self.velocity.x = 200
42
if self:onGround() then self:play('walk') end
85
if self.onGround then self:play('walk') end
44
if self:onGround() then self:play('stand') end
87
if self.onGround then self:play('stand') end
47
if the.keys:justPressed('up') and self:onGround() then
90
if the.keys:justPressed('up') and self.onGround then
48
91
self.velocity.y = -400
49
92
self.jumping = true
52
onEndFrame = function (self)
53
--print(self.velocity.y)
95
update = function (self, elapsed)
96
-- NOTE: this is an override, not a callback
98
self:doPhysics('x', elapsed)
100
self.onGround = false -- right before Y collision callbacks
101
self:doPhysics('y', elapsed)
103
self:collide(the.view.map)
55
105
onCollide = function (self, other, xOverlap, yOverlap)
56
106
-- seriously, why does this even fire?
57
107
if other == the.view.map then return end
62
112
-- assumption: any other collision is with a solid map tile
63
113
if yOverlap > xOverlap then
64
114
other:displace(self)
116
if self.velocity.x > 0 then
117
self.onWall = 'right'
118
elseif self.velocity.x < 0 then
65
123
elseif xOverlap > yOverlap then
66
124
-- check if we've moved since collisions were generated
67
125
local xov, yov = self:overlap(other.x, other.y,
68
126
other.width, other.height)
69
127
if xov ~= 0 and yov ~= 0 then
128
--print('y collision')
129
if self.velocity.y > 0 then
70
133
self.velocity.y = 0
71
134
other:displace(self)
72
135
self.jumping = false
79
onGround = function (self)
80
return (not self.jumping) and (not self.falling)
84
144
GameView = View:extend {
98
158
onRun = function (self)
99
159
self.view = GameView:new()
100
160
--print(inspect(_(the.app):keys()))
161
self.console:watch('onGround', 'the.player.onGround')
162
self.console:watch('onWall', 'the.player.onWall')
102
164
onUpdate = function (self, dt)
103
165
if the.keys:justPressed('escape') and
104
166
not self.console.visible then
b'\\ No newline at end of file'