/ld27

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

« back to all changes in this revision

Viewing changes to main.lua

  • Committer: Josh C
  • Date: 2014-07-03 15:28:23 UTC
  • Revision ID: josh@9ix.org-20140703152823-4241je58pflhx7ec
scaling

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
STRICT = true
2
 
DEBUG = true
 
2
DEBUG = false
3
3
 
4
4
require 'zoetrope'
5
5
--require 'pepperprof'
22
22
              self.focus = the.player
23
23
              self:clampTo(self.bg)
24
24
 
 
25
              self.scale = the.app.scale
 
26
 
25
27
              self.mazes = {self.maze1, self.maze2, self.maze3}
26
28
              self.bgs = {self.bg, self.bg, self.bg2}
27
29
              for _, maze in ipairs(self.mazes) do maze:die() end
34
36
              self.maze2.playerScale = 0.5
35
37
              self.maze3.playerScale = 1
36
38
 
37
 
              self.goals = {}
 
39
              self.goals = {{},{},{}}
38
40
              the.goalsAchieved = 0
39
41
              for _, obj in ipairs(self.objects.sprites) do
40
42
                 if obj:instanceOf(Goal) then
41
43
                    obj.visible = false
42
 
                    self.goals[tonumber(obj.map)] = obj
 
44
                    table.insert(self.goals[tonumber(obj.map)], obj)
43
45
                 end
44
46
              end
45
47
 
60
62
              --the.profiler = newProfiler()
61
63
              --the.profiler:start()
62
64
 
63
 
              self.gameStart = love.timer.getMicroTime()
64
 
              self.lastChange = love.timer.getMicroTime()
 
65
              self.gameStart = love.timer.getTime()
 
66
              self.lastChange = love.timer.getTime()
65
67
           end,
66
68
   onUpdate = function(self, dt)
67
 
                 if the.player.active and love.timer.getMicroTime() > self.lastChange + 10 then
 
69
                 if the.player.active and love.timer.getTime() > self.lastChange + 10 then
68
70
                    -- switch maze
69
71
                    self:switchMaze()
70
72
                 end
71
73
 
72
74
                 if not (DEBUG and the.console.visible) then
73
 
                    --the.player.collider:collide(the.activeMaze)
74
 
                    the.player.collider:collide(the.activeGoal)
 
75
                    for _, goal in ipairs(the.activeGoals) do
 
76
                       the.player.collider:collide(goal)
 
77
                    end
75
78
                 end
76
79
 
77
80
                 if the.keys:justPressed('escape', 'q') then
92
95
                      the.activeBg.visible = false
93
96
                      the.activeBg = self.bgs[newMaze]
94
97
 
95
 
                      if the.activeGoal then
96
 
                         the.activeGoal.visible = false
 
98
                      for _, goal in ipairs(the.activeGoals) do
 
99
                         goal.visible = false
97
100
                      end
98
 
                      the.activeGoal = self.goals[newMaze]
 
101
                      the.activeGoals = self.goals[newMaze]
99
102
 
100
103
                      love.audio.play(self.switchSounds[math.random(#self.switchSounds)])
101
104
                   else
102
105
                      the.activeMaze = self.maze2
103
106
                      the.activeBg = self.bg
104
 
                      the.activeGoal = self.goals[2]
 
107
                      the.activeGoals = self.goals[2]
105
108
                   end
106
109
 
107
110
                   the.activeMaze:revive()
108
111
                   the.activeBg.visible = true
109
 
                   if the.activeGoal then
110
 
                      the.activeGoal.visible = true
 
112
                   for _, goal in ipairs(the.activeGoals) do
 
113
                      goal.visible = true
111
114
                   end
112
115
                   the.player.scale = the.activeMaze.playerScale
113
116
                   the.player.collider.width = the.player.width * the.activeMaze.playerScale
116
119
                   self._fx = {0,0,0,0}
117
120
                   self.tween:start(self._fx, 4, 175, 10, 'quadIn')
118
121
 
119
 
                   self.lastChange = love.timer.getMicroTime()
 
122
                   self.lastChange = love.timer.getTime()
120
123
                end,
121
124
   onEndFrame = function(self)
122
125
                   --the.interface.translate.x = the.player.x - the.app.width / 2 + the.player.width / 2
127
130
MenuScreen = View:extend {
128
131
   bg = Tile:new{image = 'data/intro.png', x = 0, y = 0},
129
132
   onNew = function(self)
 
133
              self.scale = the.app.scale
 
134
 
130
135
              self:add(self.bg)
131
136
              --self.title:centerAround(400, 200)
132
137
 
133
138
              local nr = 'data/NewRocker-Regular.otf'
134
139
              self:add(Text:new{
135
 
                          text = 'Name Of Game',
 
140
                          text = 'Treasures of the Decimaze',
136
141
                          --x = 0,
137
142
                          y = 100,
138
143
                          width = self.bg.width,
142
147
                       })
143
148
 
144
149
              self:add(Text:new{
145
 
                          text = 'Find the 3 lost shinies!',
 
150
                          text = 'Find the 4 lost shinies!',
146
151
                          y = 170,
147
152
                          width = self.bg.width,
148
153
                          font = {nr, 28},
178
183
}
179
184
 
180
185
the.app = App:new {
 
186
   width = 800,
 
187
   height = 600,
 
188
   name = "Treasures of the Decimaze",
181
189
   onRun = function (self)
182
190
              print('Version: ' .. VERSION)
183
191
 
184
192
              self.view = MenuScreen:new()
 
193
              self:setScaling()
185
194
 
186
195
              if DEBUG then
187
196
                 self.console:watch('VERSION', 'VERSION')
193
202
              end
194
203
           end,
195
204
   onUpdate = function (self, dt)
196
 
              end
 
205
                 if the.keys:justPressed('f1') then
 
206
                    local ss = love.graphics.newScreenshot()
 
207
                    ss:encode('screenshot-' ..love.timer.getTime()..'.png')
 
208
                 end
 
209
              end,
 
210
   setScaling = function(self)
 
211
     local winw, winh = love.window.getMode()
 
212
     --if love.window.getFullscreen() then
 
213
     if winw == self.width and winh == self.height then
 
214
       self.scale = 1
 
215
       self.view.realTranslate = { x=0, y=0 }
 
216
       love.graphics.setScissor()
 
217
     else
 
218
       --self.scale = math.min(
 
219
       --  math.floor(winw / the.app.viewWidth),
 
220
       --  math.floor(winh / the.app.viewHeight)
 
221
       --)
 
222
       if winh >= 1050 then
 
223
         self.scale = 1.5
 
224
       elseif winh < the.app.height then
 
225
         self.scale = winh / the.app.height
 
226
       end
 
227
       self.view.realTranslate.x = math.floor((winw - self.width * self.scale) / 2)
 
228
       self.view.realTranslate.y = math.floor((winh - self.height * self.scale) / 2)
 
229
       --print('translate: ' .. self.view.realTranslate.x .. ', ' .. self.view.realTranslate.y)
 
230
 
 
231
       love.graphics.setColor(0,0,0)
 
232
       love.graphics.rectangle('fill', 0, 0, winw, winh)
 
233
       love.graphics.setScissor( self.view.realTranslate.x,
 
234
                                 self.view.realTranslate.y,
 
235
                                 self.width * self.scale,
 
236
                                 self.height * self.scale)
 
237
     end
 
238
 
 
239
     self.view.scale = self.scale
 
240
   end
197
241
}
 
242
 
 
243
function love.resize(w, h)
 
244
  print('love.resize')
 
245
  the.app:setScaling()
 
246
end