/zoeplat

To get this branch, use:
bzr branch http://9ix.org/bzr/zoeplat

« back to all changes in this revision

Viewing changes to main.lua

  • Committer: Josh C
  • Date: 2013-03-16 15:56:20 UTC
  • Revision ID: josh@9ix.org-20130316155620-q8dze43bqqilhtmu
profiling and analysis

Show diffs side-by-side

added added

removed removed

Lines of Context:
2
2
DEBUG = true
3
3
 
4
4
require 'zoetrope'
5
 
_ = require 'underscore'
 
5
__ = require 'underscore'
6
6
--inspect = require 'inspect'
 
7
require 'pepperprof'
7
8
 
8
9
Player = Animation:extend {
9
10
   image = 'data/player.png',
12
13
   sequences = {
13
14
      stand = { frames = { 1 }, fps = 1 },
14
15
      walk = { frames = { 2, 3 }, fps = 5 },
15
 
      jump = { frames = { 4 }, fps = 1 }
 
16
      jump = { frames = { 4 }, fps = 1 },
 
17
      climbLeft = { frames = { 5, 6 }, fps = 5 },
 
18
      climbRight = { frames = { 7, 8 }, fps = 5 }
16
19
   },
 
20
   collisions = {},
 
21
   onWall = false,
 
22
   leftWallAt = 0,
17
23
   onNew = function (self)
18
24
              self.velocity.y = 0
19
25
              self.maxVelocity.y = 400
33
39
                     assert(drag, 'active sprite has no drag property')
34
40
                     assert(minVel, 'active sprite has no minVelocity property')
35
41
                     assert(maxVel, 'active sprite has no maxVelocity property')
36
 
                     assert(_.include({'x','y','rotation'}, dir), 'direction should be x, y, or rotation')
 
42
                     assert(__.include({'x','y','rotation'}, dir), 'direction should be x, y, or rotation')
37
43
                  end
38
44
 
39
45
                  vel.x = vel.x or 0
70
76
                     if self.falling then self.jumping = false end
71
77
                     --print(self.jumping, self.falling)
72
78
 
73
 
                     if not self.onGround then
 
79
                     if (not self.onGround) and (not self.onWall) then
74
80
                        self:play('jump')
75
81
                     end
76
82
 
77
 
                     self.velocity.x = 0
78
83
                     self.acceleration.y = 800
79
84
 
 
85
                     if self.onWall then
 
86
                        self.acceleration.y = 0
 
87
 
 
88
                        if self.onWall == 'right' then
 
89
                           self:play('climbRight')
 
90
                        elseif self.onWall == 'left' then
 
91
                           self:play('climbLeft')
 
92
                        end
 
93
 
 
94
                        if the.keys:pressed('up') then
 
95
                           self.velocity.y = -200
 
96
                        elseif the.keys:pressed('down') then
 
97
                           self.velocity.y = 200
 
98
                        else
 
99
                           self.velocity.y = 0
 
100
                           self:freeze(self.sequences[self.currentName].frames[1])
 
101
                        end
 
102
                     end
 
103
 
80
104
                     if the.keys:pressed('left') then
81
105
                        self.velocity.x = -200
82
106
                        if self.onGround then self:play('walk') end
 
107
                        if self.onWall == 'right' then
 
108
                           self.onWall = false
 
109
                           self.leftWallAt = love.timer.getTime()
 
110
                        end
83
111
                     elseif the.keys:pressed('right') then
84
112
                        self.velocity.x = 200
85
113
                        if self.onGround then self:play('walk') end
 
114
                        if self.onWall == 'left' then
 
115
                           self.onWall = false
 
116
                           self.leftWallAt = love.timer.getTime()
 
117
                        end
86
118
                     else
87
 
                        if self.onGround then self:play('stand') end
 
119
                        if not self.onWall then
 
120
                           if self.onGround then self:play('stand') end
 
121
                           self.velocity.x = 0
 
122
                        end
88
123
                     end
89
124
 
90
 
                     if the.keys:justPressed('up') and self.onGround then
 
125
                     if the.keys:justPressed('up') and
 
126
                      (self.onGround or
 
127
                       (love.timer.getTime() - self.leftWallAt < .1) ) then
91
128
                        self.velocity.y = -400
92
129
                        self.jumping = true
93
130
                     end
96
133
               -- NOTE: this is an override, not a callback
97
134
 
98
135
               self:doPhysics('x', elapsed)
 
136
               self:collide(the.view.map)
 
137
 
 
138
               -- handle X collisions
 
139
               self.onWall = false
 
140
               for _, col in ipairs(self.collisions) do
 
141
                  col.other:displaceDir(self, 'x')
 
142
                  if self.velocity.x > 0 then
 
143
                     self.onWall = 'right'
 
144
                  elseif self.velocity.x < 0 then
 
145
                     self.onWall = 'left'
 
146
                  else
 
147
                     print 'x ??'
 
148
                  end
 
149
               end
99
150
 
100
151
               self.onGround = false -- right before Y collision callbacks
101
152
               self:doPhysics('y', elapsed)
102
 
 
103
153
               self:collide(the.view.map)
 
154
 
 
155
               -- handle Y collisions
 
156
               for _, col in ipairs(self.collisions) do
 
157
                  if self.velocity.y > 0 then
 
158
                     self.onGround = true
 
159
                  end
 
160
 
 
161
                  col.other:displaceDir(self, 'y')
 
162
                  self.velocity.y = 0
 
163
                  self.jumping = false
 
164
               end
 
165
 
 
166
               Animation.update(self, elapsed)
104
167
            end,
 
168
   collide = function (self, ...)
 
169
                self.collisions = {}
 
170
                Animation.collide(self, ...)
 
171
                -- I could return a true/false value here if I wanted to...
 
172
             end,
105
173
   onCollide = function (self, other, xOverlap, yOverlap)
106
 
                  -- seriously, why does this even fire?
107
174
                  if other == the.view.map then return end
108
175
 
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)
111
 
 
112
 
                  -- assumption: any other collision is with a solid map tile
