]> 4ch.mooo.com Git - 16.git/blobdiff - src/scroll.c
new file: doc/parody.doc
[16.git] / src / scroll.c
index 9bd161846bd4e062f4db60c46601f59a482b0149..65929b5a9bca125bb8a076b16a0ecef6929f3839 100644 (file)
@@ -1,7 +1,29 @@
+/* Project 16 Source Code~
+ * Copyright (C) 2012-2015 sparky4 & pngwen & andrius4669
+ *
+ * This file is part of Project 16.
+ *
+ * Project 16 is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Project 16 is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program.  If not, see <http://www.gnu.org/licenses/>, or
+ * write to the Free Software Foundation, Inc., 51 Franklin Street,
+ * Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ */
+
 #include "src/lib/dos_kb.h"\r
 #include "src/lib/mapread.h"\r
-#include "src/lib/wtest/wtest.c"\r
-#include "src/lib/planar.c"\r
+#include "src/lib/wcpu/wcpu.h"\r
+#include "src/lib/planar.h"\r
 //====#include "src\lib\ems.c"\r
 \r
 //word far *clock= (word far*) 0x046C; /* 18.2hz clock */\r
@@ -49,7 +71,7 @@ void mapDrawRow(map_view_t *mv, int tx, int ty, word y);
 void mapDrawCol(map_view_t *mv, int tx, int ty, word x);\r
 void qclean();\r
 void pdump(map_view_t *pee);\r
-void animatePlayer(map_view_t *src, map_view_t *dest, /*map_view_t *top, */sword d, short scrolloffsetswitch, int x, int y, int ls, int lp, bitmap_t *bmp);\r
+void animatePlayer(map_view_t *src, map_view_t *dest, /*map_view_t *top, */sword d, short scrolloffsetswitch, int x, int y, int ls, int lp, bitmap_t *bmp);
 \r
 #define TILEWH 16\r
 #define QUADWH                 TILEWH/2\r
