- More tweaks to ladder behaviour wrt getting on/off
- Appended 'fps' to score/fps display when pressing f2
This commit is contained in:
parent
6d42aa287a
commit
c5890190ea
58
rc.c
58
rc.c
|
@ -1725,24 +1725,29 @@ if (s->id == P_PUFF) printf("PUFF WITH DOOMCOUNT!\n");
|
||||||
bouncesprite(s);
|
bouncesprite(s);
|
||||||
|
|
||||||
if ((s->ys >= 0) && (s->y >= TILEH)) {
|
if ((s->ys >= 0) && (s->y >= TILEH)) {
|
||||||
if (s->quickdie || isonground(s)) {
|
int x,y,ty;
|
||||||
int x,y,ty;
|
// get position for puff/fruit
|
||||||
s->dead = D_FINAL;
|
x = s->x;
|
||||||
/* change into a fruit */
|
gettileat(s->x,s->y-1,NULL,&ty);
|
||||||
x = s->x;
|
//y = ty*TILEH + TILEH - 2;
|
||||||
gettileat(s->x,s->y-1,NULL,&ty);
|
y = ty*TILEH - 2;
|
||||||
//y = ty*TILEH + TILEH - 2;
|
|
||||||
y = ty*TILEH - 2;
|
|
||||||
|
|
||||||
/* make sure it's within the screen */
|
/* make sure it's within the screen */
|
||||||
if (x > (640-TILEW)) x = 640-TILEW;
|
if (x > (640-TILEW)) x = 640-TILEW;
|
||||||
if (x < (TILEW)) x = TILEW;
|
if (x < (TILEW)) x = TILEW;
|
||||||
|
|
||||||
|
if (s->quickdie || (isonground(s) && !isongroundpoint(s, s->x, s->y-TILEH))) {
|
||||||
|
/* change into a fruit */
|
||||||
|
s->dead = D_FINAL;
|
||||||
//addsprite(s->willbecome, x, y, "Fruit", B_FALSE);
|
//addsprite(s->willbecome, x, y, "Fruit", B_FALSE);
|
||||||
puffin(s->willbecome, x, y, "fruit", 0);
|
puffin(s->willbecome, x, y, "fruit", 0);
|
||||||
//ss = addsprite(P_PUFF, x, y, "Fruit", B_FALSE);
|
//ss = addsprite(P_PUFF, x, y, "Fruit", B_FALSE);
|
||||||
//ss->timer3 = s->willbecome;
|
//ss->timer3 = s->willbecome;
|
||||||
|
|
||||||
|
} else if (s->bounces >= 6) {
|
||||||
|
// just die
|
||||||
|
s->dead = D_FINAL;
|
||||||
|
puffin(-1, x, y, "nothing_sprd", 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3764,11 +3769,12 @@ void drawscore(void) {
|
||||||
|
|
||||||
if (wantframerate) {
|
if (wantframerate) {
|
||||||
scoreval = fps;
|
scoreval = fps;
|
||||||
|
sprintf(tempm, "%d fps",scoreval);
|
||||||
} else {
|
} else {
|
||||||
scoreval = player->score;
|
scoreval = player->score;
|
||||||
|
addcommas(tempm, scoreval);
|
||||||
}
|
}
|
||||||
|
|
||||||
addcommas(tempm, scoreval);
|
|
||||||
|
|
||||||
/* shadow */
|
/* shadow */
|
||||||
score = TTF_RenderText_Solid(font[TEXTSIZE_SCORE], tempm, black);
|
score = TTF_RenderText_Solid(font[TEXTSIZE_SCORE], tempm, black);
|
||||||
|
@ -4212,6 +4218,7 @@ int isladder(int tid) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// return the x position of the middle of the ladder if so
|
// return the x position of the middle of the ladder if so
|
||||||
int isonladder(sprite_t *s) {
|
int isonladder(sprite_t *s) {
|
||||||
int tx;
|
int tx;
|
||||||
|
@ -5563,7 +5570,6 @@ void usage(void) {
|
||||||
int canmove(sprite_t *pl) {
|
int canmove(sprite_t *pl) {
|
||||||
if (!pl->jumping && !pl->slamming ) {
|
if (!pl->jumping && !pl->slamming ) {
|
||||||
if (!pl->netting) {
|
if (!pl->netting) {
|
||||||
//if (!isonladder(pl) || pl->falling || isonground(pl)) {
|
|
||||||
if ( pl->climbing || pl->falling || isonground(pl)) {
|
if ( pl->climbing || pl->falling || isonground(pl)) {
|
||||||
return B_TRUE;
|
return B_TRUE;
|
||||||
}
|
}
|
||||||
|
@ -7212,7 +7218,21 @@ if (cheat) {
|
||||||
************************************************************/
|
************************************************************/
|
||||||
if ((!paused) && (!levelcomplete != LV_DOPOKER) && (levelcomplete != LV_CLOUDLOOP)) {
|
if ((!paused) && (!levelcomplete != LV_DOPOKER) && (levelcomplete != LV_CLOUDLOOP)) {
|
||||||
if ((!player->dead) && (!player->teleporting)) {
|
if ((!player->dead) && (!player->teleporting)) {
|
||||||
if (!player->climbing) {
|
int moveok = B_FALSE;
|
||||||
|
if (player->climbing) {
|
||||||
|
tiletype_t *tt;
|
||||||
|
// can only move left/right if we're at the bottom of a ladder
|
||||||
|
tt = gettileat(player->x,player->y, NULL,NULL);
|
||||||
|
if (tt->solid) {
|
||||||
|
moveok = B_TRUE;
|
||||||
|
}
|
||||||
|
tt = gettileat(player->x,player->y+TILEH, NULL,NULL);
|
||||||
|
if (tt->solid ) {
|
||||||
|
moveok = B_TRUE;
|
||||||
|
}
|
||||||
|
} else moveok = B_TRUE;
|
||||||
|
|
||||||
|
if (moveok) {
|
||||||
if (keydown(SDLK_RIGHT)) {
|
if (keydown(SDLK_RIGHT)) {
|
||||||
if (canmove(player)) {
|
if (canmove(player)) {
|
||||||
movex(player, getspeed(player));
|
movex(player, getspeed(player));
|
||||||
|
@ -7229,11 +7249,17 @@ if (cheat) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (keydown(SDLK_UP)) {
|
if (keydown(SDLK_UP)) {
|
||||||
if (!player->netting && !player->slamming && !player->jumping) {
|
if (!player->netting && !player->slamming && !player->jumping) {
|
||||||
if (player->climbing) {
|
if (player->climbing) {
|
||||||
|
int ladderx = isladderabove(player);
|
||||||
// if tile above is non-solid, or a ladder
|
// if tile above is non-solid, or a ladder
|
||||||
if (isladderabove(player) || !isroofabove(player)) {
|
if (ladderx || !isroofabove(player)) {
|
||||||
|
// lock to ladder
|
||||||
|
if (ladderx) {
|
||||||
|
player->x = ladderx; // lock to ladder
|
||||||
|
}
|
||||||
// continue climbing
|
// continue climbing
|
||||||
player->y -= getspeed(player);
|
player->y -= getspeed(player);
|
||||||
player->jumping = 0;
|
player->jumping = 0;
|
||||||
|
|
Loading…
Reference in New Issue