1 /* Project 16 Source Code~
\r
2 * Copyright (C) 2012-2017 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover
\r
4 * This file is part of Project 16.
\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
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
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
23 #ifndef __SCROLL16_H_
\r
24 #define __SCROLL16_H_
\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/16_map.h" //map is loaded here www
\r
32 //#include "src/lib/16render.h"
\r
33 #include "src/lib/16_timer.h"
\r
34 #include "src/lib/wcpu/16_wcpu.h"
\r
35 #include "src/lib/16_spri.h"
\r
37 #include <hw/cpu/cpu.h>
\r
38 #include <hw/dos/dos.h>
\r
39 #include <hw/vga/vga.h>
\r
40 #include <hw/vga/vrl.h>
\r
43 //#define TILERENDER
\r
47 //#define OLDWALKSHOWPAGESTUFF
\r
50 #define PLAYERBMPDATAVAR gvar.player[pn].data
\r
51 #define PLAYERBMPDATA *PLAYERBMPDATAVAR
\r
52 #define PLAYERBMPDATAPTR PLAYERBMPDATAVAR
\r
54 #define PCXBMPVAR gvar.player[0].data
\r
55 #define PCXBMP *PCXBMPVAR
\r
56 #define PCXBMPPTR PCXBMPVAR
\r
58 //row and colum drawing routines
\r
60 #define DRAWCOLNUM mv->page[id].dx
\r
61 #define DRAWROWNUM mv->page[id].dy
\r
62 //#define DRAWCOLNUM pl[plid].enti.q
\r
63 //#define DRAWROLNUM pl[plid].enti.q
\r
69 //===========================================================================//
\r
71 //if(gvar.player[0].enti.hp==0) printf("%d wwww\n", gvar.player[0].enti.y+8);
\r
72 //else printf("\ngvar.player[0].enti.y: %d\n", gvar.player[0].enti.y);
\r
73 //printf("gvar.video.p=%u ", gvar.video.p);
\r
74 //not used now printf("temporary gvar.player sprite 0: http://www.pixiv.net/member_illust.php?mode=medium&illust_id=45556867\n");
\r
75 //not used now printf("temporary gvar.player sprite 1: http://www.pixiv.net/member_illust.php?mode=medium&illust_id=44606385\n");
\r
76 //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
77 //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
78 //printf("map.width=%d map.height=%d map.data[0]=%d\n", mv[1].map->width, mv[1].map->height, mv[1].map->layerdata[0][0]);
\r
79 //printf("pageflipflop=%u", pageflipflop);
\r
80 //printf("&global_temp_status_text = %Fp\n", &global_temp_status_text);
\r
81 //printf("middle tile position: %dx", gvar.video.page[0].tilemidposscreenx); printf("%d\n", gvar.video.page[0].tilemidposscreeny);
\r
82 //printf(" aniframe=%u", gvar.player[0].enti.persist_aniframe);
\r
83 //printf("mv[0]txy: %dx%d ", mv[0].tx, mv[0].ty); printf("mv[1]txy: %dx%d", mv[1].tx, mv[1].ty);
\r
84 // printf("page[0]dxy: %dx%d", gvar.video.page[0].dx, gvar.video.page[0].dy);
\r
85 #define SCROLLEXITMESG \
\r
86 printf("size of mmblocktype: %u ", sizeof(mmblocktype));\
\r
88 printf("player vars:\n");\
\r
89 printf(" xy: %dx%d", gvar.player[0].enti.x, gvar.player[0].enti.y); printf(" txy: %dx%d", gvar.player[0].enti.tx, gvar.player[0].enti.ty); printf(" triggxy: %dx%d", gvar.player[0].enti.triggerx, gvar.player[0].enti.triggery); printf(" value: %d\n", gvar.mv[1].map->layerdata[0].data[(gvar.player[0].enti.triggerx-1)+(gvar.map.width*(gvar.player[0].enti.triggery-1))]);\
\r
90 printf(" hp: %d", (gvar.player[0].enti.hp)); printf(" q: %u", gvar.player[0].enti.q); printf(" info.dir: %u", gvar.player[0].info.dir); printf(" d: %u", gvar.player[0].enti.d); printf(" dire: %u", gvar.player[0].enti.dire);\
\r
91 printf(" pdir: %u\n", gvar.player[0].pdir); printf(" delay=%u", gvar.player[0].enti.spri.delay);\
\r
93 VL_PrintmodexmemInfo(&gvar.video);\
\r
95 printf("gvar.video:\n");\
\r
96 printf(" r=%u ", gvar.video.dorender);\
\r
97 printf("bgps=%u ", gvar.video.vga_state.bgps);\
\r
100 // printf("dbg_delayanimation=%u ", dbg_delayanimation);
\r
102 if(IN_KeyDown(sc_F11)){ pagedelayrendermap=!pagedelayrendermap; IN_UserInput(1, &gvar); }
\r
103 if(IN_KeyDown(sc_F10)){ gvar.kurokku.fpscap=!gvar.kurokku.fpscap; IN_UserInput(1, &gvar); }
\r
104 if(IN_KeyDown(sc_F9)){ pagenorendermap=!pagenorendermap; IN_UserInput(1, &gvar); }
\r
105 if(IN_KeyDown(sc_F8)){ gvar.video.vga_state.bgps=!gvar.video.vga_state.bgps; IN_UserInput(1, &gvar); }
\r
106 if(IN_KeyDown(sc_T)){ gvar.video.vga_state.rss=!gvar.video.vga_state.rss; IN_UserInput(1, &gvar); }
\r
109 extern char global_temp_status_text[512];
\r
110 extern char global_temp_status_text2[512];
\r
112 void initMap(map_t *map);
\r
113 void ZC_walk(global_game_variables_t *gvar, word pn);
\r
114 void ZC_panPageManual(map_view_t *pip, player_t *player, word pn);
\r
115 void ZC_MVSetup(map_view_t *pip, map_t *map, global_game_variables_t *gv);
\r
116 void ZC_MVInit(map_view_t *pip, int tx, int ty);
\r
117 //void ZC_ShowMV(map_view_t *moo, boolean vsync, boolean sr);
\r
118 void near mapScrollRight(map_view_t *mv, player_t *player, word id, word plid);
\r
119 void near mapScrollLeft(map_view_t *mv, player_t *player, word id, word plid);
\r
120 void near mapScrollUp(map_view_t *mv, player_t *player, word id, word plid);
\r
121 void near mapScrollDown(map_view_t *mv, player_t *player, word id, word plid);
\r
122 void ZC_mapScroll(map_view_t *mv, player_t *player, word pn);
\r
123 void ZC_PlayerXYpos(int x, int y, player_t *player, map_view_t *pip, boolean defaultsw);
\r
124 sword chkmap(map_t *map, word q);
\r
125 void mapGoTo(map_view_t *mv, int tx, int ty);
\r
126 void ZC_mapinitMV(map_view_t *mv, int tx, int ty);
\r
127 void ZC_mapredraw(map_view_t *mv, int tx, int ty);
\r
128 void near mapDrawTile(tiles_t *t, word i, page_t *page, word x, word y);
\r
129 void near mapDrawRow(map_view_t *mv, int tx, int ty, word y, player_t *player, word poopoffset);
\r
130 void near mapDrawCol(map_view_t *mv, int tx, int ty, word x, player_t *player, word poopoffset);
\r
131 void mapDrawWRow(map_view_t *mv, int tx, int ty, word y);
\r
132 void mapDrawWCol(map_view_t *mv, int tx, int ty, word x);
\r
133 inline void near ScrollRight(map_view_t *mv, player_t *pl, word id, word plid)
\r
135 /* increment the pixel position and update the page */
\r
136 mv[id].page->dx += pl[plid].enti.spt;
\r
138 /* check to see if this changes the tile */
\r
139 if(mv[id].page->dx >= mv[id].dxThresh )
\r
141 /* go forward one tile */
\r
142 if(id==0) mv[id].tx++;
\r
143 /* Snap the origin forward */
\r
144 mv[id].page->data += 4;
\r
146 mv[id].page->dx = mv[id].map->tiles->tileWidth;
\r
150 inline void near ScrollLeft(map_view_t *mv, player_t *pl, word id, word plid)
\r
152 /* decrement the pixel position and update the page */
\r
153 mv[id].page->dx -= pl[plid].enti.spt;
\r
155 /* check to see if this changes the tile */
\r
156 if(mv[id].page->dx == 0)
\r
158 /* go backward one tile */
\r
159 if(id==0) mv[id].tx--;
\r
160 /* Snap the origin backward */
\r
161 mv[id].page->data -= 4;
\r
163 mv[id].page->dx = mv[id].map->tiles->tileWidth;
\r
167 inline void near ScrollUp(map_view_t *mv, player_t *pl, word id, word plid)
\r
169 /* decrement the pixel position and update the page */
\r
170 mv[id].page->dy -= pl[plid].enti.spt;
\r
172 /* check to see if this changes the tile */
\r
173 if(mv[id].page->dy == 0 )
\r
175 /* go up one tile */
\r
176 if(id==0) mv[id].ty--;
\r
177 /* Snap the origin upward */
\r
178 mv[id].page->data -= mv[id].page->pi;
\r
180 mv[id].page->dy = mv[id].map->tiles->tileHeight;
\r
184 inline void near ScrollDown(map_view_t *mv, player_t *pl, word id, word plid)
\r
186 /* increment the pixel position and update the page */
\r
187 mv[id].page->dy += pl[plid].enti.spt;
\r
189 /* check to see if this changes the tile */
\r
190 if(mv[id].page->dy >= mv[id].dyThresh )
\r
192 /* go down one tile */
\r
193 if(id==0) mv[id].ty++;
\r
194 /* Snap the origin downward */
\r
195 mv[id].page->data += mv[id].page->pi;
\r
197 mv[id].page->dy = mv[id].map->tiles->tileHeight;
\r
203 void shinku(global_game_variables_t *gv);
\r
204 //animate the sprite
\r
205 void near ZC_animatePlayer(map_view_t *pip, player_t *player, word pn);
\r
207 // Move an entity around. Should actually be in 16_entity
\r
208 boolean ZC_walk2(entity_t *ent, map_view_t *map_v);
\r
210 // Move gvar.player around and call map scrolling if required/possible
\r
211 void walk_player(player_t *player, map_view_t *map_v);
\r
213 // Scroll map in one direction (assumed from gvar.player's movement)
\r
214 void mapScroll(map_view_t *mv, player_t *player);
\r
216 void ZC_GirdChk (global_game_variables_t *gvar, player_t *player);
\r
218 #endif /*__SCROLL16_H_*/
\r