93
91
the.storage.data = {highScore = 0}
96
--the.rockColliders = Group:new()
94
the.rockColliders = Group:new()
97
95
the.bullets = Group:new()
98
96
the.mirrors = Group:new()
99
--the.rocks = Group:new()
97
the.rocks = Group:new()
100
98
the.interface = Group:new()
101
the.planets = Group:new()
102
the.indicators = Group:new()
104
100
the.bg = Tile:new{
105
101
image = 'data/stars3.png',
111
self:add(the.planets)
113
108
--the.player = CrystalPlayer:new{x=400,y=300}
114
the.player = SpacePlayer:new{x=the.bg.width / 2, y=the.bg.height / 2}
109
the.player = SpacePlayer:new{x=1366,y=768}
115
110
self:add(the.player)
116
111
self:add(the.player.thrust)
118
113
--self:add(Enemy:new{x=400, y=300})
120
115
self:add(the.bullets)
121
--self:add(the.rockColliders)
116
self:add(the.rockColliders)
122
117
self:add(the.mirrors)
123
--self:add(the.rocks)
124
self:add(the.indicators)
125
119
self:add(the.interface)
127
for _ = 1, math.random(6) do
128
local planet = Planet:new{
129
x = math.random(the.app.width / 2,
130
the.bg.width - the.app.width / 2),
131
y = math.random(the.app.height / 2,
132
the.bg.height - the.app.height / 2),
133
rotation = math.random() * math.pi
135
the.planets:add(planet)
138
121
the.cursor = Cursor:new()
139
122
self:add(the.cursor)
192
175
self.gameStart = love.timer.getTime()
194
177
onUpdate = function(self, dt)
195
if false and the.player.active and love.timer.getTime() > self.lastRock + self.rockInterval then
178
if the.player.active and love.timer.getTime() > self.lastRock + self.rockInterval then
196
179
local unseenRock = nil
197
180
while not unseenRock do
198
181
local rock = Rock:new{
223
206
the.bullets:collide(the.rockColliders)
225
-- this should really go somewhere else...
226
for _, planet in ipairs(the.planets.sprites) do
228
local pvec = vector.new(
229
planet.x - the.player.x + planet.width / 2,
230
planet.y - the.player.y + planet.height / 2 )
232
-- TODO: is there a better way to specify the
234
if planet:intersects(the.player.x - the.app.width / 2,
235
the.player.y - the.app.height / 2,
238
-- planet is on the screen
239
planet.indicator.visible = false
241
planet.indicator.visible = true
243
if math.abs(pvec.x) / math.abs(pvec.y) > the.app.width / the.app.height then
244
indx = (the.app.width / 2 - 10) * util.signOf(pvec.x) + 8
245
indy = (the.app.width / 2 - 10) * pvec.y / math.abs(pvec.x)
247
indy = (the.app.height / 2 - 10) * util.signOf(pvec.y) + 8
248
indx = (the.app.height / 2 - 10) * pvec.x / math.abs(pvec.y)
251
planet.indicator.x = the.player.x + indx
252
planet.indicator.y = the.player.y + indy
256
208
-- for _, mirror in ipairs(the.mirrors.sprites) do
257
209
-- if not mirror.of then
258
210
-- print('mirror:' .. inspect(mirror))
309
261
self.view = GameView:new()
263
-- try going fullscreen. should fail silently if it
264
-- can't go to fullscreen.
265
love.graphics.toggleFullscreen()
312
268
self.console:watch('VERSION', 'VERSION')
313
269
self.console:watch('updateTook', 'the.updateTook')
317
273
self.console:watch('the.app.height', 'the.app.height')
318
274
self.console:watch('num mirrors', '#the.mirrors.sprites')
319
275
self.console:watch('num rocks', '#the.rocks.sprites')
320
self.console:watch('num planets', '#the.planets.sprites')
321
276
--self.console:watch('drawTook', 'the.drawTook')
323
278
-- back off that dark overlay a bit
327
282
onUpdate = function (self, dt)
328
if not (DEBUG and the.console.visible) then
329
if the.keys:justPressed('q') then
331
elseif the.keys:justPressed('return') then
332
if the.keys:pressed('alt') then
333
love.graphics.toggleFullscreen()
335
self.view = GameView:new()
337
elseif the.keys:justPressed('f1') then
338
local ss = love.graphics.newScreenshot()
339
ss:encode('screenshot-' ..love.timer.getTime()..'.png')
340
elseif the.keys:justPressed('f11') then
341
love.graphics.toggleFullscreen()
283
if the.keys:justPressed('q') then
285
elseif the.keys:justPressed('return') then
286
self.view = GameView:new()
287
elseif the.keys:justPressed('f1') then
288
local ss = love.graphics.newScreenshot()
289
ss:encode('screenshot-' ..love.timer.getTime()..'.png')
345
292
update = function (self, dt)