|
@@ -12,6 +12,8 @@ player={
|
|
gun_down=0,
|
|
gun_down=0,
|
|
gun_anim=0,
|
|
gun_anim=0,
|
|
gun_held=0,
|
|
gun_held=0,
|
|
|
|
+ is_firing=0,
|
|
|
|
+ big_gun_cooldown=0,
|
|
}
|
|
}
|
|
gunsprites={
|
|
gunsprites={
|
|
292, -- vulcan
|
|
292, -- vulcan
|
|
@@ -50,6 +52,8 @@ multiplier_sub = 0
|
|
multiplier_tick = 0
|
|
multiplier_tick = 0
|
|
score = 25000
|
|
score = 25000
|
|
|
|
|
|
|
|
+
|
|
|
|
+
|
|
t=0
|
|
t=0
|
|
math.randomseed(seed)
|
|
math.randomseed(seed)
|
|
|
|
|
|
@@ -88,10 +92,14 @@ end
|
|
function drawPlayer()
|
|
function drawPlayer()
|
|
if (player.show) then
|
|
if (player.show) then
|
|
-- arm
|
|
-- arm
|
|
- if player.gun_down then
|
|
|
|
- spr(260, player.x+12, player.y+11, 0, 1, 0, 0, 2, 1)
|
|
|
|
|
|
+ if player.gun_anim > 0 then
|
|
|
|
+ --spr(260, player.x+12, player.y+11, 0, 1, 0, 3, 2, 1)
|
|
else
|
|
else
|
|
- spr(260, player.x+12, player.y-2, 0, 1, 2, 0, 2, 1)
|
|
|
|
|
|
+ if player.gun_down then
|
|
|
|
+ spr(260, player.x+12, player.y+11, 0, 1, 0, 0, 2, 1)
|
|
|
|
+ else
|
|
|
|
+ spr(260, player.x+12, player.y-2, 0, 1, 2, 0, 2, 1)
|
|
|
|
+ end
|
|
end
|
|
end
|
|
|
|
|
|
-- ship
|
|
-- ship
|
|
@@ -102,6 +110,14 @@ function drawPlayer()
|
|
spr(262, val.x, val.y, 0)
|
|
spr(262, val.x, val.y, 0)
|
|
end
|
|
end
|
|
|
|
|
|
|
|
+ -- draw big bullets
|
|
|
|
+ for key,val in ipairs(p_big_bullets) do
|
|
|
|
+ local spritenum = 0
|
|
|
|
+ if val.type == 2 then spritenum = 282 end
|
|
|
|
+ if val.type == 3 then spritenum = 267 end
|
|
|
|
+ spr(spritenum, val.x, val.y, 0)
|
|
|
|
+ end
|
|
|
|
+
|
|
-- custom routines depending on gun held
|
|
-- custom routines depending on gun held
|
|
if player.gun_held > 0 then
|
|
if player.gun_held > 0 then
|
|
local gunsprite = gunsprites[player.gun_held]
|
|
local gunsprite = gunsprites[player.gun_held]
|
|
@@ -110,7 +126,11 @@ function drawPlayer()
|
|
gunsprite = gunsprite + 16
|
|
gunsprite = gunsprite + 16
|
|
gunpos = gunpos + 14
|
|
gunpos = gunpos + 14
|
|
end
|
|
end
|
|
- spr(gunsprite, player.x+12, gunpos, 0, 1, 0, 0, 2, 1)
|
|
|
|
|
|
+ if player.gun_anim > 0 then
|
|
|
|
+ spr(gunsprite, player.x+3, gunpos, 0, 1, 0, 3, 2, 1)
|
|
|
|
+ else
|
|
|
|
+ spr(gunsprite, player.x+12, gunpos, 0, 1, 0, 0, 2, 1)
|
|
|
|
+ end
|
|
|
|
|
|
-- vulcan
|
|
-- vulcan
|
|
if player.gun_held == 1 then
|
|
if player.gun_held == 1 then
|
|
@@ -124,41 +144,64 @@ function drawPlayer()
|
|
else
|
|
else
|
|
player.fire = player.fire - 1
|
|
player.fire = player.fire - 1
|
|
end
|
|
end
|
|
|
|
+
|
|
|
|
+ -- not tracking individual bullets with vulcan
|
|
|
|
+
|
|
-- begin dakka
|
|
-- begin dakka
|
|
- if muzzleIdx > 0 then
|
|
|
|
- if player.gun_down then
|
|
|
|
- spr(vulcanMuzzleSprites[muzzleIdx], player.x + 27, player.y + 14, 0, 1, flipfire, 0, 2, 1)
|
|
|
|
- else
|
|
|
|
- spr(vulcanMuzzleSprites[muzzleIdx], player.x + 28, player.y - 2, 0, 1, flipfire, 0, 2, 1)
|
|
|
|
- end
|
|
|
|
- end
|
|
|
|
- if t % 10 == 0 then
|
|
|
|
- local randFactor = math.random(10,100)
|
|
|
|
- local spawnOffsetY = 1
|
|
|
|
-
|
|
|
|
- local lineStart = math.random(player.x+20, 260)
|
|
|
|
- if player.gun_down then
|
|
|
|
- spawnOffsetY = 18
|
|
|
|
- -- vulcan tilts downward so we get to do trig! yay!
|
|
|
|
- lineStart = lineStart - player.x
|
|
|
|
- local angle = 8
|
|
|
|
- local radius2 = lineStart+38
|
|
|
|
- local c = math.cos(angle * math.pi / 180)
|
|
|
|
- local s = math.sin(angle * math.pi / 180)
|
|
|
|
- line(c * lineStart + player.x + 18, s * lineStart + player.y + 17, c * radius2 + player.x + 18, s * radius2 + player.y + 17, 14)
|
|
|
|
- else
|
|
|
|
- line(lineStart, player.y+1, lineStart+40, player.y+1, 14)
|
|
|
|
|
|
+ if player.is_firing > 0 then
|
|
|
|
+ if muzzleIdx > 0 then
|
|
|
|
+ if player.gun_down then
|
|
|
|
+ spr(vulcanMuzzleSprites[muzzleIdx], player.x + 27, player.y + 14, 0, 1, flipfire, 0, 2, 1)
|
|
|
|
+ else
|
|
|
|
+ spr(vulcanMuzzleSprites[muzzleIdx], player.x + 28, player.y - 2, 0, 1, flipfire, 0, 2, 1)
|
|
|
|
+ end
|
|
end
|
|
end
|
|
|
|
+ if t % 10 == 0 then
|
|
|
|
+ local randFactor = math.random(10,100)
|
|
|
|
+ local spawnOffsetY = 1
|
|
|
|
+
|
|
|
|
+ local lineStart = math.random(player.x+20, 260)
|
|
|
|
+ if player.gun_down then
|
|
|
|
+ spawnOffsetY = 18
|
|
|
|
+ -- vulcan tilts downward so we get to do trig! yay!
|
|
|
|
+ lineStart = lineStart - player.x
|
|
|
|
+ local angle = 8
|
|
|
|
+ local radius2 = lineStart+38
|
|
|
|
+ local c = math.cos(angle * math.pi / 180)
|
|
|
|
+ local s = math.sin(angle * math.pi / 180)
|
|
|
|
+ line(c * lineStart + player.x + 18, s * lineStart + player.y + 17, c * radius2 + player.x + 18, s * radius2 + player.y + 17, 14)
|
|
|
|
+ else
|
|
|
|
+ line(lineStart, player.y+1, lineStart+40, player.y+1, 14)
|
|
|
|
+ end
|
|
|
|
|
|
- -- shells
|
|
|
|
- spawnPixelParticle(player.x+14, player.y+spawnOffsetY, -0.2, -0.6 + (randFactor / 100), 0, 50, 15)
|
|
|
|
|
|
+ -- shells
|
|
|
|
+ spawnPixelParticle(player.x+14, player.y+spawnOffsetY, -0.2, -0.6 + (randFactor / 100), 0, 50, 15)
|
|
|
|
+ end
|
|
end
|
|
end
|
|
|
|
+
|
|
|
|
+
|
|
-- update shells with light gravity
|
|
-- update shells with light gravity
|
|
for i=1,#shellParticles do
|
|
for i=1,#shellParticles do
|
|
local p = shellParticles[i]
|
|
local p = shellParticles[i]
|
|
p.vy = p.vy + 0.1
|
|
p.vy = p.vy + 0.1
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
+
|
|
|
|
+ -- cannon
|
|
|
|
+ if player.gun_held == 2 then
|
|
|
|
+ if player.fire == 0 then
|
|
|
|
+ player.fire = 30
|
|
|
|
+ else
|
|
|
|
+ player.fire = player.fire - 1
|
|
|
|
+ end
|
|
|
|
+
|
|
|
|
+ -- todo: move to update()
|
|
|
|
+ for i=1, #p_big_bullets do
|
|
|
|
+ if p_big_bullets[i].x < 250 then
|
|
|
|
+ p_big_bullets[i].x = p_big_bullets[i].x + 10
|
|
|
|
+ end
|
|
|
|
+ end
|
|
|
|
+ end
|
|
end
|
|
end
|
|
|
|
|
|
for i=1,#shellParticles do
|
|
for i=1,#shellParticles do
|
|
@@ -171,6 +214,8 @@ function drawPlayer()
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
+
|
|
|
|
+ if player.gun_anim > 0 then player.gun_anim = player.gun_anim - 1 end
|
|
end
|
|
end
|
|
|
|
|
|
function drawUI()
|
|
function drawUI()
|
|
@@ -213,11 +258,8 @@ function drawUI()
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
|
|
--- 1xxxxxxxxxxx
|
|
|
|
--- 0xxxxxxxxxxx
|
|
|
|
--- 0xxxxxxxxxxx
|
|
|
|
--- 1xxxxxxxxxxx
|
|
|
|
function drawWater(waterHeight)
|
|
function drawWater(waterHeight)
|
|
|
|
+ -- TODO: ripples, distortion
|
|
for i=0,waterHeight-1 do
|
|
for i=0,waterHeight-1 do
|
|
local row = (135 - i - waterHeight) * 120
|
|
local row = (135 - i - waterHeight) * 120
|
|
local rowDest = (135 + i - waterHeight + 1) * 120
|
|
local rowDest = (135 + i - waterHeight + 1) * 120
|
|
@@ -225,6 +267,13 @@ function drawWater(waterHeight)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
|
|
|
|
+-- shiftValue 1, 0, -1, -2 From brightest to darkest, respectively. 0 is no change
|
|
|
|
+function filterColor(inputColor, shiftValue)
|
|
|
|
+ if shiftValue == 0 then return end
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+end
|
|
|
|
+
|
|
function drawDebug()
|
|
function drawDebug()
|
|
-- print("p.gdown: " .. tostring(player.gun_down), 5, 5, 12, true, 1, true)
|
|
-- print("p.gdown: " .. tostring(player.gun_down), 5, 5, 12, true, 1, true)
|
|
-- print("spr: " .. tostring(vulcanMuzzleSprites[player.fire + 1]), 5, 13, 12, true, 1, true)
|
|
-- print("spr: " .. tostring(vulcanMuzzleSprites[player.fire + 1]), 5, 13, 12, true, 1, true)
|
|
@@ -252,25 +301,58 @@ function update()
|
|
end
|
|
end
|
|
end
|
|
end
|
|
if btnp(4) then
|
|
if btnp(4) then
|
|
- player.gun_held = 1
|
|
|
|
- player.gun_down = not player.gun_down
|
|
|
|
|
|
+ player.gun_held = player.gun_held + 1
|
|
|
|
+ if player.gun_held > 6 then player.gun_held = 0 end
|
|
end
|
|
end
|
|
if btn(5) then
|
|
if btn(5) then
|
|
--if player.gun_held == 0 then
|
|
--if player.gun_held == 0 then
|
|
if player.fire == 0 then
|
|
if player.fire == 0 then
|
|
player.fire = 5
|
|
player.fire = 5
|
|
- table.insert(p_bullets, {x=player.x+10, y=player.y+2})
|
|
|
|
|
|
+ --table.insert(p_bullets, {x=player.x+10, y=player.y+2})
|
|
else
|
|
else
|
|
player.fire = player.fire - 1
|
|
player.fire = player.fire - 1
|
|
end
|
|
end
|
|
--end
|
|
--end
|
|
|
|
+ if player.gun_held == 1 then
|
|
|
|
+ player.is_firing = 1
|
|
|
|
+ end
|
|
|
|
+ if player.gun_held == 2 then
|
|
|
|
+ -- controlled by cooldown (or semi-auto)
|
|
|
|
+ if player.is_firing == 1 then player.is_firing = 0 end
|
|
|
|
+
|
|
|
|
+ if player.big_gun_cooldown == 0 then
|
|
|
|
+ player.big_gun_cooldown = 30
|
|
|
|
+ player.is_firing = 1
|
|
|
|
+ else
|
|
|
|
+ player.big_gun_cooldown = player.big_gun_cooldown - 1
|
|
|
|
+ player.is_firing = 0
|
|
|
|
+ end
|
|
|
|
+
|
|
|
|
+ if player.is_firing == 1 then
|
|
|
|
+ table.insert(p_big_bullets, {x=player.x+12, y=player.y+6, type=player.gun_held})
|
|
|
|
+ end
|
|
|
|
+ end
|
|
|
|
+ else
|
|
|
|
+ player.big_gun_cooldown = 0
|
|
end
|
|
end
|
|
|
|
+ if btnp(5) then
|
|
|
|
+ -- debug
|
|
|
|
+ player.gun_down = not player.gun_down
|
|
|
|
+ player.gun_anim = 1
|
|
|
|
+ end
|
|
|
|
+
|
|
for key,val in ipairs(p_bullets) do
|
|
for key,val in ipairs(p_bullets) do
|
|
p_bullets[key].x = p_bullets[key].x + 8
|
|
p_bullets[key].x = p_bullets[key].x + 8
|
|
if val.x > 240 then
|
|
if val.x > 240 then
|
|
table.remove(p_bullets, key)
|
|
table.remove(p_bullets, key)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
+ for key,val in ipairs(p_big_bullets) do
|
|
|
|
+ p_big_bullets[key].x = p_big_bullets[key].x + 8
|
|
|
|
+ if val.x > 240 then
|
|
|
|
+ table.remove(p_big_bullets, key)
|
|
|
|
+ end
|
|
|
|
+ end
|
|
for i=1,#shellParticles do
|
|
for i=1,#shellParticles do
|
|
local p = shellParticles[i]
|
|
local p = shellParticles[i]
|
|
p.x = p.x + p.vx
|
|
p.x = p.x + p.vx
|