summaryrefslogtreecommitdiff
path: root/table/water_land.h
diff options
context:
space:
mode:
Diffstat (limited to 'table/water_land.h')
-rw-r--r--table/water_land.h181
1 files changed, 94 insertions, 87 deletions
diff --git a/table/water_land.h b/table/water_land.h
index df11ecaa7..ab8aad1cd 100644
--- a/table/water_land.h
+++ b/table/water_land.h
@@ -1,130 +1,134 @@
-static const byte _shipdepot_display_seq_1[] = {
- ADD_WORD(0xFDD),
+typedef struct WaterDrawTileStruct {
+ byte delta_x;
+ byte delta_y;
+ byte delta_z;
+ byte width;
+ byte height;
+ byte unk;
+ SpriteID image;
+} WaterDrawTileStruct;
- 0,15,0,16,1,0x14,
- ADD_WORD(0x8FE8),
+#define BEGIN(image) { 0, 0, 0, 0, 0, 0, image }
+#define END(y) { 0x80, y, 0, 0, 0, 0, 0 }
- 0x80
+static const WaterDrawTileStruct _shipdepot_display_seq_1[] = {
+ BEGIN(0xFDD),
+ { 0, 15, 0, 16, 1, 0x14, 0x8FE8 },
+ END(0)
};
-static const byte _shipdepot_display_seq_2[] = {
- ADD_WORD(0xFDD),
-
- 0,0,0,16,1,0x14, ADD_WORD(0xFEA),
- 0,15,0,16,1,0x14, ADD_WORD(0x8FE6),
-
- 0x80
+static const WaterDrawTileStruct _shipdepot_display_seq_2[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 16, 1, 0x14, 0xFEA },
+ { 0, 15, 0, 16, 1, 0x14, 0x8FE6 },
+ END(0)
};
-static const byte _shipdepot_display_seq_3[] = {
- ADD_WORD(0xFDD),
-
- 15,0,0,1,0x10,0x14,ADD_WORD(0x8FE9),
-
- 0x80
+static const WaterDrawTileStruct _shipdepot_display_seq_3[] = {
+ BEGIN(0xFDD),
+ { 15, 0, 0, 1, 0x10, 0x14, 0x8FE9 },
+ END(0)
};
-static const byte _shipdepot_display_seq_4[] = {
- ADD_WORD(0xFDD),
-
- 0,0,0,1,16,0x14, ADD_WORD(0xFEB),
- 15,0,0,1,16,0x14, ADD_WORD(0x8FE7),
-
- 0x80
+static const WaterDrawTileStruct _shipdepot_display_seq_4[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 1, 16, 0x14, 0xFEB },
+ { 15, 0, 0, 1, 16, 0x14, 0x8FE7 },
+ END(0)
};
-static const byte * const _shipdepot_display_seq[] = {
+static const WaterDrawTileStruct* const _shipdepot_display_seq[] = {
_shipdepot_display_seq_1,
_shipdepot_display_seq_2,
_shipdepot_display_seq_3,
_shipdepot_display_seq_4,
};
-static const byte _shiplift_display_seq_0[] = {
- ADD_WORD(SPR_CANALS_BASE + 6),
- 0, 0, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 0 + 1),
- 0, 0xF, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 4 + 1),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_0[] = {
+ BEGIN(SPR_CANALS_BASE + 6),
+ { 0, 0, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 0 + 1 },
+ { 0, 0xF, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 4 + 1 },
+ END(0)
};
-static const byte _shiplift_display_seq_1[] = {
- ADD_WORD(SPR_CANALS_BASE + 5),
- 0, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 0),
- 0xF, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 4),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_1[] = {
+ BEGIN(SPR_CANALS_BASE + 5),
+ { 0, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 0 },
+ { 0xF, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 4 },
+ END(0)
};
-static const byte _shiplift_display_seq_2[] = {
- ADD_WORD(SPR_CANALS_BASE + 7),
- 0, 0, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 0 + 2),
- 0, 0xF, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 4 + 2),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_2[] = {
+ BEGIN(SPR_CANALS_BASE + 7),
+ { 0, 0, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 0 + 2 },
+ { 0, 0xF, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 4 + 2 },
+ END(0)
};
-static const byte _shiplift_display_seq_3[] = {
- ADD_WORD(SPR_CANALS_BASE + 8),
- 0, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 0 + 3),
- 0xF, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 4 + 3),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_3[] = {
+ BEGIN(SPR_CANALS_BASE + 8),
+ { 0, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 0 + 3 },
+ { 0xF, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 4 + 3 },
+ END(0)
};
-static const byte _shiplift_display_seq_0b[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 8 + 1),
- 0, 0xF, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 12 + 1),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_0b[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 8 + 1 },
+ { 0, 0xF, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 12 + 1 },
+ END(0)
};
-static const byte _shiplift_display_seq_1b[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 0x1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 8),
- 0xF, 0, 0, 0x1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 12),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_1b[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 0x1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 8 },
+ { 0xF, 0, 0, 0x1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 12 },
+ END(0)
};
-static const byte _shiplift_display_seq_2b[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 8 + 2),
- 0, 0xF, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 12 + 2),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_2b[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 8 + 2 },
+ { 0, 0xF, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 12 + 2 },
+ END(0)
};
-static const byte _shiplift_display_seq_3b[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 8 + 3),
- 0xF, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 12 + 3),
- 0x80, 0
+static const WaterDrawTileStruct _shiplift_display_seq_3b[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 8 + 3 },
+ { 0xF, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 12 + 3 },
+ END(0)
};
-static const byte _shiplift_display_seq_0t[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 16 + 1),
- 0, 0xF, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 20 + 1),
- 0x80, 8
+static const WaterDrawTileStruct _shiplift_display_seq_0t[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 16 + 1 },
+ { 0, 0xF, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 20 + 1 },
+ END(8)
};
-static const byte _shiplift_display_seq_1t[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 0x1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 16),
- 0xF, 0, 0, 0x1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 20),
- 0x80, 8
+static const WaterDrawTileStruct _shiplift_display_seq_1t[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 0x1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 16 },
+ { 0xF, 0, 0, 0x1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 20 },
+ END(8)
};
-static const byte _shiplift_display_seq_2t[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 16 + 2),
- 0, 0xF, 0, 0x10, 1, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 20 + 2),
- 0x80, 8
+static const WaterDrawTileStruct _shiplift_display_seq_2t[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 16 + 2 },
+ { 0, 0xF, 0, 0x10, 1, 0x14, SPR_CANALS_BASE + 9 + 20 + 2 },
+ END(8)
};
-static const byte _shiplift_display_seq_3t[] = {
- ADD_WORD(0xFDD),
- 0, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 16 + 3),
- 0xF, 0, 0, 1, 0x10, 0x14, ADD_WORD(SPR_CANALS_BASE + 9 + 20 + 3),
- 0x80, 8
+static const WaterDrawTileStruct _shiplift_display_seq_3t[] = {
+ BEGIN(0xFDD),
+ { 0, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 16 + 3 },
+ { 0xF, 0, 0, 1, 0x10, 0x14, SPR_CANALS_BASE + 9 + 20 + 3 },
+ END(8)
};
-static const byte * const _shiplift_display_seq[] = {
+static const WaterDrawTileStruct* const _shiplift_display_seq[] = {
_shiplift_display_seq_0,
_shiplift_display_seq_1,
_shiplift_display_seq_2,
@@ -141,6 +145,9 @@ static const byte * const _shiplift_display_seq[] = {
_shiplift_display_seq_3t,
};
+#undef BEGIN
+#undef END
+
static const SpriteID _water_shore_sprites[15] = {
0, 0xFDF, 0xFE0, 0xFE4, 0xFDE, 0, 0xFE2, 0, 0xFE1, 0xFE5, 0, 0, 0xFE3, 0, 0