mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-21 00:51:12 +00:00
- cast screen is working.
SVN r2891 (finale)
This commit is contained in:
parent
fe1b4d2200
commit
03d9e9e028
5 changed files with 173 additions and 1143 deletions
1135
src/f_finale.cpp
1135
src/f_finale.cpp
File diff suppressed because it is too large
Load diff
|
@ -42,6 +42,11 @@
|
||||||
#include "d_main.h"
|
#include "d_main.h"
|
||||||
#include "gstrings.h"
|
#include "gstrings.h"
|
||||||
#include "intermission/intermission.h"
|
#include "intermission/intermission.h"
|
||||||
|
#include "actor.h"
|
||||||
|
#include "d_player.h"
|
||||||
|
#include "r_state.h"
|
||||||
|
#include "r_translate.h"
|
||||||
|
#include "c_bind.h"
|
||||||
|
|
||||||
FIntermissionDescriptorList IntermissionDescriptors;
|
FIntermissionDescriptorList IntermissionDescriptors;
|
||||||
|
|
||||||
|
@ -322,6 +327,8 @@ void DIntermissionScreenCast::Init(FIntermissionAction *desc, bool first)
|
||||||
Super::Init(desc, first);
|
Super::Init(desc, first);
|
||||||
mName = static_cast<FIntermissionActionCast*>(desc)->mName;
|
mName = static_cast<FIntermissionActionCast*>(desc)->mName;
|
||||||
mClass = PClass::FindClass(static_cast<FIntermissionActionCast*>(desc)->mCastClass);
|
mClass = PClass::FindClass(static_cast<FIntermissionActionCast*>(desc)->mCastClass);
|
||||||
|
if (mClass != NULL) mDefaults = GetDefaultByType(mClass);
|
||||||
|
else mDefaults = NULL;
|
||||||
|
|
||||||
mCastSounds.Resize(static_cast<FIntermissionActionCast*>(desc)->mCastSounds.Size());
|
mCastSounds.Resize(static_cast<FIntermissionActionCast*>(desc)->mCastSounds.Size());
|
||||||
for (unsigned i=0; i < mCastSounds.Size(); i++)
|
for (unsigned i=0; i < mCastSounds.Size(); i++)
|
||||||
|
@ -330,21 +337,163 @@ void DIntermissionScreenCast::Init(FIntermissionAction *desc, bool first)
|
||||||
mCastSounds[i].mIndex = static_cast<FIntermissionActionCast*>(desc)->mCastSounds[i].mIndex;
|
mCastSounds[i].mIndex = static_cast<FIntermissionActionCast*>(desc)->mCastSounds[i].mIndex;
|
||||||
mCastSounds[i].mSound = static_cast<FIntermissionActionCast*>(desc)->mCastSounds[i].mSound;
|
mCastSounds[i].mSound = static_cast<FIntermissionActionCast*>(desc)->mCastSounds[i].mSound;
|
||||||
}
|
}
|
||||||
|
caststate = mDefaults->SeeState;
|
||||||
|
if (mClass->IsDescendantOf(RUNTIME_CLASS(APlayerPawn)))
|
||||||
|
{
|
||||||
|
advplayerstate = mDefaults->MissileState;
|
||||||
|
castsprite = skins[players[consoleplayer].userinfo.skin].sprite;
|
||||||
|
casttranslation = translationtables[TRANSLATION_Players][consoleplayer];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
advplayerstate = NULL;
|
||||||
|
if (caststate != NULL) castsprite = caststate->sprite;
|
||||||
|
else castsprite = -1;
|
||||||
|
casttranslation = NULL;
|
||||||
|
}
|
||||||
|
castdeath = false;
|
||||||
|
castframes = 0;
|
||||||
|
castonmelee = 0;
|
||||||
|
castattacking = false;
|
||||||
|
if (mDefaults->SeeSound)
|
||||||
|
{
|
||||||
|
S_Sound (CHAN_VOICE | CHAN_UI, mDefaults->SeeSound, 1, ATTN_NONE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int DIntermissionScreenCast::Responder (event_t *ev)
|
int DIntermissionScreenCast::Responder (event_t *ev)
|
||||||
{
|
{
|
||||||
return Super::Responder(ev);
|
if (ev->type == EV_KeyDown)
|
||||||
|
{
|
||||||
|
const char *cmd = Bindings.GetBind (ev->data1);
|
||||||
|
|
||||||
|
if (cmd != NULL && !stricmp (cmd, "toggleconsole"))
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (castdeath)
|
||||||
|
return 1; // already in dying frames
|
||||||
|
|
||||||
|
castdeath = true;
|
||||||
|
caststate = mClass->ActorInfo->FindState(NAME_Death);
|
||||||
|
if (caststate == NULL) return -1;
|
||||||
|
|
||||||
|
casttics = caststate->GetTics();
|
||||||
|
castframes = 0;
|
||||||
|
castattacking = false;
|
||||||
|
|
||||||
|
if (mClass->IsDescendantOf(RUNTIME_CLASS(APlayerPawn)))
|
||||||
|
{
|
||||||
|
int snd = S_FindSkinnedSound(players[consoleplayer].mo, "*death");
|
||||||
|
if (snd != 0) S_Sound (CHAN_VOICE | CHAN_UI, snd, 1, ATTN_NONE);
|
||||||
|
}
|
||||||
|
else if (mDefaults->DeathSound)
|
||||||
|
{
|
||||||
|
S_Sound (CHAN_VOICE | CHAN_UI, mDefaults->DeathSound, 1, ATTN_NONE);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int DIntermissionScreenCast::Ticker ()
|
int DIntermissionScreenCast::Ticker ()
|
||||||
{
|
{
|
||||||
return Super::Ticker();
|
Super::Ticker();
|
||||||
|
|
||||||
|
if (--casttics > 0 && caststate != NULL)
|
||||||
|
return 0; // not time to change state yet
|
||||||
|
|
||||||
|
if (caststate == NULL || caststate->GetTics() == -1 || caststate->GetNextState() == NULL)
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// sound hacks....
|
||||||
|
if (caststate != NULL && castattacking)
|
||||||
|
{
|
||||||
|
for (unsigned i = 0; i < mCastSounds.Size(); i++)
|
||||||
|
{
|
||||||
|
if ((!!mCastSounds[i].mSequence) == (basestate != mDefaults->MissileState) &&
|
||||||
|
(caststate == basestate + mCastSounds[i].mIndex - 1))
|
||||||
|
{
|
||||||
|
S_StopAllChannels ();
|
||||||
|
S_Sound (CHAN_WEAPON | CHAN_UI, mCastSounds[i].mSound, 1, ATTN_NONE);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// just advance to next state in animation
|
||||||
|
if (caststate == advplayerstate)
|
||||||
|
goto stopattack; // Oh, gross hack!
|
||||||
|
|
||||||
|
caststate = caststate->GetNextState();
|
||||||
|
castframes++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (castframes == 12)
|
||||||
|
{
|
||||||
|
// go into attack frame
|
||||||
|
castattacking = true;
|
||||||
|
if (castonmelee)
|
||||||
|
basestate = caststate = mDefaults->MeleeState;
|
||||||
|
else
|
||||||
|
basestate = caststate = mDefaults->MissileState;
|
||||||
|
castonmelee ^= 1;
|
||||||
|
if (caststate == NULL)
|
||||||
|
{
|
||||||
|
if (castonmelee)
|
||||||
|
basestate = caststate = mDefaults->MeleeState;
|
||||||
|
else
|
||||||
|
basestate = caststate = mDefaults->MissileState;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (castattacking)
|
||||||
|
{
|
||||||
|
if (castframes == 24 || caststate == mDefaults->SeeState )
|
||||||
|
{
|
||||||
|
stopattack:
|
||||||
|
castattacking = false;
|
||||||
|
castframes = 0;
|
||||||
|
caststate = mDefaults->SeeState;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
casttics = caststate->GetTics();
|
||||||
|
if (casttics == -1)
|
||||||
|
casttics = 15;
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DIntermissionScreenCast::Drawer ()
|
void DIntermissionScreenCast::Drawer ()
|
||||||
{
|
{
|
||||||
|
spriteframe_t* sprframe;
|
||||||
|
FTexture* pic;
|
||||||
|
|
||||||
Super::Drawer();
|
Super::Drawer();
|
||||||
|
|
||||||
|
const char *name = mName;
|
||||||
|
if (name != NULL)
|
||||||
|
{
|
||||||
|
if (*name == '$') name = GStrings(name+1);
|
||||||
|
screen->DrawText (SmallFont, CR_UNTRANSLATED,
|
||||||
|
(SCREENWIDTH - SmallFont->StringWidth (name) * CleanXfac)/2,
|
||||||
|
(SCREENHEIGHT * 180) / 200,
|
||||||
|
name,
|
||||||
|
DTA_CleanNoMove, true, TAG_DONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
// draw the current frame in the middle of the screen
|
||||||
|
if (caststate != NULL)
|
||||||
|
{
|
||||||
|
sprframe = &SpriteFrames[sprites[castsprite].spriteframes + caststate->GetFrame()];
|
||||||
|
pic = TexMan(sprframe->Texture[0]);
|
||||||
|
|
||||||
|
screen->DrawTexture (pic, 160, 170,
|
||||||
|
DTA_320x200, true,
|
||||||
|
DTA_FlipX, sprframe->Flip & 1,
|
||||||
|
DTA_Translation, casttranslation,
|
||||||
|
TAG_DONE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
|
@ -499,6 +648,7 @@ bool DIntermissionController::Responder (event_t *ev)
|
||||||
{
|
{
|
||||||
if (mScreen != NULL)
|
if (mScreen != NULL)
|
||||||
{
|
{
|
||||||
|
if (mScreen->mTicker < 2) return false; // prevent some leftover events from auto-advancing
|
||||||
int res = mScreen->Responder(ev);
|
int res = mScreen->Responder(ev);
|
||||||
mAdvance = (res == -1);
|
mAdvance = (res == -1);
|
||||||
return !!res;
|
return !!res;
|
||||||
|
|
|
@ -158,13 +158,13 @@ class DIntermissionScreen : public DObject
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
int mDuration;
|
int mDuration;
|
||||||
int mTicker;
|
|
||||||
FTextureID mBackground;
|
FTextureID mBackground;
|
||||||
bool mFlatfill;
|
bool mFlatfill;
|
||||||
bool mPaletteChanged;
|
bool mPaletteChanged;
|
||||||
TArray<FIIntermissionPatch> mOverlays;
|
TArray<FIIntermissionPatch> mOverlays;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
int mTicker;
|
||||||
|
|
||||||
DIntermissionScreen() {}
|
DIntermissionScreen() {}
|
||||||
virtual void Init(FIntermissionAction *desc, bool first);
|
virtual void Init(FIntermissionAction *desc, bool first);
|
||||||
|
@ -225,10 +225,22 @@ class DIntermissionScreenCast : public DIntermissionScreen
|
||||||
{
|
{
|
||||||
DECLARE_CLASS (DIntermissionScreenCast, DIntermissionScreen)
|
DECLARE_CLASS (DIntermissionScreenCast, DIntermissionScreen)
|
||||||
|
|
||||||
FString mName;
|
const char *mName;
|
||||||
const PClass *mClass;
|
const PClass *mClass;
|
||||||
|
AActor *mDefaults;
|
||||||
TArray<FICastSound> mCastSounds;
|
TArray<FICastSound> mCastSounds;
|
||||||
|
|
||||||
|
int casttics;
|
||||||
|
int castsprite; // [RH] For overriding the player sprite with a skin
|
||||||
|
const FRemapTable *casttranslation; // [RH] Draw "our hero" with their chosen suit color
|
||||||
|
FState* caststate;
|
||||||
|
FState* basestate;
|
||||||
|
FState* advplayerstate;
|
||||||
|
bool castdeath;
|
||||||
|
bool castattacking;
|
||||||
|
int castframes;
|
||||||
|
int castonmelee;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
DIntermissionScreenCast() {}
|
DIntermissionScreenCast() {}
|
||||||
|
|
|
@ -807,11 +807,14 @@ void F_StartFinale (const char *music, int musicorder, int cdtrack, unsigned int
|
||||||
textscreen->mCdId = cdid;
|
textscreen->mCdId = cdid;
|
||||||
}
|
}
|
||||||
FIntermissionDescriptor *desc = new FIntermissionDescriptor;
|
FIntermissionDescriptor *desc = new FIntermissionDescriptor;
|
||||||
desc->mLink = ending? endsequence : NAME_None;
|
|
||||||
desc->mActions.Push(textscreen);
|
desc->mActions.Push(textscreen);
|
||||||
|
|
||||||
FIntermissionActionWiper *wiper = new FIntermissionActionWiper;
|
if (ending)
|
||||||
desc->mActions.Push(wiper);
|
{
|
||||||
|
desc->mLink = endsequence;
|
||||||
|
FIntermissionActionWiper *wiper = new FIntermissionActionWiper;
|
||||||
|
desc->mActions.Push(wiper);
|
||||||
|
}
|
||||||
|
|
||||||
F_StartIntermission(desc, true, ending);
|
F_StartIntermission(desc, true, ending);
|
||||||
}
|
}
|
||||||
|
|
|
@ -220,7 +220,7 @@ Intermission Doom2Cast
|
||||||
Cast
|
Cast
|
||||||
{
|
{
|
||||||
CastClass = "Fatso"
|
CastClass = "Fatso"
|
||||||
CastName = "$CC_FATSO"
|
CastName = "$CC_MANCU"
|
||||||
AttackSound = "Missile", 1, "fatso/attack"
|
AttackSound = "Missile", 1, "fatso/attack"
|
||||||
AttackSound = "Missile", 4, "fatso/attack"
|
AttackSound = "Missile", 4, "fatso/attack"
|
||||||
AttackSound = "Missile", 7, "fatso/attack"
|
AttackSound = "Missile", 7, "fatso/attack"
|
||||||
|
|
Loading…
Reference in a new issue