/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-04-10 23:47:59 UTC
  • Revision ID: josh@9ix.org-20130410234759-nrzne3xed1puy1v2
put sprite and player in their own files

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
6
--inspect = require 'inspect'
6
 
--_ = require 'underscore'
7
 
 
8
 
Player = Animation:extend {
9
 
   image = 'data/player.png',
10
 
   height = 32,
11
 
   width = 32,
12
 
   sequences = {
13
 
      stand = { frames = { 1 }, fps = 1 },
14
 
      walk = { frames = { 2, 3 }, fps = 5 },
15
 
      jump = { frames = { 4 }, fps = 1 }
16
 
   },
17
 
   onNew = function (self)
18
 
              self.velocity.y = 0
19
 
              self.maxVelocity.y = 400
20
 
           end,
21
 
   onStartFrame = function (self)
22
 
                     -- this is all in startframe so it happens before
23
 
                     -- physics calc at beginning of update
24
 
 
25
 
                     -- jumping/falling updates could go in EndFrame...
26
 
                     self.falling = self.velocity.y > 0
27
 
                     if self.falling then self.jumping = false end
28
 
                     --print(self.jumping, self.falling)
29
 
 
30
 
                     self.velocity.x = 0
31
 
                     self.acceleration.y = 800
32
 
 
33
 
                     if the.keys:pressed('left') then
34
 
                        self.velocity.x = -200
35
 
                        if self:onGround() then self:play('walk') end
36
 
                     elseif the.keys:pressed('right') then
37
 
                        self.velocity.x = 200
38
 
                        if self:onGround() then self:play('walk') end
39
 
                     else
40
 
                        if self:onGround() then self:play('stand') end
41
 
                     end
42
 
 
43
 
                     if the.keys:justPressed('up') and self:onGround() then
44
 
                        self.velocity.y = -400
45
 
                        self.jumping = true
46
 
                        self:play('jump')
47
 
                     end
48
 
                  end,
49
 
   onEndFrame = function (self)
50
 
                   --print(self.velocity.y)
51
 
                end,
52
 
   onCollide = function (self, other, xOverlap, yOverlap)
53
 
                  -- seriously, why does this even fire?
54
 
                  if other == the.view.map then return end
55
 
 
56
 
                  --print(string.format('col s{x=%i y=%i w=%i h=%i} %s', self.x, self.y, self.width, self.height, tostring(other)))
57
 
                  --print('vel.x:'..self.velocity.x.." vel.y:"..self.velocity.y)
58
 
 
59
 
                  -- assumption: any other collision is with a solid map tile
60
 
                  if yOverlap > xOverlap then
61
 
                     other:displace(self)
62
 
                  elseif xOverlap > yOverlap then
63
 
                     -- check if we've moved since collisions were generated
64
 
                     local xov, yov = self:overlap(other.x, other.y,
65
 
                                                   other.width, other.height)
66
 
                     if xov ~= 0 and yov ~= 0 then
67
 
                        self.velocity.y = 0
68
 
                        other:displace(self)
69
 
                        self.jumping = false
70
 
                     end
71
 
                  else
72
 
                     print('??')
73
 
                  end
74
 
 
75
 
               end,
76
 
   onGround = function (self)
77
 
                 return (not self.jumping) and (not self.falling)
78
 
              end
 
7
require 'pepperprof'
 
8
require 'getopt_alt'
 
9
 
 
10
util = {
 
11
   dim = function(dir)
 
12
      if dir == 'x' then
 
13
         return 'width'
 
14
      elseif dir == 'y' then
 
15
         return 'height'
 
16
      else
 
17
         if STRICT then error('dir '..dir) end
 
18
      end
 
19
   end
79
20
}
80
21
 
81
22
GameView = View:extend {
83
24
              self:loadLayers('data/map.lua')
84
25
              self.focus = the.player
85
26
              self:clampTo(self.map)
 
27
 
 
28
              the.recorder = Recorder:new{mousePosInterval = 9999}
 
29
              the.app.meta:add(the.recorder)
 
30
              if the.app.record then
 
31
                 the.recorder:startRecording()
 
32
              elseif the.app.playback then
 
33
                 local storage = Storage:new{filename = 'record.lua'}
 
34
                 storage:load()
 
35
                 --print(inspect(storage.data))
 
36
                 the.recorder.record = storage.data
 
37
                 the.recorder:startPlaying()
 
38
              end
86
39
           end,
87
40
   onUpdate = function (self)
 
41
                 --print('drawTook: ', the.drawTook)
88
42
                 --print('tick')
89
 
                 the.player:collide(self.map)
 
43
                 --the.player:collide(self.map)
90
44
                 --self.map:collide(the.player)
91
 
              end
 
45
              end,
 
46
   -- draw = function (self, x, y)
 
47
   --           View.draw(self, x, y)
 
48
 
 
49
   --           love.graphics.print('FPS:' .. love.timer.getFPS(), 20, 20)
 
50
   --        end
92
51
}
93
52
 
94
53
the.app = App:new {
 
54
   record = true,
95
55
   onRun = function (self)
96
56
              self.view = GameView:new()
97
 
              --print(inspect(_(the.app):keys()))
 
57
              self.console:watch('onGround', 'the.player.onGround')
 
58
              self.console:watch('onWall', 'the.player.onWall')
 
59
              self.console:watch('updateTook', 'the.updateTook')
 
60
              self.console:watch('drawTook', 'the.drawTook')
 
61
              self.console:watch('recorder state', 'the.recorder.state')
 
62
 
 
63
              --the.profiler = newProfiler('time', 2000)
 
64
              --the.profiler = newProfiler()
 
65
              --the.profiler:start()
98
66
           end,
99
67
   onUpdate = function (self, dt)
100
 
                 -- TODO: make this not work if debug console is active
101
68
                 if the.keys:justPressed('escape') then
102
 
                    love.event.quit()
 
69
                    if the.profiler then
 
70
                       the.profiler:stop()
 
71
                       local outfile = io.open( "profile.txt", "w+" )
 
72
                       the.profiler:report( outfile )
 
73
                       outfile:close()
 
74
                    end
 
75
 
 
76
                    if self.record then
 
77
                       if not love.filesystem.remove('record.lua') then
 
78
                          print('could not remove record.lua')
 
79
                       end
 
80
                       local storage = Storage:new{
 
81
                          data = the.recorder.record,
 
82
                          filename = 'record.lua'
 
83
                       }
 
84
                       storage:save(false)
 
85
                       --print(inspect(the.recorder.record))
 
86
                    end
 
87
 
 
88
                    self.quit()
103
89
                 end
104
 
              end
105
 
}
 
 
b'\\ No newline at end of file'
 
90
              end,
 
91
   update = function (self, dt)
 
92
               the.updateStart = love.timer.getMicroTime()
 
93
               App.update(self, dt)
 
94
               if the.updateStart then
 
95
                  the.updateTook = love.timer.getMicroTime() - the.updateStart
 
96
               end
 
97
            end
 
98
}
 
99
 
 
100
function love.load (arg)
 
101
   opts = getopt(arg, '')
 
102
   if opts['p'] then
 
103
      the.app.playback = true
 
104
      the.app.record = false
 
105
   elseif opts['r'] then
 
106
      the.app.record = true
 
107
   end
 
108
 
 
109
   the.app:run()
 
110
end
 
 
b'\\ No newline at end of file'