From 4cd4f328bb85ed8eeb3c0c3411a472925cc518d1 Mon Sep 17 00:00:00 2001 From: sparky4 Date: Sun, 23 Nov 2014 11:50:53 -0600 Subject: [PATCH] modified: 16/modex16/ptmp.pcx temperary player sprite new file: 16/modex16/ptmp.png modified: 16/modex16/scroll.c added animated sprites modified: 16/modex16/scroll.exe exe file --- 16/modex16/ptmp.pcx | Bin 929 -> 5047 bytes 16/modex16/ptmp.png | Bin 0 -> 2715 bytes 16/modex16/scroll.c | 94 +++++++++++++++++++++++++++++++++--------- 16/modex16/scroll.exe | Bin 19296 -> 20176 bytes 4 files changed, 74 insertions(+), 20 deletions(-) create mode 100644 16/modex16/ptmp.png diff --git a/16/modex16/ptmp.pcx b/16/modex16/ptmp.pcx index 879e70c290e421070df45c09d121804d437f05f8..57cfd19698e19e70b54414bc3613029bae8af08d 100644 GIT binary patch literal 5047 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 literal 929 zcmd;LW#nK00)8L_gZ~hUXp&KYfsvtv=@BE*I#3i|V89P~7)W&xit(eI(GVD_ArPKa IwPni|04k0X`v3p{ diff --git a/16/modex16/ptmp.png b/16/modex16/ptmp.png new file mode 100644 index 0000000000000000000000000000000000000000..e3e46aa83d1a9d2adf7a8a1132cf72db371e1a49 GIT binary patch literal 2715 zcmV;M3S{+(P)hwaM; zwh9ne=$C5Zu>)HRi0h2QNYDR5f{eg83bq^&DZs}2;XQ8Tq!I~|f$?~N2AWVz1V&Nm z#HXdIJa%9h64B(&OfIEGh8LGXH69fvI+7s!ROBJ~KqV&XYl@%_of>}bu`lJ?;qd~C z1L501^P__OMK11N8Q+Q%-ifLyL3UsZpz&=L$V@ZtEMo&TYA0E7c9}YL9u}2I(2xc) zj}^b2>SR;C`59P>N?Z<+1Q|yx0aUusiAi8_DcYU}`-7CfS1v(c4a>)e;lssnF{lT; z4$s%aHMZx&k9r??{PF4s+8G`og^lY#ci4D7Tap$$rqsbj>t77*!(aS;BQ z&}rf^#)|xtF%3jI;uD$vr2qCLh@(~lyLtEe@0*`K{`!3<5a`@}yagRGM4;TmzhDR0 ztusNO1Hf9xI2BH&M$br4Oj3H@P(7s|csNpkXQ%_QV^syB9mIu!QPF>=Vfb_Nd677tAPO?VGdMsL5(hfY z3$adYdi4()Utq>#E@*cnB$&AY+MJ z+Xx&8h5V?@z^0SP)z#JI<s_NyS~iG!VA^EQR+pw0|JkaRrg1IFEg`>}Rbs5Vp~>Y(CxI1`Q;Ups9t&4s4vi zUC{}oEfO3qwCacip_I?#eGzkHUmi&V(YymU(sMkXAet^V2gcVWdw{qU3AScOBxsz! z+3E9mBO@V~0NTz22<)Ca?B>C*^3((4Q-efQIv+)h*UN%Y zK`&H;XA)`65gjWC38>KEY`(@&1ualM=V=1sa{`hQtyKqmL4vqoG%zic1`?MjZ;@GM zCy#CXm9*kOT1vE>h@N7Wq#BGrXbJPBC#vnqSaGtGx!nt<9!u$B`N(x|P0f=j@z~l^ zVBJlO&A)tLs{n~he-$ZTq!QRFKzuyiFBKH2-0u5<_%NDRIN_rF`4Uta-Q((X8i?MW z8&TX|=u8mmGz2Dqa8;Rre!sd3hD3e2pTO;fV2&Pm=I%nX9@r{CyX8{5FiN;P6*;jv z&rX;@Wgb}q;sKFYRt6fGp*kvaRjkGHH4NuKEqIpINYFN?DkZHma3DURj1^+2I*DV8}AEuVn;>9rUJ639{D}`Kql33Z|KE%Gm4E z?JY>{nAg!HRpKe>6if2^fi|p)2p6UKj}F8ay8Q%|a_!ZRbpml6KCJ1{iSrce$2x&F ztUQWi@k}>KIXtG0T|WlTCXgefbJ+KInKdvVo zb3&ES$tB1uj7!sSsnUEgsFO}msFX1gm8r&CLZOtM=m#`5?c5}yLLDrL!ty9A-OAOE z>6R(8qWZC19h;C^v3@KF=8e-a$N$axv1+;Ala2J)+EZXFwVoU7Spw_4>5~W_9JtOdHXid#NYyACw+`!tVJsAo8u+j-fv6KFes8yqbkH0(s#RJC#tb5!DK2rLK` zx3*9U8h7!ItdgrUK~&Qi3QPm-m&SHHFg*Tnm1D0xD=IsL4_YZfs6$ktz%)>T1{=CQ zRJ29Laa_UV;U$iGXHQ)KO(~$wTo1)38t4tQ1}1n8bA;y3UVSwJZI)jfX$3;>XI%c= zZ(=5<6SSG#z~;cXS)2yiv63hnyzXMZMdl}n*xCZ)Kz!PhIEA#wl@QSh@};~BhO*KV zl}Pqjw!@neL{z1nD_@;ON0bhF0%)@=8yneoy;`NjtT`DNrWp-I_|&KHT7hU;;r+6Z ztW|1U`eQg2i57TkAT(6bN~XZ#=Omv3bHP@ft+M}wR5UORlnYGEqlC^_Fe6vtseIX) zV~JOSndVYjwn@Z^DjJvrghEXgj42ZDzAaQ*@ld0uqJz~_1GY*LS};3Lro>}w{{U}j VzKOagY+C>T002ovPDHLkV1ix0=-vPT literal 0 HcmV?d00001 diff --git a/16/modex16/scroll.c b/16/modex16/scroll.c index 33965008..24e91e74 100644 --- a/16/modex16/scroll.c +++ b/16/modex16/scroll.c @@ -51,7 +51,8 @@ void mapScrollDown(map_view_t *mv, byte offset); void mapGoTo(map_view_t *mv, int tx, int ty); void mapDrawTile(tiles_t *t, word i, page_t *page, word x, word y); void mapDrawRow(map_view_t *mv, int tx, int ty, word y); -void mapDrawCol(map_view_t *mv, int tx, int ty, word x); +void mapDrawCol(map_view_t *mv, int tx, int ty, word x); +void animatePlayer(map_view_t *mv, short d1, short d2, int x, int y, int ls, bitmap_t *bmp); #define TILEWH 16 #define QUADWH (TILEWH/4) @@ -62,12 +63,12 @@ void mapDrawCol(map_view_t *mv, int tx, int ty, word x); #define MAPY 30 //#define SWAP(a, b) tmp=a; a=b; b=tmp; void main() { - bitmap_t bmp; + bitmap_t ptmp; // player sprite int q=0; - page_t screen;//,screen2; + page_t screen, screen2; map_t map; - map_view_t mv;//, mv2; - map_view_t *draw;//, *show, *tmp; + map_view_t mv, mv2; + map_view_t *draw, *show, *tmp; byte *ptr; setkb(1); @@ -79,9 +80,9 @@ void main() { /* draw the tiles */ ptr = map.data; - bmp = bitmapLoadPcx("ptmp.pcx"); // load sprite - modexPalUpdate(bmp.palette); - modexEnter(); + ptmp = bitmapLoadPcx("ptmp.pcx"); // load sprite + modexEnter(); + modexPalUpdate(ptmp.palette); screen = modexDefaultPage(); screen.width += (TILEWH*2); mv.page = &screen; @@ -104,7 +105,8 @@ void main() { player.ty = draw->ty + 8; player.x = player.tx*TILEWH; player.y = player.ty*TILEWH; - + modexDrawSpriteRegion(draw->page, player.x-4, player.y-TILEWH, 24, 64, 24, 32, &ptmp); + modexShowPage(draw->page); while(!keyp(1)) { @@ -115,11 +117,13 @@ void main() { //TODO: render the player properly with animation and sprite sheet if(keyp(77)) { +// modexDrawSpriteRegion(draw->page, player.x-4, player.y-TILEWH, 24, 32, 24, 32, &ptmp); if(draw->tx >= 0 && draw->tx+20 < MAPX && player.tx == draw->tx + 10) { for(q=0; q<(TILEWH/SPEED); q++) { - modexDrawBmp(draw->page, player.x+((q+1)*SPEED), player.y, &bmp); +// modexDrawBmp(draw->page, &bmp); + animatePlayer(draw, 1, 1, player.x, player.y, q, &ptmp); mapScrollRight(draw, SPEED); modexShowPage(draw->page); // mapScrollRight(draw, 1); @@ -132,19 +136,23 @@ void main() { for(q=0; q<(TILEWH/SPEED); q++) { player.x+=SPEED; - modexDrawBmp(draw->page, player.x, player.y, &bmp); +// modexDrawBmp(draw->page, player.x, player.y, &bmp); + animatePlayer(draw, 1, 0, player.x, player.y, q, &ptmp); modexShowPage(draw->page); } player.tx++; } } - if(keyp(75)){ + if(keyp(75)) + { +// modexDrawSpriteRegion(draw->page, player.x-4, player.y-TILEWH, 24, 96, 24, 32, &ptmp); if(draw->tx > 0 && draw->tx+20 <= MAPX && player.tx == draw->tx + 10) - { + { for(q=0; q<(TILEWH/SPEED); q++) { - modexDrawBmp(draw->page, player.x-((q+1)*SPEED), player.y, &bmp); +// modexDrawBmp(draw->page, player.x-((q+1)*SPEED), player.y, &bmp); + animatePlayer(draw, 3, 1, player.x, player.y, q, &ptmp); mapScrollLeft(draw, SPEED); modexShowPage(draw->page); // mapScrollLeft(show, 1); @@ -157,7 +165,8 @@ void main() { for(q=0; q<(TILEWH/SPEED); q++) { player.x-=SPEED; - modexDrawBmp(draw->page, player.x, player.y, &bmp); +// modexDrawBmp(draw->page, player.x, player.y, &bmp); + animatePlayer(draw, 3, 0, player.x, player.y, q, &ptmp); modexShowPage(draw->page); } player.tx--; @@ -166,11 +175,13 @@ void main() { if(keyp(80)) { + modexDrawSpriteRegion(draw->page, player.x-4, player.y-TILEWH, 24, 64, 24, 32, &ptmp); if(draw->ty >= 0 && draw->ty+15 < MAPY && player.ty == draw->ty + 8) { for(q=0; q<(TILEWH/SPEED); q++) { - modexDrawBmp(draw->page, player.x, player.y+((q+1)*SPEED), &bmp); +// modexDrawBmp(draw->page, player.x, player.y+((q+1)*SPEED), &bmp); + animatePlayer(draw, 2, 1, player.x, player.y, q, &ptmp); mapScrollDown(draw, SPEED); modexShowPage(draw->page); // mapScrollDown(show, 1); @@ -183,7 +194,8 @@ void main() { for(q=0; q<(TILEWH/SPEED); q++) { player.y+=SPEED; - modexDrawBmp(draw->page, player.x, player.y, &bmp); +// modexDrawBmp(draw->page, player.x, player.y, &bmp); + animatePlayer(draw, 2, 0, player.x, player.y, q, &ptmp); modexShowPage(draw->page); } player.ty++; @@ -196,7 +208,8 @@ void main() { { for(q=0; q<(TILEWH/SPEED); q++) { - modexDrawBmp(draw->page, player.x, player.y-((q+1)*SPEED), &bmp); +// modexDrawBmp(draw->page, player.x, player.y-((q+1)*SPEED), &bmp); + animatePlayer(draw, 0, 1, player.x, player.y, q, &ptmp); mapScrollUp(draw, SPEED); modexShowPage(draw->page); // mapScrollUp(show, 1); @@ -209,13 +222,14 @@ void main() { for(q=0; q<(TILEWH/SPEED); q++) { player.y-=SPEED; - modexDrawBmp(draw->page, player.x, player.y, &bmp); +// modexDrawBmp(draw->page, player.x, player.y, &bmp); + animatePlayer(draw, 0, 0, player.x, player.y, q, &ptmp); modexShowPage(draw->page); } player.ty--; } } - modexDrawBmp(draw->page, player.x, player.y, &bmp); +// modexDrawBmp(draw->page, player.x, player.y, &bmp); //modexShowPage(draw->page); } @@ -448,3 +462,43 @@ mapDrawCol(map_view_t *mv, int tx, int ty, word x) { i += mv->map->width; } } + +void animatePlayer(map_view_t *mv, short d1, short d2, int x, int y, int ls, bitmap_t *bmp) +{ + int qq; + + if(d2==0) qq = 0; + else qq = ((ls+1)*SPEED); + switch (d1) + { + case 0: + //up + if(ls<2) modexDrawSpriteRegion(mv->page, x-4, y-qq-TILEWH, 24, 0, 24, 32, bmp); + if(4>ls && ls>=2) modexDrawSpriteRegion(mv->page, x-4, y-qq-TILEWH, 0, 0, 24, 32, bmp); + if(6>ls && ls>=4) modexDrawSpriteRegion(mv->page, x-4, y-qq-TILEWH, 48, 0, 24, 32, bmp); + if(ls>6) modexDrawSpriteRegion(mv->page, x-4, y-qq-TILEWH, 24, 0, 24, 32, bmp); + break; + case 1: + // right + //right + if(ls<2) modexDrawSpriteRegion(mv->page, x+qq-4, y-TILEWH, 24, 32, 24, 32, bmp); + if(4>ls && ls>=2) modexDrawSpriteRegion(mv->page, x+qq-4, y-TILEWH, 0, 32, 24, 32, bmp); + if(6>ls && ls>=4) modexDrawSpriteRegion(mv->page, x+qq-4, y-TILEWH, 48, 32, 24, 32, bmp); + if(ls>6) modexDrawSpriteRegion(mv->page, x+qq-4, y-TILEWH, 24, 32, 24, 32, bmp); + break; + case 2: + //down + if(ls<2) modexDrawSpriteRegion(mv->page, x-4, y+qq-TILEWH, 24, 64, 24, 32, bmp); + if(4>ls && ls>=2) modexDrawSpriteRegion(mv->page, x-4, y+qq-TILEWH, 0, 64, 24, 32, bmp); + if(6>ls && ls>=4) modexDrawSpriteRegion(mv->page, x-4, y+qq-TILEWH, 48, 64, 24, 32, bmp); + if(ls>6) modexDrawSpriteRegion(mv->page, x-4, y+qq-TILEWH, 24, 64, 24, 32, bmp); + break; + case 3: + //left + if(ls<2) modexDrawSpriteRegion(mv->page, x-qq-4, y-TILEWH, 24, 96, 24, 32, bmp); + if(4>ls && ls>=2) modexDrawSpriteRegion(mv->page, x-qq-4, y-TILEWH, 0, 96, 24, 32, bmp); + if(6>ls && ls>=4) modexDrawSpriteRegion(mv->page, x-qq-4, y-TILEWH, 48, 96, 24, 32, bmp); + if(ls>6) modexDrawSpriteRegion(mv->page, x-qq-4, y-TILEWH, 24, 96, 24, 32, bmp); + break; + } +} diff --git a/16/modex16/scroll.exe b/16/modex16/scroll.exe index 9539ab01f1dc0a4a92009e7d24f38bff4019bdfc..b3114f26aa540c4ab3345cdc5c5f1fe86b12d911 100755 GIT binary patch delta 2829 zcmai$dvFuS9mn@^I!iLP<(DkW4-|v3TZ3&m#eg4*0Y%i|5rKo_#Dn9cbu!b;WTw=z z8^*FIil(^=(_}U=4IN4uF~c7vOoE_2J1up97)WU=j4_U(8A^ffS%xt~(-POwb?+qn zC`v2M?%i+q_xtTiBxAVRMPnTVj0&4StyN20J(Q1AKyUOEmtGstLQSP6q*qu>=;jqhGi$422@~61XnFp*=F^JA(1WGLa!d|y={%KHNj7r|;|;AU#b?q# zB2Li&=xBOVLv%N4h5LeIT4;>?>jpJu2#yEj5H{xqSiiDig~2`uL_MIl(*-*cwSfL5 zos8i;bTXZMiQ5p3kXEh?4W*H{xkj`jjY!-YRGCJWX`JY0D)DF<(e6}oMbm;JJXyip z(QN~9^S0CA~MjXY(jgeX6*I7nRAwcs8;s-F|dX;#oLL3_*dJe`Ppd5Ip zNoCHT!~EaLrEO4p87d;rOQ{^KEn57j%7dEt%<%#|h(Y(V0N(v5bi4r6$8>H}0=i9e znP+^Zy%DJoJVM(#N8yrLg*|{~e+_Qj2u3S$@oD4wE3~2#&^=GP8DBGdKIh;7x;wh% zPw^mdGC>EAkl!1wp^^09{?rQyy_ZE^&G;Brk!6`VFo)D<9%2r6GwacpCbG&{$BZ3D z7po_YkClC54wR$a$rUK@Eq19yftBo1g{*hPGv+`IySE`x2DI5gvBBAYgw$o3(nd|Y zKmF|;U4wH=KLC5i`jfKB_p%o0+YC*|H~jH2r+9?y&8ml;!R%UuF*lJZ<5 zyg}CG=0PiI%iRVC$?4qQq%A4l?g(ht`t4e}i@cmynYJTEI2+#AAe^S1vT#ZmrJKmn zyhHGP(vZL2G_JD_?0lNHgvW(*)SVCwi3jSa#YrdmkmJ(R70{(%lDrkcT$bo_!7$6@NII4c`fS#{o)Tl4qo+?w;Y`TxmU#jcoXKR$Ce z>$kD?B^#=J7?0G5Xzw$%v+>dP<2A7pKFujy5k5b=&Io`&KB#;Ky|^mKuP|%S;U|Ix zH59|2lEk{_V1BTzt`)*_!NJvcA-qLStX*h4I?O&5)#YI?Mj=E`gu?ged%^Lwdoa`o tUtecMoG-_h6FgeK2QD7BkK37!mhD+e?X6Ji6Aq=`_&BRGe!Lcd{{YZWfH?pF delta 2026 zcmZvde^69K0LORt-7gUC4g`V2I}V5wMZv>Beh7iWGgRo3B+x*uY$h#B{4tBCjpA=oUi?Ko<>w5d@EBEdX^90DR5bawh@M$xe}-$uR&_ zvGaug@n&|6-VK0|2k66zl`k%?dU*-HV!xg$KtO-ib{T+>3feZ@q!C;jf0GtTCFU>N zge2Dbfa)S0{0MbvXqB>ULm!P&wefwJzuMM(+0I`yntwO@+W5;fN$%jOJQO&4I0t`C zt^&?puA_(BD?5GB>E$|lId=82uB&vNN_y@IZELr6iBJxxo7L(o9Hp|>?#42C6evgq zO~p*w*l78R9?qI&zUMIbI6QP}!0txeBroSEMQs%i=wL_}0{8)4DK$`?inoub8hiXR z2hT%)hP|+dOKnOGdhH4?ha69wogtEgDg%xSB72Ik5YXHwB+X@VTL8r-q5MBdhnJh` z#qLp<+EJJp0hspS(5L(}f+Vncj3j+Li77y`e2hfRNGyPUt7+}F)h~3EDp)AITmuRW zpsA2a7Hqzvm$PP?@8R30F4;YZW6?bIW@l8vObP-Rs^GXiL5yC`AO&Jq_*fX@ZC|RS zK+Y=00_o)h+w*`FO-xOQu&+EU!`Ew<*DbAC=CKG` zKo4uHD}yUXg>Pg25w04!KR{6g<{xb8YwyPQ*=pIv4%{dCBvTlmA2XA*;_#9E5D1}w z`n0$N2`WI3Ye~9Hk9KQGxoj0Oh-9BE10B?mE3zu|hK3Z#=b|JH`A}{_UNt!_uR`yu zNt&V#UE_#DQG$Ho0O9S<>iU`3BfJ~E>6agGgj8AUZJInz;s>Xt6^(0#fI|s1O1uQTQ+VtL($@y(O&qhJG$K9@3GrO1~|P z8MwL{4?c#6=r?y*4KQ@WI87-ouW366Hw$z3FSB?^1k(Jv6S1 z1O9G72fDZ-`Uf#*G{M(gof&!Dgw!i6lVWKt7|5N>9C((@m{kaOx!#(UrLY~zuF2n% z(~z?#rzU^=uO&~??tj`#a>w^e>U{1{-j>`k|CXojxSadMA8aql9o_aKE%*$+aCAP~ zDKRnTy@YOMxi;kK$iC;AoRMjOaFxM21%KpFzNdqwiO2E zhW#gCFa62uzePJ-OXs(9Fw!-+z>H-2SbeO^P~Hxo*;u@>nC-pB&?u>#m?4#=^Q7{; KRF8@&0^o1N_9q?y -- 2.39.5