Objectplace improvements:

- movement speeds are scaled with player scale
- spawned objects are scaled with player scale
- command accepts argument for thing num to set
This commit is contained in:
lachwright 2020-09-06 17:28:34 +09:30
parent 4959aa5614
commit d7ab41a90b
3 changed files with 75 additions and 59 deletions

View file

@ -1023,8 +1023,8 @@ static void OP_CycleThings(INT32 amt)
states[S_OBJPLACE_DUMMY].frame = states[mobjinfo[op_currentthing].spawnstate].frame; states[S_OBJPLACE_DUMMY].frame = states[mobjinfo[op_currentthing].spawnstate].frame;
} }
if (players[0].mo->eflags & MFE_VERTICALFLIP) // correct z when flipped if (players[0].mo->eflags & MFE_VERTICALFLIP) // correct z when flipped
players[0].mo->z += players[0].mo->height - mobjinfo[op_currentthing].height; players[0].mo->z += players[0].mo->height - FixedMul(mobjinfo[op_currentthing].height, players[0].mo->scale);
players[0].mo->height = mobjinfo[op_currentthing].height; players[0].mo->height = FixedMul(mobjinfo[op_currentthing].height, players[0].mo->scale);
P_SetPlayerMobjState(players[0].mo, S_OBJPLACE_DUMMY); P_SetPlayerMobjState(players[0].mo, S_OBJPLACE_DUMMY);
op_currentdoomednum = mobjinfo[op_currentthing].doomednum; op_currentdoomednum = mobjinfo[op_currentthing].doomednum;
@ -1107,6 +1107,7 @@ static mapthing_t *OP_CreateNewMapThing(player_t *player, UINT16 type, boolean c
mt->angle = (INT16)(FixedInt(AngleFixed(player->mo->angle))); mt->angle = (INT16)(FixedInt(AngleFixed(player->mo->angle)));
mt->options = (mt->z << ZSHIFT) | (UINT16)cv_opflags.value; mt->options = (mt->z << ZSHIFT) | (UINT16)cv_opflags.value;
mt->scale = player->mo->scale;
return mt; return mt;
} }
@ -1305,19 +1306,19 @@ void OP_ObjectplaceMovement(player_t *player)
ticmiss++; ticmiss++;
if (cmd->buttons & BT_JUMP) if (cmd->buttons & BT_JUMP)
player->mo->z += FRACUNIT*cv_speed.value; player->mo->z += player->mo->scale*cv_speed.value;
else if (cmd->buttons & BT_SPIN) else if (cmd->buttons & BT_SPIN)
player->mo->z -= FRACUNIT*cv_speed.value; player->mo->z -= player->mo->scale*cv_speed.value;
if (cmd->forwardmove != 0) if (cmd->forwardmove != 0)
{ {
P_Thrust(player->mo, player->mo->angle, (cmd->forwardmove*FRACUNIT/MAXPLMOVE)*cv_speed.value); P_Thrust(player->mo, player->mo->angle, (cmd->forwardmove*player->mo->scale/MAXPLMOVE)*cv_speed.value);
P_TeleportMove(player->mo, player->mo->x+player->mo->momx, player->mo->y+player->mo->momy, player->mo->z); P_TeleportMove(player->mo, player->mo->x+player->mo->momx, player->mo->y+player->mo->momy, player->mo->z);
player->mo->momx = player->mo->momy = 0; player->mo->momx = player->mo->momy = 0;
} }
if (cmd->sidemove != 0) if (cmd->sidemove != 0)
{ {
P_Thrust(player->mo, player->mo->angle-ANGLE_90, (cmd->sidemove*FRACUNIT/MAXPLMOVE)*cv_speed.value); P_Thrust(player->mo, player->mo->angle-ANGLE_90, (cmd->sidemove*player->mo->scale/MAXPLMOVE)*cv_speed.value);
P_TeleportMove(player->mo, player->mo->x+player->mo->momx, player->mo->y+player->mo->momy, player->mo->z); P_TeleportMove(player->mo, player->mo->x+player->mo->momx, player->mo->y+player->mo->momy, player->mo->z);
player->mo->momx = player->mo->momy = 0; player->mo->momx = player->mo->momy = 0;
} }
@ -1443,62 +1444,75 @@ void Command_ObjectPlace_f(void)
G_SetGameModified(multiplayer); G_SetGameModified(multiplayer);
// Entering objectplace? // Entering objectplace?
if (!objectplacing) if (!objectplacing || COM_Argc() > 1)
{ {
objectplacing = true; if (!objectplacing)
if (players[0].powers[pw_carry] == CR_NIGHTSMODE)
return;
if (!COM_CheckParm("-silent"))
{ {
HU_SetCEchoFlags(V_RETURN8|V_MONOSPACE|V_AUTOFADEOUT); objectplacing = true;
HU_SetCEchoDuration(10);
HU_DoCEcho(va(M_GetText( if (players[0].powers[pw_carry] == CR_NIGHTSMODE)
"\\\\\\\\\\\\\\\\\\\\\\\\\x82" return;
" Objectplace Controls: \x80\\\\"
"Weapon Next/Prev: Cycle mapthings\\" if (!COM_CheckParm("-silent"))
" Jump: Float up \\" {
" Spin: Float down \\" HU_SetCEchoFlags(V_RETURN8|V_MONOSPACE|V_AUTOFADEOUT);
" Fire Ring: Place object \\"))); HU_SetCEchoDuration(10);
HU_DoCEcho(va(M_GetText(
"\\\\\\\\\\\\\\\\\\\\\\\\\x82"
" Objectplace Controls: \x80\\\\"
"Weapon Next/Prev: Cycle mapthings\\"
" Jump: Float up \\"
" Spin: Float down \\"
" Fire Ring: Place object \\")));
}
// Save all the player's data.
op_oldflags1 = players[0].mo->flags;
op_oldflags2 = players[0].mo->flags2;
op_oldeflags = players[0].mo->eflags;
op_oldpflags = players[0].pflags;
op_oldmomx = players[0].mo->momx;
op_oldmomy = players[0].mo->momy;
op_oldmomz = players[0].mo->momz;
op_oldheight = players[0].mo->height;
op_oldstate = S_PLAY_STND;
op_oldcolor = players[0].mo->color; // save color too in case of super/fireflower
// Remove ALL flags and motion.
P_UnsetThingPosition(players[0].mo);
players[0].pflags = 0;
players[0].mo->flags2 = 0;
players[0].mo->eflags = 0;
players[0].mo->flags = (MF_NOCLIP|MF_NOGRAVITY|MF_NOBLOCKMAP);
players[0].mo->momx = players[0].mo->momy = players[0].mo->momz = 0;
P_SetThingPosition(players[0].mo);
// Take away color so things display properly
players[0].mo->color = 0;
// Like the classics, recover from death by entering objectplace
if (players[0].mo->health <= 0)
{
players[0].mo->health = 1;
players[0].deadtimer = 0;
op_oldflags1 = mobjinfo[MT_PLAYER].flags;
++players[0].lives;
players[0].playerstate = PST_LIVE;
P_RestoreMusic(&players[0]);
}
else
op_oldstate = (statenum_t)(players[0].mo->state-states);
} }
// Save all the player's data. if (COM_Argc() > 1)
op_oldflags1 = players[0].mo->flags;
op_oldflags2 = players[0].mo->flags2;
op_oldeflags = players[0].mo->eflags;
op_oldpflags = players[0].pflags;
op_oldmomx = players[0].mo->momx;
op_oldmomy = players[0].mo->momy;
op_oldmomz = players[0].mo->momz;
op_oldheight = players[0].mo->height;
op_oldstate = S_PLAY_STND;
op_oldcolor = players[0].mo->color; // save color too in case of super/fireflower
// Remove ALL flags and motion.
P_UnsetThingPosition(players[0].mo);
players[0].pflags = 0;
players[0].mo->flags2 = 0;
players[0].mo->eflags = 0;
players[0].mo->flags = (MF_NOCLIP|MF_NOGRAVITY|MF_NOBLOCKMAP);
players[0].mo->momx = players[0].mo->momy = players[0].mo->momz = 0;
P_SetThingPosition(players[0].mo);
// Take away color so things display properly
players[0].mo->color = 0;
// Like the classics, recover from death by entering objectplace
if (players[0].mo->health <= 0)
{ {
players[0].mo->health = 1; UINT16 mapthingnum = atoi(COM_Argv(1));
players[0].deadtimer = 0; mobjtype_t type = P_GetMobjtype(mapthingnum);
op_oldflags1 = mobjinfo[MT_PLAYER].flags; if (type == MT_UNKNOWN)
++players[0].lives; CONS_Printf(M_GetText("No mobj type delegated to thing type %d.\n"), mapthingnum);
players[0].playerstate = PST_LIVE; else
P_RestoreMusic(&players[0]); op_currentthing = type;
} }
else
op_oldstate = (statenum_t)(players[0].mo->state-states);
// If no thing set, then cycle a little // If no thing set, then cycle a little
if (!op_currentthing) if (!op_currentthing)
@ -1506,8 +1520,8 @@ void Command_ObjectPlace_f(void)
op_currentthing = 1; op_currentthing = 1;
OP_CycleThings(1); OP_CycleThings(1);
} }
else // Cycle things sets this for the former. else
players[0].mo->height = mobjinfo[op_currentthing].height; OP_CycleThings(0); // sets all necessary height values without cycling op_currentthing
P_SetPlayerMobjState(players[0].mo, S_OBJPLACE_DUMMY); P_SetPlayerMobjState(players[0].mo, S_OBJPLACE_DUMMY);
} }