113
 
                  if yOverlap > xOverlap then
114
 
                     other:displace(self)
115
 
 
116
 
                     if self.velocity.x > 0 then
117
 
                        self.onWall = 'right'
118
 
                     elseif self.velocity.x < 0 then
119
 
                        self.onWall = 'left'
120
 
                     else
121
 
                        print 'x ??'
122
 
                     end
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
130
 
                           self.onGround = true
131
 
                        end
132
 
 
133
 
                        self.velocity.y = 0
134
 
                        other:displace(self)
135
 
                        self.jumping = false
136
 
                     end
137
 
                  else
138
 
                     print('xy ??')
139
 
                  end
140
 
 
141
 
               end,
 
176
                  table.insert(self.collisions, {other = other,
 
177
                                                 xOverlap = xOverlap,
 
178
                                                 yOverlap = yOverlap })
 
179
               end
142
180
}
143
181
 
 
182
-- displace on a specific axis (monkey patch Sprite)
 
183
function Sprite:displaceDir(other, dir)
 
184
   if not self.solid or self == other or not other.solid then return end
 
185
   if STRICT then assert(other:instanceOf(Sprite), 'asked to displace a non-sprite') end
 
186
 
 
187
   if other.sprites then
 
188
      -- handle groups
 
189
 
 
190
      for _, spr in pairs(other.sprites) do
 
191
         self:displace(spr, dir)
 
192
      end
 
193
   else
 
194
      -- handle sprites
 
195
      local dim
 
196
      if dir == 'x' then
 
197
         dim = 'width'
 
198
      elseif dir == 'y' then
 
199
         dim = 'height'
 
200
      else
 
201
         print 'dir ??'
 
202
      end
 
203
 
 
204
      local negMove = (other[dir] - self[dir]) + other[dim]
 
205
      local posMove = (self[dir] + self[dim]) - other[dir]
 
206
 
 
207
      -- TODO: re-add hinting?
 
208
      if negMove < posMove then
 
209
         chg = - negMove
 
210
      else
 
211
         chg = posMove
 
212
      end
 
213
   end
 
214
 
 
215
   other[dir] = other[dir] + chg
 
216
end
 
217
 
144
218
GameView = View:extend {
145
219
   onNew = function (self)
146
220
              self:loadLayers('data/map.lua')
157
231
the.app = App:new {
158
232
   onRun = function (self)
159
233
              self.view = GameView:new()
160
 
              --print(inspect(_(the.app):keys()))
161
234
              self.console:watch('onGround', 'the.player.onGround')
162
235
              self.console:watch('onWall', 'the.player.onWall')
 
236
              self.console:watch('updateTook', 'the.updateTook')
 
237
              self.console:watch('drawTook', 'the.drawTook')
 
238
 
 
239
              --the.profiler = newProfiler('time', 2000)
 
240
              --the.profiler = newProfiler()
 
241
              --the.profiler:start()
163
242
           end,
164
243
   onUpdate = function (self, dt)
165
 
                 if the.keys:justPressed('escape') and 
166
 
                   not self.console.visible then
 
244
                 if the.keys:justPressed('escape') then
 
245
                    if the.profiler then
 
246
                       the.profiler:stop()
 
247
                       local outfile = io.open( "profile.txt", "w+" )
 
248
                       the.profiler:report( outfile )
 
249
                       outfile:close()
 
250
                    end
 
251
 
167
252
                    self.quit()
168
253
                 end
169
 
              end
170
 
}
 
 
b'\\ No newline at end of file'
 
254
              end,
 
255
   update = function (self, dt)
 
256
               the.updateStart = love.timer.getMicroTime()
 
257
               App.update(self, dt)
 
258
               if the.updateStart then
 
259
                  the.updateTook = love.timer.getMicroTime() - the.updateStart
 
260
               end
 
261
            end
 
262
}