Compare commits
5 Commits
77b9345f76
...
9cf1956770
Author | SHA1 | Date | |
---|---|---|---|
9cf1956770 | |||
162fc09baa | |||
91d06311db | |||
a42c93ff6b | |||
5d2158fcaf |
6
.gitignore
vendored
6
.gitignore
vendored
@ -1,2 +1,8 @@
|
|||||||
|
.DS_Store
|
||||||
|
|
||||||
# Godot 4+ specific ignores
|
# Godot 4+ specific ignores
|
||||||
.godot/
|
.godot/
|
||||||
|
|
||||||
|
export_presets.cfg
|
||||||
|
|
||||||
|
/AuthKey_VSYTQ75GZQ.p8
|
||||||
|
70
AssetLoaders/Enums.gd
Normal file
70
AssetLoaders/Enums.gd
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
class_name Enums
|
||||||
|
|
||||||
|
enum TileID {
|
||||||
|
TileVoid = 0,
|
||||||
|
TileBlank = 1,
|
||||||
|
TileHome = 2,
|
||||||
|
TileBattle = 3,
|
||||||
|
TileDraw = 4,
|
||||||
|
TileBonus = 5,
|
||||||
|
TileDrop = 6,
|
||||||
|
TileWarp = 7,
|
||||||
|
TileDrawx2 = 8,
|
||||||
|
TileBonusx2 = 9,
|
||||||
|
TileDropx2 = 10,
|
||||||
|
TileFlatWall = 11,
|
||||||
|
TileVoid2 = 12, # i'm not sure why there's 8 voids, or if they're even used
|
||||||
|
TileVoid3 = 13,
|
||||||
|
TileVoid4 = 14,
|
||||||
|
TileVoid5 = 15,
|
||||||
|
TileVoid6 = 16,
|
||||||
|
TileVoid7 = 17,
|
||||||
|
TileDeck = 18,
|
||||||
|
TileVoid8 = 19,
|
||||||
|
TileBattlex2 = 20,
|
||||||
|
TileMove = 21,
|
||||||
|
TileMovex2 = 22,
|
||||||
|
TileWarpMove = 23,
|
||||||
|
TileWarpMovex2 = 24,
|
||||||
|
TileIce = 25,
|
||||||
|
TileSnow = 26,
|
||||||
|
TileHeal = 27,
|
||||||
|
TileHealx2 = 28,
|
||||||
|
TileEvent = 29, # OJEdit says "Event (Blank Tile)"
|
||||||
|
TileUnknown = 30,
|
||||||
|
TileCoopBoss = 31,
|
||||||
|
TileDamage = 32,
|
||||||
|
TileDamagex2 = 33
|
||||||
|
}
|
||||||
|
|
||||||
|
static func get_tile_texture(id: int):
|
||||||
|
match id:
|
||||||
|
0: return ""
|
||||||
|
1: return "mass_common0.dat"
|
||||||
|
2: return "mass_check0.dat"
|
||||||
|
3: return "mass_encount0.dat"
|
||||||
|
4: return "mass_draw0.dat"
|
||||||
|
5: return "mass_bonus0.dat"
|
||||||
|
6: return "mass_drop0.dat"
|
||||||
|
7: return "mass_warp0.dat"
|
||||||
|
8: return "mass_drawL2.dat"
|
||||||
|
9: return "mass_bonusL2.dat"
|
||||||
|
10: return "mass_dropL2.dat"
|
||||||
|
11: return "mass_common0.dat"
|
||||||
|
12, 13, 14, 15, 16, 17: return ""
|
||||||
|
18: return "mass_editordeck.dat"
|
||||||
|
19: return ""
|
||||||
|
20: return "mass_encountL2.dat"
|
||||||
|
21: return "mass_move0.dat"
|
||||||
|
22: return "mass_moveL2.dat"
|
||||||
|
23: return "mass_warpmove0.dat"
|
||||||
|
24: return "mass_warpmoveL2.dat"
|
||||||
|
25: return "mass_snow0.dat"
|
||||||
|
26: return "mass_snow0.dat"
|
||||||
|
27: return "mass_heal0.dat"
|
||||||
|
28: return "mass_healL2.dat"
|
||||||
|
29: return "mass_common0.dat"
|
||||||
|
30: return "mass_common0.dat"
|
||||||
|
31: return "mass_boss.dat"
|
||||||
|
32: return "mass_damage.dat"
|
||||||
|
33: return "mass_damageL2.dat"
|
99
AssetLoaders/PakAssetLoader.gd
Normal file
99
AssetLoaders/PakAssetLoader.gd
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
class_name PakAssetLoader
|
||||||
|
|
||||||
|
static var key = "a8Yb5$IpVobR,1Xph!k(#!B9h$V[o[r-I'x.37Q%E;lt2wGgk)hNF_p_!mF?Ds54.*8ErbCK,30".to_utf8_buffer()
|
||||||
|
|
||||||
|
#loads a file from a .pak file.
|
||||||
|
static func load_file(path: String):
|
||||||
|
var split = path.split(".pak/")
|
||||||
|
var pak = split[0]
|
||||||
|
var filename = split[1]
|
||||||
|
|
||||||
|
var zip_reader = ZIPReader.new()
|
||||||
|
var err = zip_reader.open(pak + ".pak")
|
||||||
|
if err != OK:
|
||||||
|
report_errors(err, pak + ".pak")
|
||||||
|
zip_reader.close()
|
||||||
|
var bytes = zip_reader.read_file(filename)
|
||||||
|
zip_reader.close()
|
||||||
|
if bytes.size() == 0:
|
||||||
|
report_errors(ERR_FILE_NOT_FOUND, filename)
|
||||||
|
|
||||||
|
if filename.ends_with(".dat"):
|
||||||
|
var magic = bytes[0]+bytes[1]+bytes[2]+bytes[3]
|
||||||
|
if magic == 0x25 + 0x7C + 0x0A + 0x42: #XOR'ed DDS file
|
||||||
|
unXOR(bytes)
|
||||||
|
magic = bytes[0]+bytes[1]+bytes[2]+bytes[3]
|
||||||
|
|
||||||
|
if magic == 0x44 + 0x44 + 0x53 + 0x20: #DDS file
|
||||||
|
var header = bytes.slice(0, 0x80)
|
||||||
|
bytes = bytes.slice(0x80)
|
||||||
|
var height = header[0xc] + (header[0xd] * 256)
|
||||||
|
var width = header[0x10] + (header[0x11] * 256)
|
||||||
|
var format = header[0x54]+header[0x55]+header[0x56]+header[0x57]
|
||||||
|
if format == 0:
|
||||||
|
fix_BGRA(bytes)
|
||||||
|
var img = Image.create_from_data(width, height, false, Image.FORMAT_RGBA8, bytes)
|
||||||
|
return ImageTexture.create_from_image(img)
|
||||||
|
elif format == 0x44 + 0x58 + 0x54 + 0x35:
|
||||||
|
var img = Image.create_from_data(width, height, false, Image.FORMAT_DXT5, bytes)
|
||||||
|
return ImageTexture.create_from_image(img)
|
||||||
|
else:
|
||||||
|
report_errors(ERR_FILE_UNRECOGNIZED, filename)
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
report_errors(ERR_FILE_UNRECOGNIZED, filename)
|
||||||
|
return
|
||||||
|
elif filename.ends_with(".ogg"):
|
||||||
|
var magic = bytes[0]+bytes[1]+bytes[2]+bytes[3]
|
||||||
|
|
||||||
|
if magic == 0x4F + 0x67 + 0x67 + 0x53:
|
||||||
|
var stream = AudioStreamOggVorbis.load_from_buffer(bytes)
|
||||||
|
stream.loop = true
|
||||||
|
stream.loop_offset = get_loop_off(filename)
|
||||||
|
return stream
|
||||||
|
else:
|
||||||
|
report_errors(ERR_FILE_UNRECOGNIZED, filename)
|
||||||
|
elif filename.ends_with(".fld"):
|
||||||
|
return bytes
|
||||||
|
|
||||||
|
|
||||||
|
static func fix_BGRA(bytes: PackedByteArray):
|
||||||
|
for i in range(0, bytes.size(), 4):
|
||||||
|
var tmp = bytes[i]
|
||||||
|
bytes[i] = bytes[i+2]
|
||||||
|
bytes[i+2] = tmp
|
||||||
|
|
||||||
|
static func unXOR(bytes: PackedByteArray):
|
||||||
|
for i in range(bytes.size()):
|
||||||
|
bytes[i] ^= key[i % key.size()]
|
||||||
|
|
||||||
|
|
||||||
|
static func get_loop_off(filename: String):
|
||||||
|
match filename:
|
||||||
|
"bgm/0.ogg":
|
||||||
|
return 1.72
|
||||||
|
"bgm/1.ogg":
|
||||||
|
return 2
|
||||||
|
|
||||||
|
|
||||||
|
static func report_errors(err: int, filepath):
|
||||||
|
# See: https://docs.godotengine.org/en/latest/classes/class_@globalscope.html#enum-globalscope-error
|
||||||
|
var result_hash = {
|
||||||
|
ERR_FILE_NOT_FOUND: "File: not found",
|
||||||
|
ERR_FILE_BAD_DRIVE: "File: Bad drive error",
|
||||||
|
ERR_FILE_BAD_PATH: "File: Bad path error.",
|
||||||
|
ERR_FILE_NO_PERMISSION: "File: No permission error.",
|
||||||
|
ERR_FILE_ALREADY_IN_USE: "File: Already in use error.",
|
||||||
|
ERR_FILE_CANT_OPEN: "File: Can't open error.",
|
||||||
|
ERR_FILE_CANT_WRITE: "File: Can't write error.",
|
||||||
|
ERR_FILE_CANT_READ: "File: Can't read error.",
|
||||||
|
ERR_FILE_UNRECOGNIZED: "File: Unrecognized error.",
|
||||||
|
ERR_FILE_CORRUPT: "File: Corrupt error.",
|
||||||
|
ERR_FILE_MISSING_DEPENDENCIES: "File: Missing dependencies error.",
|
||||||
|
ERR_FILE_EOF: "File: End of file (EOF) error."
|
||||||
|
}
|
||||||
|
if err in result_hash:
|
||||||
|
print("Error: ", result_hash[err], " ", filepath)
|
||||||
|
else:
|
||||||
|
print("Unknown error with file ", filepath, " error code: ", err)
|
||||||
|
|
53
Field/field.gd
Normal file
53
Field/field.gd
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
extends Node2D
|
||||||
|
|
||||||
|
var width: int
|
||||||
|
var height: int
|
||||||
|
var tiles: Array = []
|
||||||
|
var x = 1
|
||||||
|
var homes
|
||||||
|
var next_home
|
||||||
|
|
||||||
|
func _init():
|
||||||
|
var bytes = PakAssetLoader.load_file("user://data/fields.pak/field_practice.fld")
|
||||||
|
create_from_buffer(bytes)
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
func _ready():
|
||||||
|
homes = tiles.filter(is_home)
|
||||||
|
$Player.position = homes[0].position
|
||||||
|
next_home = homes[1].position
|
||||||
|
homes = [homes[0], homes[1], homes[3], homes[2]]
|
||||||
|
pass
|
||||||
|
|
||||||
|
func is_home(tile):
|
||||||
|
return tile.id == Enums.TileID.TileHome
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(delta):
|
||||||
|
if $Player.position != next_home:
|
||||||
|
$Player.position = $Player.position.move_toward(next_home, 4)
|
||||||
|
else:
|
||||||
|
x += 1
|
||||||
|
next_home = homes[x % 4].position
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
func create_from_buffer(bytes: PackedByteArray):
|
||||||
|
var num_tiles = bytes.size() / 8
|
||||||
|
|
||||||
|
# all boards are square
|
||||||
|
height = int(sqrt(num_tiles))
|
||||||
|
width = int(sqrt(num_tiles))
|
||||||
|
var j = 0;
|
||||||
|
for i in range(0, num_tiles):
|
||||||
|
var tile = load("res://Field/tile.tscn").instantiate()
|
||||||
|
tile.id = bytes.decode_u32(i * 8)
|
||||||
|
var exit_bits = bytes.decode_u8((i * 8) + 4)
|
||||||
|
add_child.call_deferred(tile)
|
||||||
|
tile.position = Vector2(((i % width) * 158) + 64, (j * 158) + 64)
|
||||||
|
tiles.append(tile)
|
||||||
|
if i % height == height - 1:
|
||||||
|
j += 1
|
||||||
|
#print(bytes)
|
||||||
|
pass
|
11
Field/field.tscn
Normal file
11
Field/field.tscn
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
[gd_scene load_steps=4 format=3 uid="uid://qipfodwbk1gf"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://Field/field.gd" id="1_6uvjw"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://sp3iv6cxuerm" path="res://player.tscn" id="2_oi7aa"]
|
||||||
|
[ext_resource type="Script" path="res://Player/player.gd" id="3_vsc2e"]
|
||||||
|
|
||||||
|
[node name="Field" type="Node2D"]
|
||||||
|
script = ExtResource("1_6uvjw")
|
||||||
|
|
||||||
|
[node name="Player" parent="." instance=ExtResource("2_oi7aa")]
|
||||||
|
script = ExtResource("3_vsc2e")
|
26
Field/tile.gd
Normal file
26
Field/tile.gd
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
extends Node2D
|
||||||
|
|
||||||
|
var id: Enums.TileID
|
||||||
|
var enter: Array
|
||||||
|
var exit: Array
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
func _ready():
|
||||||
|
var tex = Enums.get_tile_texture(id)
|
||||||
|
if tex != "":
|
||||||
|
$Sprite2D.texture = PakAssetLoader.load_file("user://data/field.pak/" + tex)
|
||||||
|
$Base.texture = PakAssetLoader.load_file("user://data/field.pak/mass_base0.dat")
|
||||||
|
|
||||||
|
# if id == Enums.TileID.TileIce:
|
||||||
|
# var layer = Sprite2D.new()
|
||||||
|
# var snow = Enums.get_tile_texture(Enums.TileID.TileSnow)
|
||||||
|
# layer.texture = PakAssetLoader.load_file("user://data/field.pak/" + snow)
|
||||||
|
# layer.flip_v = true
|
||||||
|
# print($Sprite2D.z_index)
|
||||||
|
# $Sprite2D.add_child(layer)
|
||||||
|
# layer.show_behind_parent = true
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(delta):
|
||||||
|
pass
|
14
Field/tile.tscn
Normal file
14
Field/tile.tscn
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
[gd_scene load_steps=2 format=3 uid="uid://b8vsmp8c1wqv6"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://Field/tile.gd" id="1_kltr3"]
|
||||||
|
|
||||||
|
[node name="Tile" type="Node2D"]
|
||||||
|
script = ExtResource("1_kltr3")
|
||||||
|
|
||||||
|
[node name="Base" type="Sprite2D" parent="."]
|
||||||
|
scale = Vector2(1.45, 1.45)
|
||||||
|
flip_v = true
|
||||||
|
|
||||||
|
[node name="Sprite2D" type="Sprite2D" parent="."]
|
||||||
|
scale = Vector2(1.2, 1.2)
|
||||||
|
flip_v = true
|
42
PanningCamera/PanningCamera2D.gd
Normal file
42
PanningCamera/PanningCamera2D.gd
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
extends Camera2D
|
||||||
|
class_name PanningCamera2D
|
||||||
|
|
||||||
|
@export var MIN_ZOOM: float = 0.5
|
||||||
|
@export var MAX_ZOOM: float = 3.0
|
||||||
|
@export var ZOOM_RATE: float = 8.0
|
||||||
|
@export var ZOOM_INCREMENT: float = 0.1
|
||||||
|
|
||||||
|
var target_zoom: float = 1.0
|
||||||
|
var reset_pos: Vector2 = Vector2(0.0, 0.0)
|
||||||
|
|
||||||
|
|
||||||
|
func _physics_process(delta: float) -> void:
|
||||||
|
zoom = lerp(zoom, target_zoom * Vector2.ONE, ZOOM_RATE * delta)
|
||||||
|
set_physics_process(not is_equal_approx(zoom.x, target_zoom))
|
||||||
|
|
||||||
|
|
||||||
|
func _unhandled_input(event: InputEvent) -> void:
|
||||||
|
if event is InputEventMouseButton:
|
||||||
|
if event.is_pressed():
|
||||||
|
if event.button_index == MOUSE_BUTTON_WHEEL_UP:
|
||||||
|
zoom_in()
|
||||||
|
if event.button_index == MOUSE_BUTTON_WHEEL_DOWN:
|
||||||
|
zoom_out()
|
||||||
|
if event is InputEventMouseMotion:
|
||||||
|
if event.button_mask == MOUSE_BUTTON_MASK_LEFT:
|
||||||
|
position -= event.relative / zoom
|
||||||
|
if event is InputEventKey:
|
||||||
|
if event.keycode == KEY_SPACE:
|
||||||
|
target_zoom = 1.0
|
||||||
|
zoom = Vector2(1.0, 1.0)
|
||||||
|
position = reset_pos
|
||||||
|
|
||||||
|
|
||||||
|
func zoom_in() -> void:
|
||||||
|
target_zoom = max(target_zoom - ZOOM_INCREMENT, MIN_ZOOM)
|
||||||
|
set_physics_process(true)
|
||||||
|
|
||||||
|
|
||||||
|
func zoom_out() -> void:
|
||||||
|
target_zoom = min(target_zoom + ZOOM_INCREMENT, MAX_ZOOM)
|
||||||
|
set_physics_process(true)
|
24
Player/player.gd
Normal file
24
Player/player.gd
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
extends Node2D
|
||||||
|
|
||||||
|
var yvel = 1
|
||||||
|
var yoff = 0
|
||||||
|
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
func _ready():
|
||||||
|
$Sprite2D.texture = PakAssetLoader.load_file("user://data/units.pak/tomomo_00_00.dat")
|
||||||
|
$Sprite2D.position = get_global_transform().origin
|
||||||
|
$Sprite2D.position.y -= 128
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(_delta):
|
||||||
|
var pos = get_global_transform().origin
|
||||||
|
pos.y += -128 + yoff
|
||||||
|
yvel -= 1
|
||||||
|
if yvel < -9:
|
||||||
|
yvel = 9
|
||||||
|
pos.y += yvel
|
||||||
|
yoff += yvel
|
||||||
|
$Sprite2D.position = pos
|
||||||
|
|
13
Player/player.tscn
Normal file
13
Player/player.tscn
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
[gd_scene load_steps=2 format=3 uid="uid://dtm0201qhcn4d"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://player.gd" id="1_6ggpr"]
|
||||||
|
|
||||||
|
[node name="Player" type="Node2D"]
|
||||||
|
z_index = 1
|
||||||
|
script = ExtResource("1_6ggpr")
|
||||||
|
metadata/_edit_group_ = true
|
||||||
|
|
||||||
|
[node name="Sprite2D" type="Sprite2D" parent="."]
|
||||||
|
top_level = true
|
||||||
|
z_index = 2
|
||||||
|
position = Vector2(2.08165e-12, -128)
|
16
main.tscn
Normal file
16
main.tscn
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
[gd_scene load_steps=3 format=3 uid="uid://djirenq1psstj"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://PanningCamera/PanningCamera2D.gd" id="1_vtapg"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://qipfodwbk1gf" path="res://Field/field.tscn" id="1_y0qkv"]
|
||||||
|
|
||||||
|
[node name="Main" type="Node2D"]
|
||||||
|
|
||||||
|
[node name="Camera2D" type="Camera2D" parent="."]
|
||||||
|
script = ExtResource("1_vtapg")
|
||||||
|
MIN_ZOOM = null
|
||||||
|
MAX_ZOOM = null
|
||||||
|
ZOOM_RATE = 5.0
|
||||||
|
|
||||||
|
[node name="Field" parent="." instance=ExtResource("1_y0qkv")]
|
||||||
|
rotation = 0.523599
|
||||||
|
skew = 0.523599
|
38
player.tscn
Normal file
38
player.tscn
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
[gd_scene load_steps=2 format=3 uid="uid://sp3iv6cxuerm"]
|
||||||
|
|
||||||
|
[sub_resource type="GDScript" id="GDScript_hd04s"]
|
||||||
|
script/source = "extends Node2D
|
||||||
|
|
||||||
|
var yvel = 1
|
||||||
|
var yoff = 0
|
||||||
|
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
func _ready():
|
||||||
|
$Sprite2D.texture = PakAssetLoader.load_file(\"user://data/units.pak/tomomo_00_00.dat\")
|
||||||
|
$Sprite2D.position = get_global_transform().origin
|
||||||
|
$Sprite2D.position.y -= 128
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(_delta):
|
||||||
|
var pos = get_global_transform().origin
|
||||||
|
pos.y += -128 + yoff
|
||||||
|
yvel -= 1
|
||||||
|
if yvel < -9:
|
||||||
|
yvel = 9
|
||||||
|
pos.y += yvel
|
||||||
|
yoff += yvel
|
||||||
|
$Sprite2D.position = pos
|
||||||
|
|
||||||
|
"
|
||||||
|
|
||||||
|
[node name="Player" type="Node2D"]
|
||||||
|
z_index = 1
|
||||||
|
script = SubResource("GDScript_hd04s")
|
||||||
|
metadata/_edit_group_ = true
|
||||||
|
|
||||||
|
[node name="Sprite2D" type="Sprite2D" parent="."]
|
||||||
|
top_level = true
|
||||||
|
z_index = 2
|
||||||
|
position = Vector2(2.08165e-12, -128)
|
Loading…
Reference in New Issue
Block a user