/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-09 06:03:56 UTC
  • Revision ID: josh@9ix.org-20130309060356-qvi2yd0odhfr3e6t
try to track X collisions.  break out Sprite's physics in prep for 
overriding them completely.

Show diffs side-by-side

added added

removed removed

Lines of Context:
2
2
DEBUG = true
3
3
 
4
4
require 'zoetrope'
 
5
--inspect = require 'inspect'
 
6
--_ = require 'underscore'
5
7
 
6
 
Player = Tile:extend {
 
8
Player = Animation:extend {
7
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
   },
8
17
   onNew = function (self)
9
18
              self.velocity.y = 0
10
19
              self.maxVelocity.y = 400
13
22
                     -- this is all in startframe so it happens before
14
23
                     -- physics calc at beginning of update
15
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
                     if not self.onGround then
 
31
                        self:play('jump')
 
32
                     end
 
33
 
16
34
                     self.velocity.x = 0
17
35
                     self.acceleration.y = 800
18
36
 
19
37
                     if the.keys:pressed('left') then
20
38
                        self.velocity.x = -200
 
39
                        if self.onGround then self:play('walk') end
21
40
                     elseif the.keys:pressed('right') then
22
41
                        self.velocity.x = 200
 
42
                        if self.onGround then self:play('walk') end
 
43
                     else
 
44
                        if self.onGround then self:play('stand') end
23
45
                     end
24
46
 
25
 
                     if the.keys:justPressed('up') then
 
47
                     if the.keys:justPressed('up') and self.onGround then
26
48
                        self.velocity.y = -400
 
49
                        self.jumping = true
27
50
                     end
28
51
                  end,
29
52
   onUpdate = function (self)
30
 
                 -- this is called after physics, so this makes sense here
31
 
                 the.view.map:subdisplace(self)
32
 
              end
 
53
                 -- needs to happen right before collision
 
54
                 self.onGround = false
 
55
                end,
 
56
   onCollide = function (self, other, xOverlap, yOverlap)
 
57
                  -- seriously, why does this even fire?
 
58
                  if other == the.view.map then return end
 
59
 
 
60
                  --print(string.format('col s{x=%i y=%i w=%i h=%i} %s', self.x, self.y, self.width, self.height, tostring(other)))
 
61
                  --print('vel.x:'..self.velocity.x.." vel.y:"..self.velocity.y)
 
62
 
 
63
                  -- assumption: any other collision is with a solid map tile
 
64
                  if yOverlap > xOverlap then
 
65
                     other:displace(self)
 
66
 
 
67
                     if self.velocity.x > 0 then
 
68
                        self.onWall = 'right'
 
69
                     elseif self.velocity.x < 0 then
 
70
                        self.onWall = 'left'
 
71
                     else
 
72
                        print '??'
 
73
                     end
 
74
                  elseif xOverlap > yOverlap then
 
75
                     -- check if we've moved since collisions were generated
 
76
                     local xov, yov = self:overlap(other.x, other.y,
 
77
                                                   other.width, other.height)
 
78
                     if xov ~= 0 and yov ~= 0 then
 
79
                        --print('y collision')
 
80
                        if self.velocity.y > 0 then
 
81
                           self.onGround = true
 
82
                        end
 
83
 
 
84
                        self.velocity.y = 0
 
85
                        other:displace(self)
 
86
                        self.jumping = false
 
87
                     end
 
88
                  else
 
89
                     print('??')
 
90
                  end
 
91
 
 
92
               end,
33
93
}
34
94
 
35
95
GameView = View:extend {
37
97
              self:loadLayers('data/map.lua')
38
98
              self.focus = the.player
39
99
              self:clampTo(self.map)
40
 
           end
 
100
           end,
 
101
   onUpdate = function (self)
 
102
                 --print('tick')
 
103
                 the.player:collide(self.map)
 
104
                 --self.map:collide(the.player)
 
105
              end
41
106
}
42
107
 
43
108
the.app = App:new {
44
109
   onRun = function (self)
45
110
              self.view = GameView:new()
 
111
              --print(inspect(_(the.app):keys()))
 
112
              self.console:watch('onGround', 'the.player.onGround')
 
113
              self.console:watch('onWall', 'the.player.onWall')
46
114
           end,
47
115
   onUpdate = function (self, dt)
48
 
                 if the.keys:justPressed('escape') then
 
116
                 if the.keys:justPressed('escape') and 
 
117
                   not self.console.visible then
49
118
                    love.event.quit()
50
119
                 end
51
120
              end