]> 4ch.mooo.com Git - 16.git/blob - src/lib/scroll16.h
pushing some changes!
[16.git] / src / lib / scroll16.h
1 /* Project 16 Source Code~\r
2  * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
3  *\r
4  * This file is part of Project 16.\r
5  *\r
6  * Project 16 is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 3 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Project 16 is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>, or\r
18  * write to the Free Software Foundation, Inc., 51 Franklin Street,\r
19  * Fifth Floor, Boston, MA 02110-1301 USA.\r
20  *\r
21  */\r
22 \r
23 #ifndef __SCROLL16_H_\r
24 #define __SCROLL16_H_\r
25 \r
26 #include "src/lib/16_head.h"\r
27 #include "src/lib/16_tail.h"\r
28 #include "src/lib/bakapee.h"\r
29 #include "src/lib/16_vl.h"\r
30 #include "src/lib/16_in.h"\r
31 #include "src/lib/bitmap.h"\r
32 #include "src/lib/16_map.h" //map is loaded here www\r
33 #include "src/lib/16render.h"\r
34 //#include "src/lib/16_map.h"   //new map stuff\r
35 #include "src/lib/16_timer.h"\r
36 #include "src/lib/wcpu/16_wcpu.h"\r
37 #include "src/lib/16_sprit.h"\r
38 \r
39 #include <hw/cpu/cpu.h>\r
40 #include <hw/dos/dos.h>\r
41 #include <hw/vga/vga.h>\r
42 #include <hw/vga/vrl.h>\r
43 \r
44 #define SPRITE\r
45 //#define TILERENDER\r
46 \r
47 #define ANIMATESPRIFUN ZC_animatePlayer\r
48 \r
49 #define PLAYERBMPDATAVAR        player[pn].data\r
50 #define PLAYERBMPDATA           *PLAYERBMPDATAVAR\r
51 #define PLAYERBMPDATAPTR        PLAYERBMPDATAVAR\r
52 \r
53 #define PCXBMPVAR       player[0].data\r
54 #define PCXBMP          *PCXBMPVAR\r
55 #define PCXBMPPTR       PCXBMPVAR\r
56 \r
57 typedef struct {\r
58         map_t *map;\r
59         page_t *page;\r
60         int tx; //appears to be the top left tile position on the viewable screen map\r
61         int ty; //appears to be the top left tile position on the viewable screen map\r
62         word dxThresh; //Threshold for physical tile switch\r
63         word dyThresh; //Threshold for physical tile switch\r
64         video_t *video; //pointer to game variables of the video\r
65         nibble *panp;   // pointer to video's pan page num\r
66 //newer vars!\r
67         int dx, dy, delta, d;\r
68 } map_view_t;\r
69 /* Map is presumed to:\r
70  * 1. Have all the required layers and tilesets within itself\r
71  * 2. Have a 'fence' around accessible blocks to simplify boundary logic\r
72  * 3. Have a persistent map and tile size among the layers\r
73  * Map view is presumed to:\r
74  * 1. Calculate, store and update a panning info, which includes, but not limited to:\r
75  *      combined layer information, actual map representation (reflecting real state of the game),\r
76  *      pixel shift for smooth tile scrolling.\r
77  * 2. Provide ways to draw a visible part of map. For simplicity with smooth scrolling,\r
78  *      additional row/column is always drawn at the each side of the map. This implies that 'fence'\r
79  *      should have a sprite too. Map is drawn left-to-right, top-to-bottom.\r
80  */\r
81 \r
82 //for null map!\r
83 #define MAPW    40\r
84 #define MAPH    30\r
85 \r
86         //if(player[0].enti.hp==0) printf("%d wwww\n", player[0].enti.y+8);\r
87         //else printf("\nplayer[0].enti.y: %d\n", player[0].enti.y);\r
88 //      printf("palette offset: %d\n", paloffset/3);\r
89 //++++  printf("Total used: %zu\n", oldfreemem-GetFreeSize());\r
90 //++++  printf("Total free: %zu\n", GetFreeSize());\r
91 //not used now  printf("temporary player sprite 0: http://www.pixiv.net/member_illust.php?mode=medium&illust_id=45556867\n");\r
92 //not used now  printf("temporary player sprite 1: http://www.pixiv.net/member_illust.php?mode=medium&illust_id=44606385\n");\r
93 //printf("mv[%u].tx: %d", gvar.video.panp, mv[gvar.video.panp].tx); printf("    mv[%u].ty: %d   ", gvar.video.panp, mv[gvar.video.panp].ty);\r
94 //printf("gvar.kurokku: "); printf("%.0f ", clock());   printf("tiku=%lu ", gvar.kurokku.tiku); printf("t=%.0f ", gvar.kurokku.t);      printf("ticktock()=%f ", ticktock(&gvar));      printf("%.0f fps", (double)gvar.kurokku.tiku/ticktock(&gvar));\r
95 //printf("map.width=%d  map.height=%d   map.data[0]=%d\n", mv[0].map->width, mv[0].map->height, mv[0].map->data[0]);\r
96 //printf("&global_temp_status_text = %Fp\n", &global_temp_status_text);\r
97 //print_anim_ids(player[0].ent->spri);\r
98 #define SCROLLEXITMESG  printf("tx: %d  ", mv[0].tx);\\r
99         printf("ty: %d\n", mv[0].ty);\\r
100         printf("\n");\\r
101         printf("player vars:\n");\\r
102         printf("        x: %d", player[0].enti.x); printf("     y: %d\n", player[0].enti.y);\\r
103         \\r
104         printf("        tx: %d", player[0].enti.tx); printf("   ty: %d\n", player[0].enti.ty);\\r
105         printf("        triggx: %d", player[0].enti.triggerx); printf(" triggy: %d\n", player[0].enti.triggery);\\r
106         printf("        hp: %d", (player[0].enti.hp));  printf("        q: %d", player[0].enti.q);      printf("        player.info.dir: %d", player[0].info.dir);      printf("        player.d: %d ", player[0].enti.d);\\r
107                 printf("        pdir=%d\n", player[0].pdir); printf("   aniframe=%u", player[0].enti.persist_aniframe);\\r
108         printf("        tile data value at player trigger position: %d\n\n", mv[0].map->data[(player[0].enti.triggerx-1)+(map.width*(player[0].enti.triggery-1))]);\\r
109 \\r
110         printf("Virtual Screen: %dx", gvar.video.page[0].width);        printf("%d      ", gvar.video.page[0].height);\\r
111         printf("Screen: %dx", gvar.video.page[0].sw);   printf("%d\n", gvar.video.page[0].sh);\\r
112         printf("virtual tile resolution: %dx", gvar.video.page[0].tilesw);      printf("%d      ", gvar.video.page[0].tilesh);\\r
113         printf("tile resolution: %dx", gvar.video.page[0].tw);  printf("%d\n", gvar.video.page[0].th);\\r
114         printf("middle tile position: %dx", gvar.video.page[0].tilemidposscreenx);      printf("%d\n", gvar.video.page[0].tilemidposscreeny);\\r
115         modexprintmeminfo(&gvar.video);\\r
116 \\r
117         printf("gvar.video.p=%u ", gvar.video.p); printf("gvar.video.r=%u ", gvar.video.r);\\r
118         printf("pageflipflop=%u\n", pageflipflop);\\r
119         printf("\n");\r
120 \r
121 #define SHOWMVFUN ZC_ShowMV(&mv, 0, 0);\r
122 #define PANKEYFUN \\r
123                         ZC_panPageManual(&mv, &player, 0); \\r
124                         if(IN_KeyDown(1+1) || IN_KeyDown(sc_Z)){ gvar.video.panp=0; SHOWMVFUN; } \\r
125                         if(IN_KeyDown(2+1) || IN_KeyDown(sc_X)){ gvar.video.panp=1; SHOWMVFUN; } \\r
126                         if(IN_KeyDown(3+1) || IN_KeyDown(sc_C)){ gvar.video.panp=2; SHOWMVFUN; if(IN_KeyDown(sc_C)) modexClearRegion(&gvar.video.page[2], 0, 0, gvar.video.page[2].sw, gvar.video.page[2].sh, 47); } \\r
127                         if(IN_KeyDown(4+1) || IN_KeyDown(sc_V)){ gvar.video.panp=3; SHOWMVFUN; if(IN_KeyDown(sc_V)) modexClearRegion(&gvar.video.page[3], 0, 0, gvar.video.page[3].sw, gvar.video.page[3].sh, 45); } \\r
128                         if(IN_KeyDown(25)){ modexpdump(mv[1].page); modexShowPage(&(gvar.video.page[1])); IN_UserInput(1,1); }\r
129 \r
130 extern boolean pageflipflop, pageploop;\r
131 \r
132 extern char global_temp_status_text[512];\r
133 \r
134 //map_t allocMap(int w, int h);\r
135 //void initMap(map_t *map);\r
136 void ZC_walk(map_view_t *pip, player_t *player, word pn);\r
137 void oldwalk(map_view_t *pip, player_t *player, word pn);\r
138 void ZC_panPageManual(map_view_t *pip, player_t *player, word pn);\r
139 void ZC_MVSetup(map_view_t *pip, map_t *map, global_game_variables_t *gv);\r
140 void ZC_MVInit(map_view_t *pip, int tx, int ty);\r
141 void ZC_ShowMV(map_view_t *moo, boolean vsync, boolean sr);\r
142 void near mapScrollRight(map_view_t *mv, player_t *player, word id, word plid);\r
143 void near mapScrollLeft(map_view_t *mv, player_t *player, word id, word plid);\r
144 void near mapScrollUp(map_view_t *mv, player_t *player, word id, word plid);\r
145 void near mapScrollDown(map_view_t *mv, player_t *player, word id, word plid);\r
146 void near ScrollRight(map_view_t *mv, player_t *player, word id, word plid);\r
147 void near ScrollLeft(map_view_t *mv, player_t *player, word id, word plid);\r
148 void near ScrollUp(map_view_t *mv, player_t *player, word id, word plid);\r
149 void near ScrollDown(map_view_t *mv, player_t *player, word id, word plid);\r
150 void playerXYpos(int x, int y, player_t *player, map_view_t *pip, nibble pn);\r
151 sword chkmap(map_t *map, word q);\r
152 void mapGoTo(map_view_t *mv, int tx, int ty);\r
153 void mapinitmapview(map_view_t *mv, int tx, int ty);\r
154 void near mapDrawTile(tiles_t *t, word i, page_t *page, word x, word y);\r
155 void near mapDrawRow(map_view_t *mv, int tx, int ty, word y, player_t *player, word poopoffset);\r
156 void near mapDrawCol(map_view_t *mv, int tx, int ty, word x, player_t *player, word poopoffset);\r
157 void mapDrawWRow(map_view_t *mv, int tx, int ty, word y);\r
158 void mapDrawWCol(map_view_t *mv, int tx, int ty, word x);\r
159 //void qclean();\r
160 void shinku(global_game_variables_t *gv);\r
161 void near ZC_drawframe(map_view_t *pip, player_t *player, word pn, sword x, sword y, word sw);\r
162 void near animatePlayer(map_view_t *pip, player_t *player, word pn, sword scrollswitch);\r
163 void near ZC_animatePlayer(map_view_t *pip, player_t *player, word pn, sword scrollswitch);\r
164 \r
165 // Move an entity around. Should actually be in 16_entity\r
166 boolean ZC_walk2(entity_t *ent, map_view_t *map_v);\r
167 \r
168 // Move player around and call map scrolling if required/possible\r
169 void walk_player(player_t *player, map_view_t *map_v);\r
170 \r
171 // Scroll map in one direction (assumed from player's movement)\r
172 void near mapScroll(map_view_t *mv, player_t *player);\r
173 \r
174 #endif /*__SCROLL16_H_*/\r
175 //older zc_animate\r
176 //#define SPRITO\r
177 /*void near ZC_animatePlayer_(map_view_t *pip, player_t *player, word pn, sword scrollswitch)\r
178 {\r
179         sword x = player[pn].enti.x;\r
180         sword y = player[pn].enti.y;\r
181         word dire=10; //direction\r
182         sword qq; //scroll offset\r
183         word ls = player[pn].enti.persist_aniframe;\r
184 #ifndef SPRITO\r
185         int i=0;\r
186 #endif\r
187         switch(scrollswitch)\r
188         {\r
189                 case 0:\r
190                         qq = 0;\r
191                 break;\r
192                 default:\r
193                         qq = ((player[pn].enti.q)*(player[pn].enti.speed));\r
194                 break;\r
195         }\r
196 #ifdef SPRITE\r
197         x-=4;\r
198 #endif\r
199         y-=pip[0].map->tiles->tileHeight;\r
200         switch (player[pn].enti.d)\r
201         {\r
202                 case 0:\r
203                         //up\r
204                         dire*=player[pn].enti.d+1;\r
205                         y-=qq;\r
206                 break;\r
207                 case 3:\r
208                         // right\r
209                         dire*=(player[pn].enti.d-1);\r
210                         x+=qq;\r
211                 break;\r
212                 case 2:\r
213                 break;\r
214                 case 4:\r
215                         //down\r
216                         dire*=(player[pn].enti.d-1);\r
217                         y+=qq;\r
218                 break;\r
219                 case 1:\r
220                         //left\r
221                         dire*=(player[pn].enti.d+3);\r
222                         x-=qq;\r
223                 break;\r
224         }\r
225 \r
226         //setting xy position\r
227         player[pn].ent->spri->x = x;\r
228         player[pn].ent->spri->y = y;\r
229 \r
230 #ifndef SPRITO\r
231 //#define DRAWFRAME if (i == -1) return; oldanimate_spri(player[pn].ent->spri, pip->video)\r
232 #define DRAWFRAME if (i == -1) return; animate_spri(player[pn].ent->spri, pip->video)\r
233 #define NFRAME1 i = set_anim_by_id(player[pn].ent->spri, 2+dire);       DRAWFRAME;\r
234 #define NFRAME2 i = set_anim_by_id(player[pn].ent->spri, 1+dire);       DRAWFRAME;\r
235 #define NFRAME3 i = set_anim_by_id(player[pn].ent->spri, dire); DRAWFRAME;\r
236 #define NFRAME4 i = set_anim_by_id(player[pn].ent->spri, 2+dire);       DRAWFRAME;\r
237 #else\r
238 #define NFRAME1 modexClearRegion(pip[(pip->video->p)].page, x, y, 16, 32, 2+dire);\r
239 #define NFRAME2 modexClearRegion(pip[(pip->video->p)].page, x, y, 16, 32, 1+dire);\r
240 #define NFRAME3 modexClearRegion(pip[(pip->video->p)].page, x, y, 16, 32, dire);\r
241 #define NFRAME4 modexClearRegion(pip[(pip->video->p)].page, x, y, 16, 32, 1+dire);\r
242 #endif\r
243 \r
244         switch(ls)\r
245         {\r
246                 case 1:\r
247                         NFRAME1\r
248                 break;\r
249                 case 2:\r
250                         NFRAME2\r
251                 break;\r
252                 case 3:\r
253                         NFRAME3\r
254                 break;\r
255                 case 4:\r
256                         NFRAME4\r
257                 break;\r
258         }\r
259         pip->video->r=1;\r
260 }*/\r
261 \r
262 //modexDrawSpritePBufRegion\r
263 //modexDrawBmpPBufRegion\r
264 //#define PBUFSFUN              modexDrawSpriteRegion\r
265 //#define PBUFBFUN              modexDrawBmpRegion\r