mirror of
https://git.do.srb2.org/STJr/SRB2.git
synced 2025-01-18 23:42:11 +00:00
Adapt various thing types for UDMF
This commit is contained in:
parent
53931727bd
commit
79c3197de2
5 changed files with 236 additions and 10 deletions
|
@ -4265,6 +4265,12 @@ udmf
|
|||
width = 24;
|
||||
height = 24;
|
||||
sprite = "RINGA0";
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
|
||||
300
|
||||
{
|
||||
|
@ -4380,6 +4386,12 @@ udmf
|
|||
sprite = "TOKEA0";
|
||||
width = 16;
|
||||
height = 32;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
313
|
||||
{
|
||||
|
@ -4420,11 +4432,23 @@ udmf
|
|||
{
|
||||
title = "Emerald Hunt Location";
|
||||
sprite = "SHRDA0";
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
321
|
||||
{
|
||||
title = "Match Chaos Emerald Spawn";
|
||||
sprite = "CEMGA0";
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
322
|
||||
{
|
||||
|
@ -4432,6 +4456,12 @@ udmf
|
|||
sprite = "EMBMA0";
|
||||
width = 16;
|
||||
height = 30;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -4661,6 +4691,12 @@ udmf
|
|||
{
|
||||
title = "Order";
|
||||
}
|
||||
arg1
|
||||
{
|
||||
title = "Respawn at center?";
|
||||
type = 11;
|
||||
enum = "noyes";
|
||||
}
|
||||
}
|
||||
520
|
||||
{
|
||||
|
@ -4668,6 +4704,12 @@ udmf
|
|||
sprite = "SPHRD0";
|
||||
width = 16;
|
||||
height = 24;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
521
|
||||
{
|
||||
|
@ -4675,6 +4717,12 @@ udmf
|
|||
sprite = "SPIKA0";
|
||||
width = 12;
|
||||
height = 8;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
522
|
||||
{
|
||||
|
@ -4791,6 +4839,12 @@ udmf
|
|||
title = "Gas Jet";
|
||||
sprite = "STEMD0";
|
||||
width = 32;
|
||||
arg0
|
||||
{
|
||||
title = "Play sound?";
|
||||
type = 11;
|
||||
enum = "noyes";
|
||||
}
|
||||
}
|
||||
542
|
||||
{
|
||||
|
@ -4889,6 +4943,12 @@ udmf
|
|||
sprite = "SSWYD2D8";
|
||||
width = 16;
|
||||
height = 32;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
559
|
||||
{
|
||||
|
@ -4897,6 +4957,12 @@ udmf
|
|||
sprite = "SSWRD2D8";
|
||||
width = 16;
|
||||
height = 32;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
560
|
||||
{
|
||||
|
@ -4905,6 +4971,12 @@ udmf
|
|||
sprite = "SSWBD2D8";
|
||||
width = 16;
|
||||
height = 32;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
1134
|
||||
{
|
||||
|
@ -4927,6 +4999,12 @@ udmf
|
|||
sprite = "BSTYA0";
|
||||
width = 28;
|
||||
height = 2;
|
||||
arg0
|
||||
{
|
||||
title = "Force spin?";
|
||||
type = 11;
|
||||
enum = "noyes";
|
||||
}
|
||||
}
|
||||
545
|
||||
{
|
||||
|
@ -4935,6 +5013,12 @@ udmf
|
|||
sprite = "BSTRA0";
|
||||
width = 28;
|
||||
height = 2;
|
||||
arg0
|
||||
{
|
||||
title = "Force spin?";
|
||||
type = 11;
|
||||
enum = "noyes";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -5572,6 +5656,12 @@ udmf
|
|||
type = 11;
|
||||
enum = "pushablebehavior";
|
||||
}
|
||||
arg1
|
||||
{
|
||||
title = "Solid gold?";
|
||||
type = 11;
|
||||
enum = "noyes";
|
||||
}
|
||||
}
|
||||
1103
|
||||
{
|
||||
|
@ -6049,6 +6139,17 @@ udmf
|
|||
sprite = "EGR1A1";
|
||||
width = 20;
|
||||
height = 72;
|
||||
arg0
|
||||
{
|
||||
title = "Movement";
|
||||
type = 11;
|
||||
enum
|
||||
{
|
||||
0 = "None";
|
||||
1 = "Right";
|
||||
2 = "Left";
|
||||
}
|
||||
}
|
||||
}
|
||||
1128
|
||||
{
|
||||
|
@ -6265,6 +6366,12 @@ udmf
|
|||
sprite = "SALDARAL";
|
||||
width = 96;
|
||||
height = 160;
|
||||
arg0
|
||||
{
|
||||
title = "Allow non-minecart players?";
|
||||
type = 11;
|
||||
enum = "noyes";
|
||||
}
|
||||
}
|
||||
1222
|
||||
{
|
||||
|
@ -6293,6 +6400,16 @@ udmf
|
|||
sprite = "internal:zoom";
|
||||
width = 8;
|
||||
height = 16;
|
||||
arg0
|
||||
{
|
||||
title = "Type";
|
||||
type = 11;
|
||||
enum
|
||||
{
|
||||
0 = "Disable";
|
||||
1 = "Enable";
|
||||
}
|
||||
}
|
||||
}
|
||||
1230
|
||||
{
|
||||
|
@ -6391,6 +6508,12 @@ udmf
|
|||
sprite = "PUMIA1A5";
|
||||
width = 30;
|
||||
height = 60;
|
||||
arg0
|
||||
{
|
||||
title = "Buoyant?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
1306
|
||||
{
|
||||
|
@ -6939,6 +7062,12 @@ udmf
|
|||
sprite = "SPHRA0";
|
||||
width = 16;
|
||||
height = 24;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
1707
|
||||
{
|
||||
|
@ -7051,6 +7180,12 @@ udmf
|
|||
sprite = "COINA0";
|
||||
width = 16;
|
||||
height = 24;
|
||||
arg0
|
||||
{
|
||||
title = "Float?";
|
||||
type = 11;
|
||||
enum = "yesno";
|
||||
}
|
||||
}
|
||||
1801
|
||||
{
|
||||
|
|
|
@ -1437,7 +1437,7 @@ void P_TouchSpecialThing(mobj_t *special, mobj_t *toucher, boolean heightcheck)
|
|||
// Misc touchables //
|
||||
// *************** //
|
||||
case MT_STARPOST:
|
||||
P_TouchStarPost(special, player, special->spawnpoint && (special->spawnpoint->options & MTF_OBJECTSPECIAL));
|
||||
P_TouchStarPost(special, player, special->spawnpoint && special->spawnpoint->args[1]);
|
||||
return;
|
||||
|
||||
case MT_FAKEMOBILE:
|
||||
|
|
45
src/p_mobj.c
45
src/p_mobj.c
|
@ -8590,9 +8590,9 @@ static boolean P_EggRobo1Think(mobj_t *mobj)
|
|||
{
|
||||
fixed_t basex = mobj->cusval, basey = mobj->cvmem;
|
||||
|
||||
if (mobj->spawnpoint && mobj->spawnpoint->options & (MTF_AMBUSH|MTF_OBJECTSPECIAL))
|
||||
if (mobj->spawnpoint && mobj->spawnpoint->args[0] != TMED_NONE)
|
||||
{
|
||||
angle_t sideang = mobj->movedir + ((mobj->spawnpoint->options & MTF_AMBUSH) ? ANGLE_90 : -ANGLE_90);
|
||||
angle_t sideang = mobj->movedir + ((mobj->spawnpoint->args[0] == TMED_LEFT) ? ANGLE_90 : -ANGLE_90);
|
||||
fixed_t oscillate = FixedMul(FINESINE(((leveltime * ANG1) >> (ANGLETOFINESHIFT + 2)) & FINEMASK), 250*mobj->scale);
|
||||
basex += P_ReturnThrustX(mobj, sideang, oscillate);
|
||||
basey += P_ReturnThrustY(mobj, sideang, oscillate);
|
||||
|
@ -11775,14 +11775,14 @@ fixed_t P_GetMapThingSpawnHeight(const mobjtype_t mobjtype, const mapthing_t* mt
|
|||
dz = 288*FRACUNIT;
|
||||
break;
|
||||
|
||||
// Horizontal springs, may float additional units with MTF_AMBUSH.
|
||||
// Horizontal springs, float additional units unless args[0] is set.
|
||||
case MT_YELLOWHORIZ:
|
||||
case MT_REDHORIZ:
|
||||
case MT_BLUEHORIZ:
|
||||
offset += mthing->options & MTF_AMBUSH ? 16*FRACUNIT : 0;
|
||||
offset += mthing->args[0] ? 0 : 16*FRACUNIT;
|
||||
break;
|
||||
|
||||
// Ring-like items, may float additional units with MTF_AMBUSH.
|
||||
// Ring-like items, float additional units unless args[0] is set.
|
||||
case MT_SPIKEBALL:
|
||||
case MT_EMERHUNT:
|
||||
case MT_EMERALDSPAWN:
|
||||
|
@ -11796,13 +11796,13 @@ fixed_t P_GetMapThingSpawnHeight(const mobjtype_t mobjtype, const mapthing_t* mt
|
|||
case MT_BOMBSPHERE:
|
||||
case MT_NIGHTSCHIP:
|
||||
case MT_NIGHTSSTAR:
|
||||
offset += mthing->options & MTF_AMBUSH ? 24*FRACUNIT : 0;
|
||||
offset += mthing->args[0] ? 0 : 24*FRACUNIT;
|
||||
break;
|
||||
|
||||
// Remaining objects.
|
||||
default:
|
||||
if (P_WeaponOrPanel(mobjtype))
|
||||
offset += mthing->options & MTF_AMBUSH ? 24*FRACUNIT : 0;
|
||||
offset += mthing->args[0] ? 0 : 24*FRACUNIT;
|
||||
}
|
||||
|
||||
if (!(dz + offset)) // Snap to the surfaces when there's no offset set.
|
||||
|
@ -12717,7 +12717,7 @@ static boolean P_SetupSpawnedMapThing(mapthing_t *mthing, mobj_t *mobj, boolean
|
|||
break;
|
||||
}
|
||||
case MT_EGGSTATUE:
|
||||
if (mthing->options & MTF_EXTRA)
|
||||
if (mthing->args[1])
|
||||
{
|
||||
mobj->color = SKINCOLOR_GOLD;
|
||||
mobj->colorized = true;
|
||||
|
@ -13096,6 +13096,22 @@ static boolean P_SetupSpawnedMapThing(mapthing_t *mthing, mobj_t *mobj, boolean
|
|||
if (mthing->args[1])
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
break;
|
||||
case MT_STEAM:
|
||||
if (mthing->args[0])
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
break;
|
||||
case MT_SALOONDOORCENTER:
|
||||
if (mthing->args[0])
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
break;
|
||||
case MT_MINECARTSWITCHPOINT:
|
||||
if (mthing->args[0])
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
break;
|
||||
case MT_ROLLOUTSPAWN:
|
||||
if (mthing->args[0])
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@ -13136,6 +13152,12 @@ static boolean P_SetupSpawnedMapThing(mapthing_t *mthing, mobj_t *mobj, boolean
|
|||
break;
|
||||
}
|
||||
}
|
||||
if (mobj->flags & MF_SPRING && mobj->info->painchance == 3)
|
||||
{
|
||||
if (mthing->args[0])
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
}
|
||||
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -13171,7 +13193,12 @@ static void P_SetAmbush(mobj_t *mobj)
|
|||
mobj->type != MT_CACOLANTERN &&
|
||||
mobj->type != MT_PIAN &&
|
||||
mobj->type != MT_EGGGUARD &&
|
||||
mobj->type != MT_STARPOST)
|
||||
mobj->type != MT_STEAM &&
|
||||
mobj->type != MT_SALOONDOORCENTER &&
|
||||
mobj->type != MT_MINECARTSWITCHPOINT &&
|
||||
mobj->type != MT_ROLLOUTSPAWN &&
|
||||
mobj->type != MT_STARPOST &&
|
||||
!(mobj->flags & MF_SPRING && mobj->info->painchance == 3))
|
||||
mobj->flags2 |= MF2_AMBUSH;
|
||||
}
|
||||
|
||||
|
|
|
@ -4914,6 +4914,8 @@ static void P_ConvertBinaryMap(void)
|
|||
else
|
||||
mapthings[i].args[0] = TMP_NORMAL;
|
||||
}
|
||||
if (mobjinfo[mobjtype].flags & MF_SPRING && mobjinfo[mobjtype].painchance == 3)
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
}
|
||||
|
||||
if (mapthings[i].type >= 1 && mapthings[i].type <= 35) //Player starts
|
||||
|
@ -4996,6 +4998,32 @@ static void P_ConvertBinaryMap(void)
|
|||
case 294: //Fang waypoint
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 300: //Ring
|
||||
case 301: //Bounce ring
|
||||
case 302: //Rail ring
|
||||
case 303: //Infinity ring
|
||||
case 304: //Automatic ring
|
||||
case 305: //Explosion ring
|
||||
case 306: //Scatter ring
|
||||
case 307: //Grenade ring
|
||||
case 308: //Red team ring
|
||||
case 309: //Blue team ring
|
||||
case 312: //Emerald token
|
||||
case 320: //Emerald hunt location
|
||||
case 321: //Match chaos emerald spawn
|
||||
case 322: //Emblem
|
||||
case 330: //Bounce ring panel
|
||||
case 331: //Rail ring panel
|
||||
case 332: //Automatic ring panel
|
||||
case 333: //Explosion ring panel
|
||||
case 334: //Scatter ring panel
|
||||
case 335: //Grenade ring panel
|
||||
case 520: //Bomb sphere
|
||||
case 521: //Spikeball
|
||||
case 1706: //Blue sphere
|
||||
case 1800: //Coin
|
||||
mapthings[i].args[0] = !(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 500: //Air bubble patch
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
|
@ -5009,6 +5037,7 @@ static void P_ConvertBinaryMap(void)
|
|||
else
|
||||
// Old behavior if Parameter is 0; add 360 to the angle for each consecutive star post.
|
||||
mapthings[i].args[0] = (mapthings[i].angle/360);
|
||||
mapthings[i].args[1] = !!(mapthings[i].options & MTF_OBJECTSPECIAL);
|
||||
break;
|
||||
case 522: //Wall spike
|
||||
if (mapthings[i].options & MTF_OBJECTSPECIAL)
|
||||
|
@ -5039,6 +5068,9 @@ static void P_ConvertBinaryMap(void)
|
|||
if (mapthings[i].options & MTF_AMBUSH)
|
||||
mapthings[i].args[1] |= TMF_NODISTANCECHECK;
|
||||
break;
|
||||
case 541: //Gas jet
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 543: //Balloon
|
||||
if (mapthings[i].angle > 0)
|
||||
P_WriteConstant(((mapthings[i].angle - 1) % (numskincolors - 1)) + 1, &mapthings[i].stringargs[0]);
|
||||
|
@ -5052,6 +5084,11 @@ static void P_ConvertBinaryMap(void)
|
|||
if (mapthings[i].options & MTF_AMBUSH)
|
||||
mapthings[i].args[0] |= TMDS_ROTATEEXTRA;
|
||||
break;
|
||||
case 558: //Horizontal yellow spring
|
||||
case 559: //Horizontal red spring
|
||||
case 560: //Horizontal blue spring
|
||||
mapthings[i].args[0] = !(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 700: //Water ambience A
|
||||
case 701: //Water ambience A
|
||||
case 702: //Water ambience A
|
||||
|
@ -5174,6 +5211,9 @@ static void P_ConvertBinaryMap(void)
|
|||
case 1011: //Stalagmite (DSZ2)
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_OBJECTSPECIAL);
|
||||
break;
|
||||
case 1102: //Eggman Statue
|
||||
mapthings[i].args[1] = !!(mapthings[i].options & MTF_EXTRA);
|
||||
break;
|
||||
case 1104: //Mace spawnpoint
|
||||
case 1105: //Chain with maces spawnpoint
|
||||
case 1106: //Chained spring spawnpoint
|
||||
|
@ -5238,6 +5278,14 @@ static void P_ConvertBinaryMap(void)
|
|||
if (mapthings[i].options & MTF_EXTRA)
|
||||
mapthings[i].args[0] |= TMFH_CORONA;
|
||||
break;
|
||||
case 1127: //Spectator EggRobo
|
||||
if (mapthings[i].options & MTF_AMBUSH)
|
||||
mapthings[i].args[0] = TMED_LEFT;
|
||||
else if (mapthings[i].options & MTF_OBJECTSPECIAL)
|
||||
mapthings[i].args[0] = TMED_RIGHT;
|
||||
else
|
||||
mapthings[i].args[0] = TMED_NONE;
|
||||
break;
|
||||
case 1200: //Tumbleweed (Big)
|
||||
case 1201: //Tumbleweed (Small)
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
|
@ -5259,6 +5307,12 @@ static void P_ConvertBinaryMap(void)
|
|||
P_WriteConstant(MT_ROCKCRUMBLE1 + (sides[lines[j].sidenum[0]].rowoffset >> FRACBITS), &mapthings[i].stringargs[0]);
|
||||
break;
|
||||
}
|
||||
case 1221: //Minecart saloon door
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 1229: //Minecart switch point
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 1300: //Flame jet (horizontal)
|
||||
case 1301: //Flame jet (vertical)
|
||||
mapthings[i].args[0] = (mapthings[i].angle >> 13)*TICRATE/2;
|
||||
|
@ -5269,6 +5323,9 @@ static void P_ConvertBinaryMap(void)
|
|||
mapthings[i].args[0] = mapthings[i].angle;
|
||||
mapthings[i].args[1] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 1305: //Rollout Rock
|
||||
mapthings[i].args[0] = !!(mapthings[i].options & MTF_AMBUSH);
|
||||
break;
|
||||
case 1700: //Axis
|
||||
mapthings[i].args[2] = mapthings[i].angle & 16383;
|
||||
mapthings[i].args[3] = !!(mapthings[i].angle & 16384);
|
||||
|
|
|
@ -96,6 +96,13 @@ typedef enum
|
|||
TMP_CLASSIC = 3,
|
||||
} textmappushabletype_t;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
TMED_NONE = 0,
|
||||
TMED_RIGHT = 1,
|
||||
TMED_LEFT = 2,
|
||||
} textmapeggrobodirection_t;
|
||||
|
||||
//FOF flags
|
||||
typedef enum
|
||||
{
|
||||
|
|
Loading…
Reference in a new issue