mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-08 18:09:45 +01:00
Add set_enemy_colour
There's a few cases in `setenemyroom` which are only meant to override the enemy colour set in the type, so let's move that to it's own function instead. While we're at it, we should move the custom level enemy color logic there as well, because it's in an awkward place. This will also help with things like custom enemy types in the future, or using things like the emitters in custom levels, because this will correct those colors in custom levels.
This commit is contained in:
parent
3aca47e890
commit
333524533d
3 changed files with 149 additions and 77 deletions
|
@ -181,21 +181,6 @@ void entclass::setenemyroom( int rx, int ry )
|
|||
obj.set_enemy_type(this, "circle");
|
||||
break;
|
||||
//Space Station 2
|
||||
case rn(14, 11):
|
||||
colour = 17;
|
||||
break; //Lies
|
||||
case rn(16, 11):
|
||||
colour = 8;
|
||||
break; //Lies
|
||||
case rn(13, 10):
|
||||
colour = 11;
|
||||
break; //Factory
|
||||
case rn(13, 9):
|
||||
colour = 9;
|
||||
break; //Factory
|
||||
case rn(13, 8):
|
||||
colour = 8;
|
||||
break; //Factory
|
||||
case rn(13,7): // MAVVERRRICK
|
||||
obj.set_enemy_type(this, "bus");
|
||||
break;
|
||||
|
|
|
@ -248,7 +248,6 @@ void entityclass::set_enemy_type(entclass* entity, const char* type)
|
|||
{
|
||||
EnemyType* enemyType = &enemy_types[type];
|
||||
entity->tile = enemyType->tile;
|
||||
entity->colour = enemyType->colour;
|
||||
entity->animate = enemyType->animate;
|
||||
entity->w = enemyType->width;
|
||||
entity->h = enemyType->height;
|
||||
|
@ -261,6 +260,11 @@ void entityclass::set_enemy_type(entclass* entity, const char* type)
|
|||
entity->lerpoldyp += enemyType->y_offset;
|
||||
entity->size = enemyType->size;
|
||||
|
||||
if (enemyType->colour != -1)
|
||||
{
|
||||
entity->colour = enemyType->colour;
|
||||
}
|
||||
|
||||
if (enemyType->override_behave)
|
||||
{
|
||||
entity->behave = enemyType->behave;
|
||||
|
@ -322,6 +326,144 @@ const char* entityclass::legacy_id_to_entity(const int id)
|
|||
}
|
||||
}
|
||||
|
||||
void entityclass::set_enemy_colour(entclass* entity)
|
||||
{
|
||||
if (entity == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
// For custom levels, color should be based on the room
|
||||
if (customplatformtile > 0) {
|
||||
// Special case for gray Warp Zone tileset!
|
||||
const RoomProperty* const room = cl.getroomprop(game.roomx - 100, game.roomy - 100);
|
||||
if (room->tileset == 3 && room->tilecol == 6)
|
||||
{
|
||||
entity->colour = 18;
|
||||
return;
|
||||
}
|
||||
|
||||
int entcol = (customplatformtile / 12);
|
||||
switch (entcol) {
|
||||
// RED
|
||||
case 3:
|
||||
case 7:
|
||||
case 12:
|
||||
case 23:
|
||||
case 28:
|
||||
case 34:
|
||||
case 42:
|
||||
case 48:
|
||||
case 58:
|
||||
entity->colour = 6;
|
||||
break;
|
||||
//GREEN
|
||||
case 5:
|
||||
case 9:
|
||||
case 22:
|
||||
case 25:
|
||||
case 29:
|
||||
case 31:
|
||||
case 38:
|
||||
case 46:
|
||||
case 52:
|
||||
case 53:
|
||||
entity->colour = 7;
|
||||
break;
|
||||
// BLUE
|
||||
case 1:
|
||||
case 6:
|
||||
case 14:
|
||||
case 27:
|
||||
case 33:
|
||||
case 44:
|
||||
case 50:
|
||||
case 57:
|
||||
entity->colour = 12;
|
||||
break;
|
||||
// YELLOW
|
||||
case 4:
|
||||
case 17:
|
||||
case 24:
|
||||
case 30:
|
||||
case 37:
|
||||
case 45:
|
||||
case 51:
|
||||
case 55:
|
||||
entity->colour = 9;
|
||||
break;
|
||||
// PURPLE
|
||||
case 2:
|
||||
case 11:
|
||||
case 15:
|
||||
case 19:
|
||||
case 32:
|
||||
case 36:
|
||||
case 49:
|
||||
entity->colour = 20;
|
||||
break;
|
||||
// CYAN
|
||||
case 8:
|
||||
case 10:
|
||||
case 13:
|
||||
case 18:
|
||||
case 26:
|
||||
case 35:
|
||||
case 41:
|
||||
case 47:
|
||||
case 54:
|
||||
entity->colour = 11;
|
||||
break;
|
||||
// PINK
|
||||
case 16:
|
||||
case 20:
|
||||
case 39:
|
||||
case 43:
|
||||
case 56:
|
||||
entity->colour = 8;
|
||||
break;
|
||||
// ORANGE
|
||||
case 21:
|
||||
case 40:
|
||||
entity->colour = 17;
|
||||
break;
|
||||
default:
|
||||
entity->colour = 6;
|
||||
break;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Okay, so we're not in a custom level.
|
||||
* Most colors are stored in the enemy type themselves,
|
||||
* because each enemy is pretty much only in a single room.
|
||||
* There's some special cases, though, like LIES and factory clouds,
|
||||
* so let's correct their colors to match the rooms.
|
||||
*/
|
||||
|
||||
switch (rn(game.roomx - 100, game.roomy - 100))
|
||||
{
|
||||
// First, adjust the color of the LIES enemies
|
||||
case rn(14, 11):
|
||||
entity->colour = 17;
|
||||
break;
|
||||
case rn(16, 11):
|
||||
entity->colour = 8;
|
||||
break;
|
||||
// Then, the factory enemies
|
||||
case rn(13, 10):
|
||||
entity->colour = 11;
|
||||
break;
|
||||
case rn(13, 9):
|
||||
entity->colour = 9;
|
||||
break;
|
||||
case rn(13, 8):
|
||||
entity->colour = 8;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void entityclass::resetallflags(void)
|
||||
{
|
||||
SDL_memset(flags, false, sizeof(flags));
|
||||
|
@ -1498,18 +1640,6 @@ entclass* entityclass::createentity(int xp, int yp, int t, int meta1, int meta2,
|
|||
//Rule 4 is a horizontal line, 5 is vertical
|
||||
//Rule 6 is a crew member
|
||||
|
||||
bool custom_gray;
|
||||
// Special case for gray Warp Zone tileset!
|
||||
if (map.custommode)
|
||||
{
|
||||
const RoomProperty* const room = cl.getroomprop(game.roomx - 100, game.roomy - 100);
|
||||
custom_gray = room->tileset == 3 && room->tilecol == 6;
|
||||
}
|
||||
else
|
||||
{
|
||||
custom_gray = false;
|
||||
}
|
||||
|
||||
entclass& entity = *entptr;
|
||||
entity.xp = xp;
|
||||
entity.yp = yp;
|
||||
|
@ -1559,12 +1689,12 @@ entclass* entityclass::createentity(int xp, int yp, int t, int meta1, int meta2,
|
|||
if (game.roomy == 111 && (game.roomx >= 113 && game.roomx <= 117))
|
||||
{
|
||||
entity.setenemy(0);
|
||||
entity.setenemyroom(game.roomx, game.roomy); //For colour
|
||||
set_enemy_colour(&entity);
|
||||
}
|
||||
else if (game.roomx == 113 && (game.roomy <= 110 && game.roomy >= 108))
|
||||
{
|
||||
entity.setenemy(1);
|
||||
entity.setenemyroom(game.roomx, game.roomy); //For colour
|
||||
set_enemy_colour(&entity);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -2299,51 +2429,7 @@ entclass* entityclass::createentity(int xp, int yp, int t, int meta1, int meta2,
|
|||
|
||||
const char* type = legacy_id_to_entity(customenemy);
|
||||
set_enemy_type(&entity, type);
|
||||
|
||||
//Set colour based on room tile
|
||||
//Set custom colours
|
||||
if (customplatformtile > 0) {
|
||||
int entcol = (customplatformtile / 12);
|
||||
switch (entcol) {
|
||||
//RED
|
||||
case 3: case 7: case 12: case 23: case 28:
|
||||
case 34: case 42: case 48: case 58:
|
||||
entity.colour = 6; break;
|
||||
//GREEN
|
||||
case 5: case 9: case 22: case 25: case 29:
|
||||
case 31: case 38: case 46: case 52: case 53:
|
||||
entity.colour = 7; break;
|
||||
//BLUE
|
||||
case 1: case 6: case 14: case 27: case 33:
|
||||
case 44: case 50: case 57:
|
||||
entity.colour = 12; break;
|
||||
//YELLOW
|
||||
case 4: case 17: case 24: case 30: case 37:
|
||||
case 45: case 51: case 55:
|
||||
entity.colour = 9; break;
|
||||
//PURPLE
|
||||
case 2: case 11: case 15: case 19: case 32:
|
||||
case 36: case 49:
|
||||
entity.colour = 20; break;
|
||||
//CYAN
|
||||
case 8: case 10: case 13: case 18: case 26:
|
||||
case 35: case 41: case 47: case 54:
|
||||
entity.colour = 11; break;
|
||||
//PINK
|
||||
case 16: case 20: case 39: case 43: case 56:
|
||||
entity.colour = 8; break;
|
||||
//ORANGE
|
||||
case 21: case 40:
|
||||
entity.colour = 17; break;
|
||||
default:
|
||||
entity.colour = 6;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (custom_gray) {
|
||||
entity.colour = 18;
|
||||
}
|
||||
set_enemy_colour(&entity);
|
||||
break;
|
||||
}
|
||||
case 100: // Invalid enemy, but gets treated as a teleporter
|
||||
|
@ -2583,7 +2669,7 @@ bool entityclass::updateentities( int i )
|
|||
{
|
||||
entclass* entity = createentity(entities[i].xp+28, entities[i].yp, 1, 10, -1);
|
||||
set_enemy_type(entity, "lies");
|
||||
entity->setenemyroom(game.roomx, game.roomy); // For the color
|
||||
set_enemy_colour(entity);
|
||||
entities[i].state = 1;
|
||||
entities[i].statedelay = 12;
|
||||
}
|
||||
|
@ -2620,7 +2706,7 @@ bool entityclass::updateentities( int i )
|
|||
{
|
||||
entclass* entity = createentity(entities[i].xp, entities[i].yp, 1, 12, -1);
|
||||
set_enemy_type(entity, "factory_clouds");
|
||||
entity->setenemyroom(game.roomx, game.roomy); // For the color
|
||||
set_enemy_colour(entity);
|
||||
entities[i].state = 1;
|
||||
entities[i].statedelay = 16;
|
||||
}
|
||||
|
|
|
@ -69,6 +69,7 @@ public:
|
|||
void add_default_types(void);
|
||||
const char* legacy_id_to_entity(int id);
|
||||
void set_enemy_type(entclass* entity, const char* type);
|
||||
void set_enemy_colour(entclass* entity);
|
||||
|
||||
void resetallflags(void);
|
||||
|
||||
|
|
Loading…
Reference in a new issue