From a1ee548188b86097b90bc7a5633f810e279605ef Mon Sep 17 00:00:00 2001 From: Rob Pearce Date: Mon, 22 Dec 2008 03:03:48 +0000 Subject: [PATCH] Added new monster: frog --- data/levels/level102.dat | 10 +-- data/levels/level104.dat | 8 +-- data/levels/level115.dat | 4 +- data/levels/level41.dat | 3 +- data/levels/level418.dat | 7 +- data/levels/level99.dat | 23 ++++--- data/sprites/frog.png | Bin 0 -> 1272 bytes data/sprites/frogcaught.png | Bin 0 -> 1286 bytes data/sprites/frogdead.png | Bin 0 -> 1282 bytes data/sprites/frogfall.png | Bin 0 -> 1526 bytes data/sprites/frogjump.png | Bin 0 -> 1521 bytes defs.h | 11 +++- rc.c | 123 +++++++++++++++++++++++++++++++++--- shared.c | 21 +++++- website/img/frog.png | Bin 0 -> 1865 bytes website/info.html | 1 + 16 files changed, 173 insertions(+), 38 deletions(-) create mode 100644 data/sprites/frog.png create mode 100644 data/sprites/frogcaught.png create mode 100644 data/sprites/frogdead.png create mode 100644 data/sprites/frogfall.png create mode 100644 data/sprites/frogjump.png create mode 100644 website/img/frog.png diff --git a/data/levels/level102.dat b/data/levels/level102.dat index 0c68c2f..3154a6b 100644 --- a/data/levels/level102.dat +++ b/data/levels/level102.dat @@ -33,17 +33,17 @@ monsters 17 4 28 15 34 28 15 23 28 -6 6 27 49 13 21 49 32 8 49 11 11 49 33 17 -60 28 13 60 31 24 -60 11 16 60 7 8 -6 35 0 -6 17 3 +60 28 13 +60 11 16 +157 6 27 +157 17 6 +157 35 8 endmonsters exitdir 2 44,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44, diff --git a/data/levels/level104.dat b/data/levels/level104.dat index 7b2070e..08e74e2 100644 --- a/data/levels/level104.dat +++ b/data/levels/level104.dat @@ -46,12 +46,12 @@ monsters 15 16 5 15 14 5 6 5 11 -18 31 14 -18 26 5 -18 9 23 49 28 23 +157 9 23 +157 24 14 +157 31 5 124 24 5 -124 15 5 +124 17 5 endmonsters exitdir 1 44,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44, diff --git a/data/levels/level115.dat b/data/levels/level115.dat index 8c81be9..7644159 100644 --- a/data/levels/level115.dat +++ b/data/levels/level115.dat @@ -10,8 +10,6 @@ monsters 12 34 14 12 4 14 60 22 13 -124 15 19 -124 24 19 49 32 5 49 7 5 1 32 22 @@ -42,6 +40,8 @@ monsters 17 4 2 17 5 25 17 34 25 +157 24 19 +157 15 16 endmonsters exitdir 1 44,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,44, diff --git a/data/levels/level41.dat b/data/levels/level41.dat index 28200d5..15d5e44 100644 --- a/data/levels/level41.dat +++ b/data/levels/level41.dat @@ -28,10 +28,11 @@ monsters 15 33 19 15 24 8 15 23 8 -132 19 6 312 112 312 442 +132 19 6 312 112 312 112 312 442 15 18 5 15 20 5 16 19 5 +157 35 6 endmonsters exitdir 1 61,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,61, diff --git a/data/levels/level418.dat b/data/levels/level418.dat index ef305d7..befc25f 100644 --- a/data/levels/level418.dat +++ b/data/levels/level418.dat @@ -7,14 +7,11 @@ monsters 0 6 28 134 33 28 23 20 4 -12 31 20 12 21 16 12 24 8 -12 6 12 12 12 24 6 28 2 6 9 3 -49 21 28 16 14 20 16 16 20 16 18 20 @@ -52,6 +49,10 @@ monsters 16 31 4 16 30 4 16 29 4 +157 22 28 +157 17 28 +12 31 20 +12 6 12 endmonsters exitdir 1 61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61,61, diff --git a/data/levels/level99.dat b/data/levels/level99.dat index 312eab6..738c6c9 100644 --- a/data/levels/level99.dat +++ b/data/levels/level99.dat @@ -4,12 +4,11 @@ hurryup 30 help endhelp monsters -0 5 23 -134 35 22 -23 12 19 +0 35 19 +134 36 19 +23 38 19 6 20 10 -133 18 19 -133 26 19 +157 3 18 endmonsters exitdir 1 4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, @@ -31,13 +30,13 @@ exitdir 1 4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, 4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, 4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, -4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, -4,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,4, -4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, -4,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, -4,0,0,0,0,0,0,0,17,0,0,0,0,0,17,0,0,0,0,0,17,0,0,0,0,0,17,0,0,0,0,17,0,0,0,0,0,0,0,4, -4,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,4, -4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,4,1,1,1,1,1,4, +4,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,4, +4,0,0,0,0,0,0,0,0,1,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,1,1,1,1,1,1,4, +4,0,0,0,0,0,0,0,0,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4, +4,0,0,0,0,0,0,0,0,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4, +4,0,0,0,0,0,0,0,0,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4, +4,0,0,0,1,1,1,1,1,1,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4, +4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,1,1,1,1,1,1,4, 4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,4,0,0,0,0,0,4, 4,0,0,0,0,0,0,0,0,4,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,4,0,0,0,0,0,4, 4,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, diff --git a/data/sprites/frog.png b/data/sprites/frog.png new file mode 100644 index 0000000000000000000000000000000000000000..160d62387dea3c82d3be95edd47fa38e2bd452af GIT binary patch literal 1272 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 literal 0 HcmV?d00001 diff --git a/data/sprites/frogfall.png b/data/sprites/frogfall.png new file mode 100644 index 0000000000000000000000000000000000000000..dcf9ad6ba36c3dcce396e0ec5229e93bebedeb8b GIT binary patch literal 1526 zcmVTyfaG(GH03CEi zSad^gZEa<4bO1wgWnpw>WFU8GbZ8({Xk{QrNlj4iWF>9@00mk}L_t(Y$F-DcY?B2T z$N%ryx7XWt>$Y}RcQHVY$qI6)IBpzrB^r;Pd%heqNiml{9PhIfTmoJj|3A zT;qIU=l>>=zheqJWlYiVYFAzRn5D};Z8CUVuap|5r@zUpu%Py;8 zk-=b?C>u1pc!Dr?sl6X~n*2y9$cTtaFp>zxt-MhKgHaDfkq}OZ@OwRAIaf!{(jP+ z;}I|nO7hL9Xa%FAGBhw4bkHz53`PR*2m=VlLNIeiM52P2X~|-XEaQKgX`AM*4>TUz zH0kBNcO1v`lH4;1o)J`rH1QGXik*b9je{gBvYlZ#f{}=*Y$g~5Ajz0|R*>X8DUpE2 zz=G45pkZk!kU_BwQcP(mu;x*n!460qU2wryTWF)x7Wif}>)iWYAKgxZ+`Q#90g9BE zPy(?*(NC#JQ%uBe$)KKy2|`Swk!Z2P*gktNu(Zf(FhE- zbzuv|;)k>-Uv;r^Ve94Ui;WjLuix=w4)M*_Qg+qm3UMf(v1>kcYHhg;0P{CIlAY@E zFYu_uHZqa$#&UFyc)I{=vIWLzDTofsMOKVOP|-l;Gthnd40=-p_yQexSWdfi@U5!i zf9%9xIegkB-6;o|bn2sUGa{lf z4@zPtB-<>5X^}`w6MT2bUx+bpdfu?lG$;S5lT979?W!0ptfza;ZAr4O^T%^ba;v)!m%I9_ z?^^-@TK$noik?B{3pYwZc2Z#z?SvhHe-Qp=aEcx`*>yh$#hufMiGRg`4N zix^)hY;N?WzrHYc@)BoyIUXdl-XHU)@s<=?n4$Q&_omSRFr}hoF#xPh*RI?%&vAVJ cvm*+B2hyBnrEbvLUjP6A07*qoM6N<$g3wpcwEzGB literal 0 HcmV?d00001 diff --git a/data/sprites/frogjump.png b/data/sprites/frogjump.png new file mode 100644 index 0000000000000000000000000000000000000000..28c42c9c89f6498d8f097b2f07e0de7030d10f3d GIT binary patch literal 1521 zcmVWFU8GbZ8({Xk{QrNlj4iWF>9@00mV^L_t(Y$F-JiY!d|- z$NzV|yWU;ft?k;qWLsMpn;UZ*5SSYqu&Jn^I3xr=X^e^l6Qh#&$q$P$8qtIVgC>*k zfoPPsfMx_FgqMv8Y*S$l+}P}JUH8(iy}n(qy_eqk!32YfNCMC2C;9*Ke_l;^!14OI zcWNWenIlxQ`P0_zjfupP++geWM)(g;+{z*Dx9GYvn}}!ZYaUr(sat6fcxp6HJ%tWEu=Kxs>XeDe5IctGd!rq$` zM}`ix^$P=E3`RyO!>I@|iUd`bLGmOBih{S$i#m4=c*=x{q3iJP8Gv)!LrC%YnAETWxo~uPWc8-fn*Rs!Yv2mm8yVbrI&kJq#>UgKoWxuv1|24t04PwQ z5jl9BJ}7b=QZ@zRqJVlo1LI#g!ybQe*M_d;4MSVTGQ4smLD zFL7A-ac?*qePw*akMczx7yu{&;MqKY&=JcB$f-FL4^m(M3^r#* zbFCW_O(F=xjC|1oO_LC?B>@25LsLXcwG*6!2Y@?IN42$zKdtm$(}KC`vgMVC8BtXU z-s7Xo}YZY zuxfuGJdUoJ47z5f|9e?g>|W_=C@Wb$h15wQD55B@7|A>lPTI1I11#llQdzTOMyHW>$(CFy8a!b$jcYr7MKR*hZc|S21X`wit zRE1;+Drpsn*@=AFvO8nXRTOXwKctg$yNj2WjXK5zx2x5AK^>o;EO6WQL~QK4;t&2~ z%$kbf3Q>-8gamU+1rGyb*FuJiBtRMl7CR{POr>ux$GYQNTN0BqeIxLIs0LL;=9A@+u$H0}ZLUSa7YMMdj zryD4CTToQYfs`ane0Kvk!x_AFZsxCYtUJCHt%Lr)bRG?zgm|{x9LZ_gskAQk*k{?r zgl=5UdH6~;po$(LO^{9sx{yW)wp8@yB7K&Ao`H0cs_dl}NE z9IQngru|V=sHhZAocQgSp4E*f>lZW_X*nwdqPmfmAq1ii?C1Cc X<*Rsyiw7OF00000NkvXXu0mjfuE(Jo literal 0 HcmV?d00001 diff --git a/defs.h b/defs.h index e98c26d..22a28d6 100644 --- a/defs.h +++ b/defs.h @@ -193,6 +193,10 @@ #define ICESPEED 2 // how fast a level turns to ice #define MONJUMPSPEED 5 // how high monsters jump +#define FROGJUMPSPEED1 3 // how high frogs jump +#define FROGJUMPSPEED2 6 // how high frogs jump + +#define FROGPAUSE 20 // how long frog waits in between jumps #define BOMBSHAKETIME 100 // time for screen will shake after a bomb #define RATSHAKETIME 50 // shake time when king rat is stunned @@ -301,6 +305,10 @@ #define B_TRUE -1 #define B_FALSE 0 +// reasons for not being able to move +#define NM_SIDE -1 +#define NM_BELOW -2 + // fruit types #define FT_FRUIT 1 #define FT_PERM 2 @@ -408,7 +416,7 @@ #define S_SLOPE 2 // Sprite types -#define MAXPTYPES 157 +#define MAXPTYPES 158 #define P_PLAYER 0 #define P_RAT 1 #define P_CHEESE 2 @@ -571,6 +579,7 @@ #define P_PILL 154 #define P_RAYGUN 155 #define P_RAYGUNBULLET 156 +#define P_FROG 157 #define FLY_FLYTIME 150 diff --git a/rc.c b/rc.c index f92f512..7a76445 100644 --- a/rc.c +++ b/rc.c @@ -1437,6 +1437,22 @@ void jump(sprite_t *s, int dir) { // jump right away s->jumpspeed = MONJUMPSPEED; // will be changed later s->jumping = 1; + } else if (s->id == P_FROG) { + sprite_t *whoabove; + whoabove = isplayerabove(s); + + if (whoabove) { + double ydis; + ydis = abs(s->y - whoabove->y); + if (ydis <= (TILEH*5)) { + s->jumpspeed = MONJUMPSPEED; // normal jump + } else { + s->jumpspeed = FROGJUMPSPEED2; // very high + } + } else { + s->jumpspeed = FROGJUMPSPEED1; // ie not high enough for most platforms + } + s->jumping = 1; } else { // delay then jump s->jumptimer = getjumpdelay(s->id); @@ -2512,7 +2528,22 @@ int movesprite(sprite_t *s) { } } else if (s->jumping) { if (s->id != P_KINGRAT) { - movex(s, s->jumpdir*getspeed(s), B_TRUE); + int rv; + rv = movex(s, s->jumpdir*getspeed(s), B_TRUE); + // frogs bounce off walls + /* + if (s->id == P_FROG) { + if (rv == NM_SIDE) { + if (!isongroundpoint(s,s->x,s->y - (TILEH/2))) { + if (!isroofabove(s)) { + s->dir = -s->dir; + s->jumpdir = -s->jumpdir; + } + } + } + } + */ + } return B_FALSE; } @@ -2657,6 +2688,11 @@ int movesprite(sprite_t *s) { } newsp = addsprite(s->timer3, s->x,s->y,s->name ); + + if (s->timer3 == P_FROG) { + // so all frogs don't jump at once. + newsp->timer3 = (rand() % FROGPAUSE); + } // is it a boss? if so update boss pointer switch (s->timer3) { @@ -3191,6 +3227,74 @@ int movesprite(sprite_t *s) { movex(s, s->jumpdir*getspeed(s), B_TRUE); } } + } else if (s->id == P_FROG) { + if (isinwater(s)) { + // move like a fish + double absxs,absys; + + s->flies = B_TRUE; + s->falling = B_FALSE; + + if ((s->xs == -99) || (s->ys == -99)) { + s->xs = getspeed(s) * s->dir; + s->ys = getspeed(s); + } + + if (s->xs > 0) absxs = 1; + else absxs = -1; + + if (s->ys > 0) absys = 1; + else absys = -1; + + /* can we move? */ + tt = gettileat(s->x + (s->dir * ((s->img->w/2)+3)) + s->xs , s->y-(s->img->h/2),NULL,NULL); + if ((tt->solid) || (tt->spikes )) { + /* turn */ + s->xs = -s->xs; + } + + tt = gettileat(s->x, s->y-(s->img->h/2) + s->ys,NULL,NULL); + if ((tt->solid) || (tt->spikes) ) { + /* turn */ + s->ys = -s->ys; + } else if (!tt->water) { + s->flies = B_FALSE; + // exit water + jump(s, s->dir); + // force big jump + s->jumpspeed = FROGJUMPSPEED2; + + } + /* move */ + s->x += s->xs; + s->y += s->ys; + s->dir = absxs; + s->moved = MV_WALK; + } else { + // for if we get back in the water + s->xs = -99; + s->ys = -99; + s->flies = B_FALSE; + + // timer3 used for pause inbetween jump + if ((!s->falling) && (!s->jumping)) { + if (s->timer3) { + s->timer3--; + } else { + // jump forwards + jump(s, s->dir); + s->timer3 = FROGPAUSE; + } + } else { // falling + int rv; + // move forwards + rv = movex(s, s->dir*getspeed(s), B_TRUE); + if (rv == NM_SIDE) { // bounce off walls + /* if we couldn't move (hit a wall), turn */ + s->dir = -s->dir; + } + } + } } else if (s->id == P_SLUG) { if (!s->falling) { int move = B_FALSE; @@ -3261,10 +3365,8 @@ int movesprite(sprite_t *s) { } else { ydiff = 999; } - if (isplayerabove(s) && (ydiff >= (TILEH*4)) && (ydiff <= (TILEH*8))) { // player between 4 and 8 tiles above - if (xdiff <= (TILEW*8)) { // if closeish horizontally /* jump up */ jump(s, 0); @@ -5686,6 +5788,9 @@ double getspeed(sprite_t *s ) { if (s->jumping) { speed = 8; // very fast jumping } + } else if (id == P_FROG) { + if (s->angry) speed = 1.5; + else speed = 1; } else if (id == P_RAT) { if (s->angry) speed = 1.5; else speed = 1; @@ -5713,7 +5818,7 @@ double getspeed(sprite_t *s ) { speed = PLATFORM_MAXSPEED; } - if (isinwater(s) && (s->id != P_FISH)) { + if (isinwater(s) && (s->id != P_FISH) && (s->id != P_FROG)) { if (!s->hasmask) { speed /= 2; } @@ -7377,11 +7482,11 @@ int movex(sprite_t *s,double amt,int onpurpose) { tt2 = gettileat(newx,newy,&newtilex,&newtiley); if (tt2->solid == S_SOLID) { s->xs = 0; - return B_TRUE; + return NM_SIDE; } if (tt2->solid == S_SLOPE && (!candoslopes(s->id))) { s->xs = 0; - return B_TRUE; + return NM_SIDE; } } @@ -7392,11 +7497,11 @@ int movex(sprite_t *s,double amt,int onpurpose) { tt2 = gettileat(newx,newy,&newtilex,&newtiley); if (tt2->solid == S_SOLID) { //s->xs = 0; - return B_TRUE; + return NM_BELOW; } if (tt2->solid == S_SLOPE && (!candoslopes(s->id))) { //s->xs = 0; - return B_TRUE; + return NM_BELOW; } } @@ -7427,7 +7532,7 @@ int movex(sprite_t *s,double amt,int onpurpose) { domove = B_FALSE; if (tt2->solid == S_SOLID) { // s->xs = 0; - return B_TRUE; + return NM_SIDE; } else if ((tt2->solid == S_SLOPE) && candoslopes(s->id)) { /* we can move, but need to adjust our height */ domove = B_TRUE; diff --git a/shared.c b/shared.c index 7f5b286..cf0f760 100644 --- a/shared.c +++ b/shared.c @@ -762,8 +762,14 @@ void setdefaults(sprite_t *s) { s->timer1 = 0; } s->timer2 = 0; - s->timer3 = 0; + if (s->id == P_FROG) { + // so all frogs don't jump at the same time + s->timer3 = rand() % FROGPAUSE; + } else { + s->timer3 = 0; + } s->timer4 = 0; + s->dbltimer = -1; s->dropping = 0; s->dropx = -1; @@ -1330,6 +1336,14 @@ int loadimagesets(void) { /* next 3 are auto generated */ imageset[P_FLY].numimages = 8; + loadspriteimage(P_FROG,F_WALK1, "sprites/frog.png"); + loadspriteimage(P_FROG,F_JUMP, "sprites/frogjump.png"); + loadspriteimage(P_FROG,F_FALL, "sprites/frogfall.png"); + loadspriteimage(P_FROG,F_CAUGHT, "sprites/frogcaught.png"); + loadspriteimage(P_FROG,F_DEAD, "sprites/frogdead.png"); + /* next 3 are auto generated */ + imageset[P_FROG].numimages = 8; + loadspriteimage(P_SPIDER,F_WALK1, "sprites/newspider.png"); loadspriteimage(P_SPIDER,F_JUMP, "sprites/newspiderjump.png"); loadspriteimage(P_SPIDER,F_FALL, "sprites/newspiderfall.png"); @@ -1929,10 +1943,12 @@ void drawsprite(sprite_t *s) { SDL_Rect area; int frame = 0; +#ifndef __EDITOR if (isplayer(s) && s->lives < 0) { // permenantly dead - don't draw return; } +#endif // don't show caught mosnters in gunner mode if (!isplayer(s) && (s->caughtby) ) { @@ -3025,6 +3041,7 @@ int ismonster(int id) { case P_SNAIL: case P_SLUG: case P_FISH: + case P_FROG: return MT_MONSTER; case P_BLACKCLOUD: case P_KINGRAT: @@ -3519,6 +3536,8 @@ void setfruitinfo(void) { setinfo(P_SPIDER, "Spider", "Spiders will lurk quietly on the ceiling, crawling back and forth. If they notice a player nearby however they will swiftly pounce down onto their prey!", "spider.png"); + setinfo(P_FROG, "Frog", "Green frogs will continually bounce around, making them more difficult to catch.", "frog.png"); + setinfo(P_SNAKE, "Snake", "The snake moves in a similar fashion to the rat with one important exception - upon seeing a player they will spit a glob of deadly venom at them!", "snake.png"); setinfo(P_FLY, "Fly", "Annoying pests at the best of times, flies pose additional danger to dwarves. They fly around more erratically than bees and after landing can scurry quickly back and forth.", "fly.png"); diff --git a/website/img/frog.png b/website/img/frog.png new file mode 100644 index 0000000000000000000000000000000000000000..95ceba3c423b08a23f9edaaa087ece3ba0be48a4 GIT binary patch literal 1865 zcmV-P2e$Z$P)X00006VoOIv0RI60 z0RN!9r;`8x010qNS#tmYE+YT{E+YYWr9XB6000McNliru*bEi|Cop}ZhX()v03CEi zSad^gZEa<4bO1wgWnpw>WFU8GbZ8({Xk{QrNlj4iWF>9@00yl|L_t(o!?l=wj1*@b z$3OGFZ}+zM(ksVtS7^%t<&Iiw3l_Egr%{@wiZ8^N)MyhW{R5I}^)I7FlN!;4i28?$ z31S*zNR6ewK&+;=MGh>b1@2P31FrY7%Pu?nzBjY8JN`369>&?@PTNVI%0N{XL`>*8pyd>y|fouc2C`U?bsRbVY@JF4VNcV~S zZ0c`6+Vj(6g?wQVuz|X8b_7*jz?GH>CxWSha!Pl1QvdkwM~Ca1q+KZ`^Etza_9wJ% zvTlw=vq0|m^Hl%7K+$%HJrpI8eTYz){S6v3&4TbLg&=%uM z-~HlaO1t*t>B5<|Y}FiSD2<+?W<@5`?_f1-jHu4=P@IUZ(JT}(&t@nWYM6@3$Z!|( z07!lDEgYm1s0eoJ3U=t*XG7 z_k8=sa=B9SVDjED1<KD__^saO^g%pXB&lgA}V(8Hru5937 z;i@tns*Zw6WwOGv_dLv*f6rh_C05@)z}9;nMUf1?_1x2Mm&+9m(1oxh#zsQUgaImm z`iWoec=GMi#a+2f9vK(O0=)uet&G#_(v<3GjzV7*?DJ!97?~dyW-B-u2RWfa-67Ma zqEsE+T#+7q7^AAwj72HtQrJ@|3#d2JvV;pOxnADLx_8p z5L)~tZ3Z$8YMAXgt2#e-nH)-mZ0K|K&=F9PucjH!J`**vz=BmMojCZ zFW%2U+Yk>WMi{EOyzuqkGCh&Q%GT&vlxZXl3PuiN{V?%4Yw_ZrFJ@Oo?SxUP((7Dh8MNzn2!!4*&Bv`=76z{PO(OE2yT6G@gQ(N+i}q zS;)h%LH~x;tZ^e~Q#qm$9lOimm41`x;C8lVvy5mumD7`MzEYpnBXZ@XzfQj~e)if_ zrs~WC*S(SVV9O!P?26TlnEch+T;dMl5Oc$CKLKIPeb`8!G}p!@Hs3{YMR`7nZ6-75%!e>Zxai6sWXP zFibru0A~l_>(mZGY~0Q3hq`FH6e;g%h;80 zZ(*CwR<++swmw>ISNtzqB})OXXzSv=n70zpWgY(kE!iUp^*pwF00000NkvXXu0mjf DQWl)G literal 0 HcmV?d00001 diff --git a/website/info.html b/website/info.html index 13049fa..a1b5be9 100644 --- a/website/info.html +++ b/website/info.html @@ -14,6 +14,7 @@
PirahnaThese fish at at home in the water and unhampered by slowness while swimming.
PlantEvil venus fly trap plants will lie in wait and devour any player foolish enough to wander into their clutches.
FlyAnnoying pests at the best of times, flies pose additional danger to dwarves. They fly around more erratically than bees and after landing can scurry quickly back and forth. +
FrogGreen frogs will continually bounce around, making them more difficult to catch. Bosses
Cloud of DoomThis unkillable cloud will appear if you spend too much time on one level. Beware, as the only way to defeat the cloud of doom is to complete the level before it grows too large to handle!
King RatThis mighty creature is the ruler of the rats, and impervious to the player's net. It can only be harmed by slamming another monster into it! King Rat will roam the level searching for a player, and upon spotting them will charge at high speed.