- [+] replace isice() with tt->ice
- [+] extra properties on existing tiles - [+] sticky tiles should make it hard to accelerate when not moving - [+] Tile which stops net! (metal, honey, ice)
This commit is contained in:
parent
49bdea060d
commit
1ab55faf16
|
@ -160,12 +160,15 @@ end
|
||||||
tile honey
|
tile honey
|
||||||
id 1
|
id 1
|
||||||
solid 1
|
solid 1
|
||||||
|
stopnet 1
|
||||||
file newtiles/honey.png
|
file newtiles/honey.png
|
||||||
end
|
end
|
||||||
|
|
||||||
tile honeytop
|
tile honeytop
|
||||||
id 4
|
id 4
|
||||||
solid 1
|
solid 1
|
||||||
|
sticky 1
|
||||||
|
stopnet 1
|
||||||
file newtiles/honeytop.png
|
file newtiles/honeytop.png
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -210,12 +213,16 @@ end
|
||||||
tile icetop
|
tile icetop
|
||||||
id 20
|
id 20
|
||||||
solid 1
|
solid 1
|
||||||
|
slippery 1
|
||||||
|
stopnet 1
|
||||||
file newtiles/icetop.png
|
file newtiles/icetop.png
|
||||||
end
|
end
|
||||||
|
|
||||||
tile ice
|
tile ice
|
||||||
id 21
|
id 21
|
||||||
solid 1
|
solid 1
|
||||||
|
slippery 1
|
||||||
|
stopnet 1
|
||||||
file newtiles/ice.png
|
file newtiles/ice.png
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -356,6 +363,7 @@ end
|
||||||
tile land
|
tile land
|
||||||
id 4
|
id 4
|
||||||
solid 1
|
solid 1
|
||||||
|
stopnet 1
|
||||||
file newtiles/metal.png
|
file newtiles/metal.png
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -492,6 +500,7 @@ end
|
||||||
tile castle
|
tile castle
|
||||||
id 4
|
id 4
|
||||||
solid 1
|
solid 1
|
||||||
|
stopnet 1
|
||||||
file newtiles/castle.png
|
file newtiles/castle.png
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -577,6 +586,7 @@ end
|
||||||
tile icebridge
|
tile icebridge
|
||||||
id 26
|
id 26
|
||||||
solid 2
|
solid 2
|
||||||
|
slippery 1
|
||||||
file newtiles/icebridge.png
|
file newtiles/icebridge.png
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
5
defs.h
5
defs.h
|
@ -239,6 +239,8 @@ enum ENDGAMETYPE {
|
||||||
#define ICEACCEL 0.1
|
#define ICEACCEL 0.1
|
||||||
#define ICEDECCEL 0.03
|
#define ICEDECCEL 0.03
|
||||||
|
|
||||||
|
#define STICKYACCEL 0.02
|
||||||
|
|
||||||
// blackcloud
|
// blackcloud
|
||||||
#define CLOUDGROWSPEED 25 // lower is faster
|
#define CLOUDGROWSPEED 25 // lower is faster
|
||||||
#define CLOUDGROWAMT 0.01 // lower is faster
|
#define CLOUDGROWAMT 0.01 // lower is faster
|
||||||
|
@ -909,6 +911,9 @@ typedef struct tiletype_s {
|
||||||
int solid;
|
int solid;
|
||||||
int water;
|
int water;
|
||||||
int spikes;
|
int spikes;
|
||||||
|
int sticky;
|
||||||
|
int stopnet;
|
||||||
|
int slippery;
|
||||||
SDL_Surface *img[MAXTILEFRAMES];
|
SDL_Surface *img[MAXTILEFRAMES];
|
||||||
int numframes;
|
int numframes;
|
||||||
int animspeed;
|
int animspeed;
|
||||||
|
|
67
rc.c
67
rc.c
|
@ -1894,7 +1894,7 @@ void jump(sprite_t *s, int dir) {
|
||||||
s->jumpdir++;
|
s->jumpdir++;
|
||||||
} else if ((tt->id == T_LEFT) && (s->jumpdir < 0)) {
|
} else if ((tt->id == T_LEFT) && (s->jumpdir < 0)) {
|
||||||
s->jumpdir--;
|
s->jumpdir--;
|
||||||
} else if (isice(tt->id) && !isinwater(s)) {
|
} else if (tt->slippery && !isinwater(s)) {
|
||||||
s->jumpdir = s->xs / getspeed(s);
|
s->jumpdir = s->xs / getspeed(s);
|
||||||
//if (s->jumpdir > getspeed(s)) s->jumpdir -= getspeed(s);
|
//if (s->jumpdir > getspeed(s)) s->jumpdir -= getspeed(s);
|
||||||
//if (s->jumpdir < -getspeed(s)) s->jumpdir += getspeed(s);
|
//if (s->jumpdir < -getspeed(s)) s->jumpdir += getspeed(s);
|
||||||
|
@ -2068,12 +2068,6 @@ void die(sprite_t *s) {
|
||||||
if (s2->caughtby == s) {
|
if (s2->caughtby == s) {
|
||||||
uncatch(s2);
|
uncatch(s2);
|
||||||
s2->angry = B_TRUE;
|
s2->angry = B_TRUE;
|
||||||
if (s2->id == P_SPIDER) {
|
|
||||||
// climb up!
|
|
||||||
s2->flies = B_TRUE;
|
|
||||||
s2->falling = B_FALSE;
|
|
||||||
s2->ys = -getspeed(s2);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6850,7 +6844,7 @@ void dotileeffects(sprite_t *s) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finished = B_TRUE;
|
finished = B_TRUE;
|
||||||
} else if (isice(tt->id)) {
|
} else if (tt->slippery) {
|
||||||
if (isplayer(s) && !isinwater(s)) {
|
if (isplayer(s) && !isinwater(s)) {
|
||||||
if (globpowerup != PW_CLOCK) {
|
if (globpowerup != PW_CLOCK) {
|
||||||
if (!s->moved) {
|
if (!s->moved) {
|
||||||
|
@ -8177,8 +8171,6 @@ void drawnetting(sprite_t *s) {
|
||||||
netsleft = s->netmax - s->netcaught;
|
netsleft = s->netmax - s->netcaught;
|
||||||
if (netsleft < 1) netsleft = 1;
|
if (netsleft < 1) netsleft = 1;
|
||||||
dis = (int)s->img->h / (int)(netsleft+1) + 1;
|
dis = (int)s->img->h / (int)(netsleft+1) + 1;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
for (y = dis; y < s->img->h; y += dis) {
|
for (y = dis; y < s->img->h; y += dis) {
|
||||||
SDL_Rect endarea;
|
SDL_Rect endarea;
|
||||||
|
@ -8970,7 +8962,33 @@ void dogravity(sprite_t *s) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// extend/withdraw player net
|
||||||
if (s->netting) {
|
if (s->netting) {
|
||||||
|
tiletype_t *tt;
|
||||||
|
double xx,yy;
|
||||||
|
double disfromtop,incamt;
|
||||||
|
int stop = B_FALSE;
|
||||||
|
|
||||||
|
// check for net hitting bad tile.
|
||||||
|
xx = s->x + (s->netlen * s->netdir);
|
||||||
|
//incamt = (int)s->img->h / (int)(netsleft+1) + 1;
|
||||||
|
incamt = (int)s->img->h / (int)(s->netmax+1) + 1;
|
||||||
|
for (disfromtop = incamt; disfromtop < s->img->h; disfromtop += incamt) {
|
||||||
|
yy = s->y - s->img->h + disfromtop;
|
||||||
|
tt = gettileat(xx,yy,NULL,NULL);
|
||||||
|
if (tt->stopnet) {
|
||||||
|
stop = B_TRUE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (stop) {
|
||||||
|
// net immediately starts returning.
|
||||||
|
s->netspeed = -NETSPEED;
|
||||||
|
adjustx(s, F_WALK1);
|
||||||
|
}
|
||||||
|
|
||||||
|
// net is still going
|
||||||
if (s->powerup == PW_ACCORDION) {
|
if (s->powerup == PW_ACCORDION) {
|
||||||
if (s->netspeed > 0) {
|
if (s->netspeed > 0) {
|
||||||
s->netlen += s->netspeed;
|
s->netlen += s->netspeed;
|
||||||
|
@ -9383,9 +9401,14 @@ int movex(sprite_t *s,double amt,int onpurpose) {
|
||||||
tt = gettileat(s->x, s->y, &tilex,&tiley);
|
tt = gettileat(s->x, s->y, &tilex,&tiley);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (amt > 0) amtdir = 1;
|
if (amt > 0) amtdir = 1;
|
||||||
else (amtdir = -1);
|
else (amtdir = -1);
|
||||||
|
|
||||||
|
// walking on sticky tiles?
|
||||||
|
if (tt->sticky && onpurpose && !s->falling) {
|
||||||
|
amt /= 2;
|
||||||
|
}
|
||||||
|
|
||||||
curx = s->x;
|
curx = s->x;
|
||||||
cury = s->y;
|
cury = s->y;
|
||||||
|
@ -9424,11 +9447,12 @@ int movex(sprite_t *s,double amt,int onpurpose) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get new position */
|
/* get new position */
|
||||||
if (isplayer(s) && isice(tt->id) && !isinwater(s) && onpurpose ) {
|
if (isplayer(s) && tt->slippery && !isinwater(s) && onpurpose ) {
|
||||||
double newxs;
|
double newxs;
|
||||||
|
double accel = ICEACCEL;
|
||||||
// change speed
|
// change speed
|
||||||
newxs = s->xs + (s->dir*ICEACCEL);
|
newxs = s->xs + (s->dir*accel);
|
||||||
s->xs += (s->dir*ICEACCEL);
|
s->xs += (s->dir*accel);
|
||||||
// don't get too fast!
|
// don't get too fast!
|
||||||
if (newxs > getspeed(s)) newxs = getspeed(s);
|
if (newxs > getspeed(s)) newxs = getspeed(s);
|
||||||
if (newxs < -getspeed(s)) newxs = -getspeed(s);
|
if (newxs < -getspeed(s)) newxs = -getspeed(s);
|
||||||
|
@ -9460,9 +9484,10 @@ int movex(sprite_t *s,double amt,int onpurpose) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (domove) {
|
if (domove) {
|
||||||
if (isplayer(s) && isice(tt->id) && !isinwater(s) && onpurpose) {
|
if (isplayer(s) && tt->slippery && !isinwater(s) && onpurpose) {
|
||||||
|
double accel = ICEACCEL;
|
||||||
// change speed
|
// change speed
|
||||||
s->xs += (s->dir*ICEACCEL);
|
s->xs += (s->dir*accel);
|
||||||
// don't get too fast!
|
// don't get too fast!
|
||||||
if (s->xs > getspeed(s)) s->xs = getspeed(s);
|
if (s->xs > getspeed(s)) s->xs = getspeed(s);
|
||||||
if (s->xs < -getspeed(s)) s->xs = -getspeed(s);
|
if (s->xs < -getspeed(s)) s->xs = -getspeed(s);
|
||||||
|
@ -9473,7 +9498,7 @@ int movex(sprite_t *s,double amt,int onpurpose) {
|
||||||
s->x += amt;
|
s->x += amt;
|
||||||
s->xs = amt;
|
s->xs = amt;
|
||||||
if (!onpurpose) {
|
if (!onpurpose) {
|
||||||
if (isice(tt->id) && !isinwater(s)) {
|
if (tt->slippery && !isinwater(s)) {
|
||||||
s->moved = MV_ICE;
|
s->moved = MV_ICE;
|
||||||
} else if (!isconveyor(tt->id)) {
|
} else if (!isconveyor(tt->id)) {
|
||||||
s->moved = MV_WALK;
|
s->moved = MV_WALK;
|
||||||
|
@ -13389,6 +13414,13 @@ void uncatch(sprite_t *s) {
|
||||||
}
|
}
|
||||||
s->caughtby = NULL;
|
s->caughtby = NULL;
|
||||||
s->caughtstate = B_FALSE;
|
s->caughtstate = B_FALSE;
|
||||||
|
|
||||||
|
if (s->id == P_SPIDER) {
|
||||||
|
// climb up!
|
||||||
|
s->flies = B_TRUE;
|
||||||
|
s->falling = B_FALSE;
|
||||||
|
s->ys = -getspeed(s);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void makeinvuln(sprite_t *s) {
|
void makeinvuln(sprite_t *s) {
|
||||||
|
@ -15060,6 +15092,7 @@ int isbridge(int id) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
int isice(int id) {
|
int isice(int id) {
|
||||||
switch (id) {
|
switch (id) {
|
||||||
case T_ICE:
|
case T_ICE:
|
||||||
|
@ -15069,6 +15102,8 @@ int isice(int id) {
|
||||||
}
|
}
|
||||||
return B_FALSE;
|
return B_FALSE;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
int isconveyor(int id) {
|
int isconveyor(int id) {
|
||||||
switch (id) {
|
switch (id) {
|
||||||
|
|
2
rc.h
2
rc.h
|
@ -146,7 +146,7 @@ int getpnum(sprite_t *s);
|
||||||
sprite_t *getrandomaliveplayer(void);
|
sprite_t *getrandomaliveplayer(void);
|
||||||
int isonplatform(double x, double y);
|
int isonplatform(double x, double y);
|
||||||
int countbabies(sprite_t *s, int babytype);
|
int countbabies(sprite_t *s, int babytype);
|
||||||
int isice(int id);
|
//int isice(int id);
|
||||||
int isconveyor(int id);
|
int isconveyor(int id);
|
||||||
int isbridge(int id);
|
int isbridge(int id);
|
||||||
int savebmp(SDL_Surface *which);
|
int savebmp(SDL_Surface *which);
|
||||||
|
|
15
shared.c
15
shared.c
|
@ -1181,6 +1181,9 @@ int loadtiletypes(char *filename) {
|
||||||
t->animsync = B_FALSE;
|
t->animsync = B_FALSE;
|
||||||
t->water = B_FALSE;
|
t->water = B_FALSE;
|
||||||
t->spikes = B_FALSE;
|
t->spikes = B_FALSE;
|
||||||
|
t->sticky = B_FALSE;
|
||||||
|
t->slippery = B_FALSE;
|
||||||
|
t->stopnet = B_FALSE;
|
||||||
t->solid = B_TRUE;
|
t->solid = B_TRUE;
|
||||||
for (i = 0; i < TILEW; i++) {
|
for (i = 0; i < TILEW; i++) {
|
||||||
t->lowness[i] = 0;
|
t->lowness[i] = 0;
|
||||||
|
@ -1230,6 +1233,18 @@ int loadtiletypes(char *filename) {
|
||||||
p = strtok(buf, " ");
|
p = strtok(buf, " ");
|
||||||
p = strtok(NULL, " ");
|
p = strtok(NULL, " ");
|
||||||
t->solid = atoi(p);
|
t->solid = atoi(p);
|
||||||
|
} else if (strstr(buf, "sticky") == buf) {
|
||||||
|
p = strtok(buf, " ");
|
||||||
|
p = strtok(NULL, " ");
|
||||||
|
t->sticky = atoi(p);
|
||||||
|
} else if (strstr(buf, "stopnet") == buf) {
|
||||||
|
p = strtok(buf, " ");
|
||||||
|
p = strtok(NULL, " ");
|
||||||
|
t->stopnet = atoi(p);
|
||||||
|
} else if (strstr(buf, "slippery") == buf) {
|
||||||
|
p = strtok(buf, " ");
|
||||||
|
p = strtok(NULL, " ");
|
||||||
|
t->slippery = atoi(p);
|
||||||
} else if (strstr(buf, "spikes") == buf) {
|
} else if (strstr(buf, "spikes") == buf) {
|
||||||
p = strtok(buf, " ");
|
p = strtok(buf, " ");
|
||||||
p = strtok(NULL, " ");
|
p = strtok(NULL, " ");
|
||||||
|
|
Loading…
Reference in New Issue