@@ -63,7 +85,7 @@ void animatePlayer(map_view_t *src, map_view_t *dest, /*map_view_t *top, */sword
 //#define TRIGGY 9\r
 \r
 void main() {\r
-       size_t oldfreemem=GetFreeSize();\r
+//++++ size_t oldfreemem=GetFreeSize();\r
        /*long emmhandle;\r
        long emsavail;\r
        char teststr[80];*/\r
@@ -184,7 +206,7 @@ void main() {
        //printf("      %d\n", sizeof(ptmp.data));\r
        //printf("1:    %d\n", paloffset);\r
        map.tiles->data->offset=(paloffset/3);\r
-       modexPalUpdate(map.tiles->data, &paloffset, 0, 0);\r
+       //XTmodexPalUpdate(map.tiles->data, &paloffset, 0, 0);\r
        printf("\n====\n");\r
        printf("0       paloffset=      %d\n", paloffset/3);\r
        printf("====\n\n");\r
@@ -196,11 +218,11 @@ void main() {
        /* setup camera and screen~ */\r
        screen = modexDefaultPage();\r
        screen.width += (TILEWH*2);\r
-       screen.height += (TILEWH*2)+QUADWH;\r
+       screen.height += (TILEWH*2);//+QUADWH;\r
        mv[0].page = &screen;\r
        screen2 = modexNextPage(mv[0].page);\r
        mv[1].page = &screen2;\r
-       screen3 = modexNextPage0(mv[1].page, 352, 176); //(352*176)+1024 is the remaining amount of memory left wwww\r
+       screen3 = modexNextPage0(mv[1].page, 320, 240); //(352*176)+1024 is the remaining amount of memory left wwww\r
        //screen3 = modexNextPage0(mv2.page, 320, 192); //(352*176)+1024 is the remaining amount of memory left wwww\r
        mv[2].page = &screen3;\r
 \r
@@ -208,9 +230,6 @@ void main() {
        bg = &mv[0];\r
        spri = &mv[1];\r
        mask = &mv[2];
-       //pgid[0].mv = &mv;
-       //pgid[1].mv = &mv2;
-       //pgid[2].mv = &mv3;\r
 \r
 //TODO: LOAD map data and position the map in the middle of the screen if smaller then screen\r
        mapGoTo(bg, 0, 0);\r
@@ -241,7 +260,8 @@ void main() {
        modexDrawSpriteRegion(spri->page, player.x-4, player.y-TILEWH, 24, 64, 24, 32, &ptmp);\r
 \r
        modexShowPage(spri->page);\r
-//     printf("Total used @ before loop:                       %zu\n", oldfreemem-GetFreeSize());\r
+//     printf("Total used @ before loop:                       %zu\n", oldfreemem-GetFreeSize());
+       modexClearRegion(mv[2].page, 0, 0, mv[2].page->width, mv[2].page->height, 1);\r
        modexFadeOn(4, gpal);\r
        while(!keyp(1) && player.hp>0)\r
        {\r
@@ -264,9 +284,9 @@ void main() {
                        {\r
                                INC_PER_FRAME;\r
                                //animatePlayer(bg, spri, mask, 1, 1, player.x, player.y, persist_aniframe, q, &ptmp);\r
-                               animatePlayer(bg, spri, player.d-1, 1, player.x, player.y, persist_aniframe, player.q, &ptmp);\r
+                               animatePlayer(bg, spri, player.d-1, 1, player.x, player.y, persist_aniframe, player.q, &ptmp);
                                mapScrollRight(mv, SPEED, 0);\r
-                               mapScrollRight(mv, SPEED, 1);\r
+                               mapScrollRight(mv, SPEED, 1);
                                //mapScrollRight(mask, SPEED);\r
                                modexShowPage(spri->page);\r
                                player.q++;\r
@@ -595,8 +615,8 @@ void main() {
        printf("player.hp: %d", player.hp);     printf("        player.q: %d", player.q);       printf("        player.d: %d\n", player.d);\r
        printf("tile data value at player trigger position: %d\n", bg->map->data[(player.triggerx-1)+(map.width*(player.triggery-1))]);\r
        printf("palette offset: %d\n", paloffset/3);\r
-       printf("Total used: %zu\n", oldfreemem-GetFreeSize());\r
-       printf("Total free: %zu\n", GetFreeSize());\r
+//++++ printf("Total used: %zu\n", oldfreemem-GetFreeSize());\r
+//++++ printf("Total free: %zu\n", GetFreeSize());\r
        printf("temporary player sprite 0: http://www.pixiv.net/member_illust.php?mode=medium&illust_id=45556867\n");\r
        printf("temporary player sprite 1: http://www.pixiv.net/member_illust.php?mode=medium&illust_id=44606385\n");\r
        printf("Screen: %dx", screen.width);    printf("%d\n", screen.height);\r
@@ -707,8 +727,8 @@ initMap(map_t *map) {
                }\r
                //tile = tile ? 0 : 1;\r
        }*/\r
-}\r
-\r
+}
+
 \r
 void\r
 mapScrollRight(map_view_t *mv, byte offset, word id)
@@ -729,7 +749,7 @@ mapScrollRight(map_view_t *mv, byte offset, word id)
        /* draw the next column */\r
        x= SCREEN_WIDTH + mv[id].map->tiles->tileWidth;\r
                if(id==0)
-                       mapDrawCol(&mv[id], mv[id].tx + 20 , mv[id].ty-1, x);
+                       mapDrawCol(&mv[0], mv[0].tx + 20 , mv[0].ty-1, x);
                else
                        modexCopyPageRegion(mv[id].page, mv[0].page, x, 0, x, 0, mv[id].map->tiles->tileWidth, mv[id].map->tiles->tileHeight*17);
        }\r
@@ -753,11 +773,12 @@ mapScrollLeft(map_view_t *mv, byte offset, word id)
        mv[id].page->data -= 4;\r
        mv[id].page->dx = mv[id].map->tiles->tileWidth;\r
 \r
-       /* draw the next column */\r
+       /* draw the next column */
+       x= 0;\r
                if(id==0)\r
-                       mapDrawCol(&mv[0], mv[id].tx-1, mv[id].ty-1, 0);
+                       mapDrawCol(&mv[0], mv[0].tx-1, mv[0].ty-1, 0);
                else
-                       modexCopyPageRegion(mv[id].page, mv[0].page, 0, 0, 0, 0, mv[id].map->tiles->tileWidth, mv[id].map->tiles->tileHeight*17);\r
+                       modexCopyPageRegion(mv[id].page, mv[0].page, x, 0, x, 0, mv[id].map->tiles->tileWidth, mv[id].map->tiles->tileHeight*17);\r
        }\r
 }\r
 \r
@@ -779,11 +800,11 @@ mapScrollUp(map_view_t *mv, byte offset, word id)
        mv[id].page->dy = mv[id].map->tiles->tileHeight;\r
 \r
        /* draw the next row */\r
-       //y= 0;\r
+       y= 0;\r
                if(id==0)\r
-                       mapDrawRow(&mv[0], mv[id].tx-1 , mv[id].ty-1, 0);
+                       mapDrawRow(&mv[0], mv[0].tx-1 , mv[0].ty-1, 0);
                else\r
-                       modexCopyPageRegion(mv[id].page, mv[0].page, 0, 0, 0, 0, mv[id].map->tiles->tileWidth*22, mv[id].map->tiles->tileHeight);
+                       modexCopyPageRegion(mv[id].page, mv[0].page, 0, y, 0, y, mv[id].map->tiles->tileWidth*22, mv[id].map->tiles->tileHeight);
        }\r
 }\r
 \r
@@ -807,7 +828,7 @@ mapScrollDown(map_view_t *mv, byte offset, word id)
        /* draw the next row */\r
        y= SCREEN_HEIGHT + mv[id].map->tiles->tileHeight;\r
                if(id==0)\r
-                       mapDrawRow(&mv[0], mv[id].tx-1 , mv[id].ty+15, y);
+                       mapDrawRow(&mv[0], mv[0].tx-1 , mv[0].ty+15, y);
                else
                        modexCopyPageRegion(mv[id].page, mv[0].page, 0, y, 0, y, mv[id].map->tiles->tileWidth*22, mv[id].map->tiles->tileHeight);\r
        }\r
@@ -956,5 +977,6 @@ animatePlayer(map_view_t *src, map_view_t *dest, /*map_view_t *top, */sword d, s
        //modexClearRegion(top->page, 66, 66, 2, 40, 0);\r
        //modexCopyPageRegion(dest->page, top->page, 66, 66, 66, 66, 2, 40);\r
        //turn this off if XT\r
-       if(detectcpu() > 0) modexWaitBorder();\r
+       //XTif(detectcpu() > 0)
+       modexWaitBorder();\r
 }\r