1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-05 16:39:44 +01:00

De-duplicate vertical moving platform fix for player/SCM

Instead of having two separate functions to move entities along vertical
moving platforms, one for the player and one for the supercrewmate, they
have been consolidated into one function.
This commit is contained in:
Misa 2020-09-05 17:25:49 -07:00 committed by Ethan Lee
parent 1c5b72410a
commit ceaee392e5
3 changed files with 8 additions and 55 deletions

View file

@ -4497,17 +4497,16 @@ void entityclass::entitymapcollision( int t )
} }
} }
void entityclass::movingplatformfix( int t ) void entityclass::movingplatformfix( int t, int j )
{ {
if (t < 0 || t >= (int) entities.size()) if (!INBOUNDS(t, entities) || !INBOUNDS(j, entities))
{ {
puts("movingplatformfix() out-of-bounds!"); puts("movingplatformfix() out-of-bounds!");
return; return;
} }
//If this intersects the player, then we move the player along it //If this intersects the entity, then we move them along it
int j = getplayer(); if (entitycollide(t, j))
if (j > -1 && entitycollide(t, j))
{ {
//ok, bollox, let's make sure //ok, bollox, let's make sure
entities[j].yp = entities[j].yp + int(entities[j].vy); entities[j].yp = entities[j].yp + int(entities[j].vy);
@ -4518,7 +4517,7 @@ void entityclass::movingplatformfix( int t )
entities[j].newyp = entities[j].yp + int(entities[j].vy); entities[j].newyp = entities[j].yp + int(entities[j].vy);
if (testwallsy(j, entities[j].xp, entities[j].newyp)) if (testwallsy(j, entities[j].xp, entities[j].newyp))
{ {
if (entities[t].vy > 0) if (entities[t].vy > 0)
{ {
entities[j].yp = entities[t].yp + entities[t].h; entities[j].yp = entities[t].yp + entities[t].h;
entities[j].vy = 0; entities[j].vy = 0;
@ -4539,46 +4538,6 @@ void entityclass::movingplatformfix( int t )
} }
} }
void entityclass::scmmovingplatformfix( int t )
{
if (t < 0 || t >= (int) entities.size())
{
puts("scmmovingplatformfix() out-of-bounds!");
return;
}
//If this intersects the SuperCrewMate, then we move them along it
int j = getscm();
if (entitycollide(t, j))
{
//ok, bollox, let's make sure
entities[j].yp = entities[j].yp + (entities[j].vy);
if (entitycollide(t, j))
{
entities[j].yp = entities[j].yp - (entities[j].vy);
entities[j].vy = entities[t].vy;
entities[j].newyp = static_cast<float>(entities[j].yp) + entities[j].vy;
if (testwallsy(j, entities[j].xp, entities[j].newyp))
{
if (entities[t].vy > 0)
{
entities[j].yp = entities[t].yp + entities[t].h;
entities[j].vy = 0;
}
else
{
entities[j].yp = entities[t].yp - entities[j].h-entities[j].cy;
entities[j].vy = 0;
}
}
else
{
entities[t].state = entities[t].onwall;
}
}
}
}
void entityclass::hormovingplatformfix( int t ) void entityclass::hormovingplatformfix( int t )
{ {
if (t < 0 || t >= (int) entities.size()) if (t < 0 || t >= (int) entities.size())

View file

@ -152,9 +152,7 @@ public:
void entitymapcollision(int t); void entitymapcollision(int t);
void movingplatformfix(int t); void movingplatformfix(int t, int j);
void scmmovingplatformfix(int t);
void hormovingplatformfix(int t); void hormovingplatformfix(int t);

View file

@ -892,14 +892,10 @@ void gamelogic()
obj.entitymapcollision(i); // Collisions with walls obj.entitymapcollision(i); // Collisions with walls
obj.createblock(0, obj.entities[i].xp, obj.entities[i].yp, obj.entities[i].w, obj.entities[i].h); obj.createblock(0, obj.entities[i].xp, obj.entities[i].yp, obj.entities[i].w, obj.entities[i].h);
obj.movingplatformfix(i, obj.getplayer());
if (game.supercrewmate) if (game.supercrewmate)
{ {
obj.movingplatformfix(i); obj.movingplatformfix(i, obj.getscm());
obj.scmmovingplatformfix(i);
}
else
{
obj.movingplatformfix(i);
} }
} }
} }