display hint in planets

This commit is contained in:
Fabien Freling 2021-08-13 19:27:34 +02:00
parent f98063c5d3
commit 0934981061

View file

@ -30,6 +30,24 @@ class D {
static right { 3 } static right { 3 }
} }
var CheatSeq = [D.up, D.up, D.left, D.right, D.up, D.down]
var DirRot = Fn.new {|dir|
if (dir == D.up) {
return 0
}
if (dir == D.right) {
return 1
}
if (dir == D.down) {
return 2
}
if (dir == D.left) {
return 3
}
return -1
}
class Star { class Star {
construct new(x, y, size, scrollSpeed, color) { construct new(x, y, size, scrollSpeed, color) {
_x = x _x = x
@ -52,6 +70,31 @@ class Star {
} }
} }
class HintPlanet {
construct new(x, y, scrollSpeed, dir) {
_x = x
_y = y
_scrollSpeed = scrollSpeed
_rot = DirRot.call(dir)
_size = 32
}
update() {
_x = _x - _scrollSpeed
}
draw() {
TIC.spr(64, _x - _size / 2, _y - _size / 2, 0, 1, 0, 0, _size / TileSize, _size / TileSize)
if (_rot != -1) {
TIC.spr(68, _x - 2, _y - 4, 0, 1, 0, _rot)
}
}
expired {
_x + _size / 2 < 0
}
}
class Bullet { class Bullet {
construct new(x, y) { construct new(x, y) {
_x = x _x = x
@ -71,7 +114,6 @@ class Bullet {
} }
draw() { draw() {
//TIC.rect(_x, _y, _w, _h, 4)
TIC.spr(288, _x, _y - 4, 0) TIC.spr(288, _x, _y - 4, 0)
} }
@ -232,6 +274,7 @@ class World {
_world_y = 0 _world_y = 0
_w_offset_x = 0 _w_offset_x = 0
_world_scroll_speed = 60 / 2 _world_scroll_speed = 60 / 2
_hint_planet_i = 0
// init background // init background
for (i in 0..W) { for (i in 0..W) {
@ -250,9 +293,7 @@ class World {
collect(list) { collect(list) {
var i = 0 var i = 0
while (i < list.count) { while (i < list.count) {
//System.print("%(list[i])")
if (list[i].expired) { if (list[i].expired) {
//System.print("remove element from list")
list.removeAt(i) list.removeAt(i)
} else { } else {
i = i + 1 i = i + 1
@ -302,7 +343,12 @@ class World {
var speed = 0.1 var speed = 0.1
var mediumTick = (spaceBetween + width) / speed var mediumTick = (spaceBetween + width) / speed
if (_t % mediumTick == 0) { if (_t % mediumTick == 0) {
_stars.add(Star.new(W, R.int(0,H-20), width, speed, 13)) var dir = -1
if (_hint_planet_i < CheatSeq.count) {
dir = CheatSeq[_hint_planet_i]
}
_stars.add(HintPlanet.new(W, R.int(16,H-32), speed, dir))
_hint_planet_i = _hint_planet_i + 1
} }
// Map scrolling // Map scrolling
@ -435,7 +481,6 @@ class Game is TIC{
_p_buttons = [] _p_buttons = []
_p_index = 0 _p_index = 0
_d_enabled = false _d_enabled = false
_cheat_seq = [D.up, D.up, D.left, D.right, D.up, D.down]
} }
TIC() { TIC() {
@ -476,13 +521,13 @@ class Game is TIC{
cheatFound() { cheatFound() {
var end = _p_index var end = _p_index
var start = (end - _cheat_seq.count) var start = (end - CheatSeq.count)
if (start < 0) { if (start < 0) {
return false return false
} }
for (i in 0..._cheat_seq.count) { for (i in 0...CheatSeq.count) {
var dir = _p_buttons[(start + i) % _p_buttons.count] var dir = _p_buttons[(start + i) % _p_buttons.count]
var cheat = _cheat_seq[i] var cheat = CheatSeq[i]
if (dir != cheat) { if (dir != cheat) {
return false return false
} }
@ -513,19 +558,9 @@ class Game is TIC{
for (i in start...end) { for (i in start...end) {
var pos = i - start var pos = i - start
var dir = _p_buttons[i % _p_buttons.count] var dir = _p_buttons[i % _p_buttons.count]
var rot = DirRot.call(dir)
var sprId = 84 var sprId = 84
if (dir == D.up) { TIC.spr(sprId, 5 + pos * 10, H - 20, 0, 1, 0, rot)
TIC.spr(sprId, 5 + pos * 10, H - 20, 0)
}
if (dir == D.down) {
TIC.spr(sprId, 5 + pos * 10, H - 20, 0, 1, 2)
}
if (dir == D.left) {
TIC.spr(sprId, 5 + pos * 10, H - 20, 0, 1, 0, 3)
}
if (dir == D.right) {
TIC.spr(sprId, 5 + pos * 10, H - 20, 0, 1, 0, 1)
}
} }
} else { } else {
TIC.print("debug mode: enabled", 60, H - 10, Color.white) TIC.print("debug mode: enabled", 60, H - 10, Color.white)