diff --git a/source/data.fnl b/source/data.fnl
index a4ab1e3..05dc543 100644
--- a/source/data.fnl
+++ b/source/data.fnl
@@ -75,6 +75,50 @@
;; 157:0500505555555555555555550555555505555555555555555555555505555555
;; 158:5555555555555555055555555555555555555555055555555555555505550055
;; 159:5555555055555555555555555555555055555550555555555555555555050050
+;; 161:0000000000000000000000000000000000000000000000000000000000666666
+;; 162:0000000000000000006600000ff660000ff06600000066600000066066600660
+;; 164:00000000000000000000000000000000000000060000066600006eee000aaeae
+;; 165:000000000000000000000000000000006666660066666666aeee6eeeaeeeaeea
+;; 166:00000000000000000000000000000000000000ff000000ff6000000060000000
+;; 167:0000000000000000000000000000000000000000000000006000000060000000
+;; 168:00000000000000000000000000000000000000060000066600006eee000aaeae
+;; 169:000000000000000000000000000000006666666066666666aeee6eeeaeeeaeea
+;; 170:000000000000000000000000000000000000000000000000600000006000ff00
+;; 176:0000000000000006000000660000a666000a66aa000a66a600a06aee000006e0
+;; 177:666666666666666666666666a6666666a666666666aa6666eaa666a6aeee6a66
+;; 178:6666666066666660666666666666166666111666666666666666666666666666
+;; 179:0000000000000000000000006000000060006600606666006666660066666600
+;; 180:000aeeae00a0eeae0aa0eeee0000aeee000aaeee00a00eee00000aee000000e6
+;; 181:eaeeaeeaeaeeaeeaeaeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee
+;; 182:66000000e6000000e6600000e6600000ea660000eae66666aee66600eee66600
+;; 183:0600000006000000060000000600000060000000000000000000000000000000
+;; 184:000aeeae00a0eeae0aa0eeee0000aeee000aaeee00a00eee00000aee000000e6
+;; 185:eaeeaeeaeaeeaeeaeaeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee
+;; 186:6600ff00e6000060e6600006e6600000ea660000eae66666aee66600eee66600
+;; 187:0000000000000000000000006000000060000000000000000000000000000000
+;; 192:000000000000000000000000000000000000006000a060a600a666a600a666aa
+;; 193:eeeeea660eeeeae60eeeeeee0eeeeeee0eeeeeee0eeeeeeeeeeaeeeeeeeaeeee
+;; 194:aa666666a6666666a6a66666e6a66666ee666666ee666666ee666666a66a6666
+;; 195:6666660066666600666666006666660066666600600066000000060000000000
+;; 196:000000ee000000ee000006ee000ae6ee0aeaeeee0aee6eee0aee6eea0aeaeeea
+;; 197:eee66eeeeee66eeeeeeeeeeeeeeeeeeeeeeeeaeeeeeeaaeeeeeeaeeeeeaeaee6
+;; 198:eee66600eee66660aee66666aee66666aea66666a6666666a666666666666666
+;; 199:0060000006600000666000006660000066600000666000006660000066600000
+;; 200:000000ee000000ee000006ee000ae6ee0aeaeeee0aee6eee0aee6eea0aeaeeea
+;; 201:eee66eeeeee66eeeeeeeeeeeeeeeeeeeeeeeeaeeeeeeaaeeeeeeaeeeeeaeaee6
+;; 202:eee66600eee66660aee66666aee66666aea66666a6666666a666666666666666
+;; 203:0000000006000000660000006600000066000000660000006600000060000000
+;; 208:00a6666a000a666a000066660000066600000066000000060000000000000000
+;; 209:eeeaaeeea666aa66a6666a666666666666666666666666660666666600000000
+;; 210:a66a6666aa6666606aa666606666666066666600666660006666000000000000
+;; 212:0aeaeeea00eaeaea000aeaee0000066600000000000000000000000000000000
+;; 213:eeaee666eeae6666ee6666666666660000000000000000000000000000000000
+;; 214:6666000666600006600000000000000000000000000000000000000000000000
+;; 215:6660000066000000660000006000000000000000000000000000000000000000
+;; 216:0aeaeeea00eaeaea000aeaee0000066600000000000000000000000000000000
+;; 217:eeaee666eeae6666ee6666666666600000000000000000000000000000000000
+;; 218:6666000666600006000000060000000000000000000000000000000000000000
+;; 219:6000000060000000000000000000000000000000000000000000000000000000
;;
;;
@@ -123,11 +167,20 @@
;; 051:000000cc0000bbcc00abbcbbaaaabb006aaa0000660000000000000000000000
;; 052:1210000029200000121000000000000000000000000000000000000000000000
;; 053:2010000009000000102000000000000000000000000000000000000000000000
+;; 057:0000000006666660660000666000000060000000ff000000ff00000000666666
+;; 058:0000000000000000600000006600000006000000066000000660000066660000
+;; 059:0000000000000000000000000000000000000000000000000000000000066000
;; 060:0000000000000006000000660000066600a0666600a6666600a66a6600a66a66
;; 061:6666666666666666666666666666666666666166a6661111a6666166a6666666
;; 062:6666600066666600666666666666666666666666666666666666666666666666
;; 063:0000666000666660666666606666666066666660666666606666666066666660
;; 064:000077000ff777007ff7f7707777777007777877077888770778877000077000
+;; 067:00000000000ff00000ffff000ff77ff00ff77ff000ffff00000ff00000000000
+;; 068:00000000000cc00000cffc000cfff7c00cff77c000c77c00000cc00000000000
+;; 072:0000000000000006000000660000066600a0666600a6666600a66a6600a66a66
+;; 073:6666666666666666666666666666666666666166a6661111a6666166a6666666
+;; 074:6666600066666600666666666666666666666666666666666666666666666666
+;; 075:0066600066666000666660006666600066666600666666006666660066666600
;; 076:0066666600666666006666660066666600666666000666660006666600006666
;; 077:a66a6666666a66a6666666a66666666666666666666666666666666666666666
;; 078:66666666666666666a6666606666660066666600666666006666660066666000
@@ -135,12 +188,19 @@
;; 080:0000000000005550000555560006666500055555000555550000555500007000
;; 081:00000000000000000000000050000110550001105700007050f0007070070070
;; 082:000000a000000a800000aa600008888000aaa860088866800caca86006666600
+;; 088:0066666600666666006666660066666600666666000666660006666600006666
+;; 089:a6666666666a6666666a66a6666666a666666666666666666666666666666666
+;; 090:6666666666666666666666606a66660066666600666666006666660066666000
+;; 091:6666660000066600000066000000000000000000000000000000000000000000
;; 092:0000666600000666000000660000000000000000000000000000000000000000
;; 093:6666666666666666666666666666666600000000000000000000000000000000
;; 094:6666600066660000666000006000000000000000000000000000000000000000
;; 096:000f0000000700000000700000000f0001100070011000700077770000000000
;; 097:0f00f70000700000007000000007110000001100000000000000000000000000
;; 098:0606600006060000060600000006000006000000000600000000000000000000
+;; 104:0000666600000666000000660000000000000000000000000000000000000000
+;; 105:6666666666666666666666666666666600000000000000000000000000000000
+;; 106:6666600066660000666000006000000000000000000000000000000000000000
;; 112:0002000000720000077777000000777000000777000000770000000000000000
;; 113:0000000000000000000000770000077700002770000727000077700000000000
;; 114:0000000000000000000020000007277700777777000000000000000000000000
@@ -182,10 +242,37 @@
;; 161:0000c00000007000000ccff000fccf88c7fff8aaf7fff88800ffffff000ffff0
;; 162:0000f00000007000000ccff000fccf8807fff8aaf7fff88800ffffff000ffff0
;; 163:0000c00000007000000ccff000fccf88c7fff8aa07fff88800ffffff000ffff0
+;; 165:00000000000666600060006600600ff000066ff0000000000000000000666666
+;; 166:0000000000000000600000006600000006000000066000000660000066660000
;; 176:0000c0000000a000000cccc0c0cccc88caccc8aacaccc888c0cccccc000cccc0
;; 177:0000c0000000a000000cccc000cccc88caccc8aacaccc88800cccccc000cccc0
;; 178:0000c0000000a000000cccc000cccc880accc8aacaccc88800cccccc000cccc0
;; 179:0000c0000000a000000cccc000cccc88caccc8aa0accc88800cccccc000cccc0
+;; 180:000000000000000600000066000006660000066600a0666600a6666600a66a66
+;; 181:666666666666666666666666666666666666666666666666a6666666a6666666
+;; 182:6666600066666600666666666666666666666666666666666666666666666666
+;; 183:6600000066600000666000006666000066660000666600006666000066660000
+;; 193:00000000000666600066006600600000006000000006ff000000ff0000666666
+;; 194:0000000000000000600000006600000006000000066000000660000066660000
+;; 195:0000000000000000000000000000000000000000000000000000000006600000
+;; 196:00a66a6600666666006666660066666600666666000666660006666600006666
+;; 197:a6666666a666a6666666a66a6666666a66666666666666666666666666666666
+;; 198:66666666666666666666666066a6660066666600666666006666660066666000
+;; 199:6666000066660000666000006600000000000000000000000000000000000000
+;; 208:000000000000000600000066000006660000066600a0666600a6666600a66a66
+;; 209:666666666666666666666666666666666666616666661111a6666166a6666666
+;; 210:6666600066666606666666666666666666666666666666666666666666666666
+;; 211:6660000066600000666000006666000066660000666600006666000066660000
+;; 212:0000666600000666000000660000000000000000000000000000000000000000
+;; 213:6666666666666666666666666666666600000000000000000000000000000000
+;; 214:6666600066660000666000006000000000000000000000000000000000000000
+;; 224:00a66a6600666666006666660066666600666666006666660006666600006666
+;; 225:a6666666a66a6666666a66a6666666a666666666666666666666666666666666
+;; 226:6666666666666666666666606a66660066666600666666006666660066666000
+;; 227:6666000006660000006600000000000000000000000000000000000000000000
+;; 240:0000666600000666000000660000000000000000000000000000000000000000
+;; 241:6666666666666666666666666666666600000000000000000000000000000000
+;; 242:6666600066660000666000006000000000000000000000000000000000000000
;;
;;
@@ -253,4 +340,3 @@
;;
;; 000:141428fa0c36bbcc5218282c00ff000c0c10202d518e2e913c405591142c5d8161599dcaf2f4f60cff08201834f661ba
;;
-
diff --git a/source/main.fnl b/source/main.fnl
index 753b641..3c2eac9 100644
--- a/source/main.fnl
+++ b/source/main.fnl
@@ -247,6 +247,17 @@
(inc self.y (* (- self.speed.y *cam*.speedy) *dt*))
(pix self.x self.y color)))
+ (global *bexplosion-particle* (deepcopy *particle*))
+ (tset *bexplosion-particle*
+ :update
+ (fn [self]
+ (var color 11)
+ (if (< self.lifetime 600)
+ (set color 6))
+ (inc self.x (+ (* (- self.speed.x *cam*.speedx) *dt*) (sin (* 0.4 (+ *tick* self.speed.y)))))
+ (inc self.y (* (+ self.speed.y *cam*.speedy) *dt*))
+ (pix self.x self.y color)))
+
(global *pexplosion-particle* (deepcopy *particle*))
(tset *pexplosion-particle*
:update
@@ -258,6 +269,24 @@
(inc self.y (* (+ self.speed.y *cam*.speedy) *dt*))
(pix self.x self.y color)))
+ (global *bcexplosion-particle* (deepcopy *particle*))
+ (tset *bcexplosion-particle*
+ :update
+ (fn [self]
+ ;(trace self.lifetime)
+ (var color 15)
+ (if (< self.lifetime 200)
+ (set color 6)
+ (< self.lifetime 400)
+ (set color 7)
+ (< self.lifetime 650)
+ (set color 7))
+ (when (= (% *tick* 4) 0)
+ (dec self.scale 2))
+ (dec self.x (* *cam*.speedx *dt*))
+
+ (circ self.x self.y self.scale color)))
+
(global *cexplosion-particle* (deepcopy *particle*))
(tset *cexplosion-particle*
:update
@@ -276,7 +305,7 @@
(circ self.x self.y self.scale color)))
- (global *particle-types* { :cexplosion *cexplosion-particle* :bubble *bubble-particle* :pixel *pixel-particle* :pexplosion *pexplosion-particle* })
+ (global *particle-types* { :bcexplosion *bcexplosion-particle* :bexplosion *bexplosion-particle* :cexplosion *cexplosion-particle* :bubble *bubble-particle* :pixel *pixel-particle* :pexplosion *pexplosion-particle* })
(global *emitters* [])
(global *emitter* { :x 0 :y 0 ; Emitter position
@@ -338,6 +367,31 @@
(global *cexplosion-emitter* (deepcopy *emitter*))
(set *cexplosion-emitter*.type :cexplosion)
+ ;; Boss explosion
+ (global *bexplosion-emitter* (deepcopy *emitter*))
+ (set *bexplosion-emitter*.type :bexplosion)
+ (set *bexplosion-emitter*.num-particles 7)
+ (set *bexplosion-emitter*.lifetime-range { :min 700 :max 1000 })
+ (set *bexplosion-emitter*.scale-range { :min 3 :max 6 })
+ (set *bexplosion-emitter*.pos-range { :xmin 0 :xmax 6 :ymin 2 :ymax 8 })
+ (set *bexplosion-emitter*.speed-range { :xmin -5 :xmax 5 :ymin -50 :ymax -40 })
+ (tset *bexplosion-emitter*
+ :update
+ (fn [self]
+ (when (> self.num-particles 0)
+ (self:emit)
+ (when (> self.num-particles 4)
+ (self:emit :bcexplosion))
+ (dec self.num-particles))
+
+ (dec self.x (* *cam*.speedx *dt*))
+
+ (each [i particle (ipairs self.particles)]
+ (particle:update)
+ (if (<= particle.lifetime 0)
+ (table.remove self.particles i)
+ (dec particle.lifetime (* *dt* 1000))))))
+
;; Pixel explosion
(global *pexplosion-emitter* (deepcopy *emitter*))
(set *pexplosion-emitter*.type :pexplosion)
@@ -942,7 +996,7 @@
(fn init-enemies []
;; List of enemy types
(global *enemy-types* [ :simple-fish :stronger-fish ])
- (global *enemy* { :w 8 :h 8 :speedx 50 :speedy 0 :damage 2.0 :health 2.0 :points 1 :emitter :pexplosion :flicker 0 })
+ (global *enemy* { :w 8 :h 8 :speedx 50 :speedy 0 :damage 2.0 :health 2.0 :points 1 :emitter :pexplosion :flicker 0 :no-flicker false })
(set *enemy*.animator
{ :current-animation :moving
:current-index 1
@@ -1012,11 +1066,12 @@
(inc self.y (* 0.5 (sin (* 0.05 (+ *tick* self.y)))))))
(global *energy-ball* (deepcopy *enemy*))
- (set *energy-ball*.animator.animations.moving [ 265 ])
+ (set *energy-ball*.animator.animations.moving [ 265 323 324 ])
(set *energy-ball*.points 0)
(set *energy-ball*.health 9999)
(set *energy-ball*.speedx 130)
(set *energy-ball*.damage 20)
+ (set *energy-ball*.no-flicker true)
(global *follower* (deepcopy *energy-ball*))
(set *follower*.speedx 200)
@@ -1046,10 +1101,25 @@
;; Attack speed factor
(set *anglerfish*.asfactor 1)
(set *anglerfish*.attack-types [ :follow :energy :straight :pacifist ])
+ (set *anglerfish*.animator
+ { :current-animation :moving
+ :current-index 1
+ :elapsed 0
+ :speed 150
+ :animations
+ { :moving [ 300 312 448 420 448 312 ]
+ :attack [ 160 164 160 168 ] }})
(set *anglerfish*.draw
(fn [self]
- (spr 300 self.x self.y 0 1 0 0 4 4)))
+ (animate self)
+ (if (and (> self.flicker 0) (< (% *tick* 5) 3))
+ (do (dec self.flicker))
+ (spr (get-animation-frame self.animator) self.x self.y 0 1 0 0 4 4))))
+
+ ;(set *anglerfish*.draw
+ ;(fn [self]
+ ;(spr 300 self.x self.y 0 1 0 0 4 4)))
(set *anglerfish*.move
(fn [self]
@@ -1122,10 +1192,20 @@
(dec self.x (* 60 *dt*))))
(= self.state :attack)
- (self:attack)
+ (do (when (not (= self.animator.current-animation :attack))
+ (set self.animator.current-animation :attack))
+ (when (= (% *tick* 30) 0)
+ (local emitter (deepcopy *bexplosion-emitter*))
+ (set emitter.x (+ self.x 9))
+ (set emitter.y (+ self.y 12))
+ ;(set emitter. (+ self.y 16))
+ (table.insert *emitters* emitter))
+ (self:attack))
(= self.state :moving)
- (do (when (= (% self.aframe 15) 0) ; Spawn monster
+ (do (when (not (= self.animator.current-animation :moving))
+ (set self.animator.current-animation :moving))
+ (when (= (% self.aframe 15) 0) ; Spawn monster
(local rn (r 0 100))
(when (< rn 40)
(local enemy (spawn-enemy :stronger-fish self.x (+ self.y 16)))
@@ -1263,7 +1343,7 @@
(each [shot-index shot (pairs *player*.shots)]
(when (bcollides? shot enemy) (dec enemy.health shot.damage)
;; Play sound when shot
- (when (> enemy.health 0) (set enemy.flicker 18) (sfx 4 33 4 3 6))
+ (when (and (> enemy.health 0) (not enemy.no-flicker)) (set enemy.flicker 18) (sfx 4 33 4 3 6))
(destroy-shot shot-index)
(when (and enemy.shake (= *shake* 0)) (global *shake* 5))))
@@ -1556,9 +1636,9 @@
(local tycam (// (math.abs *cam*.y) 8))
(map txcam tycam 31 18 (- 0 (% (math.abs *cam*.x) 8)) (- 0 (% (math.abs *cam*.y) 8)) 0)
(update-goods)
- (update-emitters)
(*player*:draw)
(update-enemies)
+ (update-emitters)
(draw-hud))
(fn update-camera []