View file

@ -274,6 +274,8 @@ extern tic_t itemrespawntime[ITEMQUESIZE];
extern size_t iquehead, iquetail; extern size_t iquehead, iquetail;
extern consvar_t cv_gravity, cv_movebob; extern consvar_t cv_gravity, cv_movebob;
mobjtype_t P_GetMobjtype(UINT16 mthingtype);
void P_RespawnSpecials(void); void P_RespawnSpecials(void);
mobj_t *P_SpawnMobj(fixed_t x, fixed_t y, fixed_t z, mobjtype_t type); mobj_t *P_SpawnMobj(fixed_t x, fixed_t y, fixed_t z, mobjtype_t type);

View file

@ -11249,7 +11249,7 @@ void P_PrecipitationEffects(void)
* \param mthingtype Mapthing number in question. * \param mthingtype Mapthing number in question.
* \return Mobj type; MT_UNKNOWN if nothing found. * \return Mobj type; MT_UNKNOWN if nothing found.
*/ */
static mobjtype_t P_GetMobjtype(UINT16 mthingtype) mobjtype_t P_GetMobjtype(UINT16 mthingtype)
{ {
mobjtype_t i; mobjtype_t i;
for (i = 0; i < NUMMOBJTYPES; i++) for (i = 0; i < NUMMOBJTYPES; i++)