- cast screen is working.

SVN r2891 (finale)
This commit is contained in:
Christoph Oelckers 2010-10-03 20:58:54 +00:00
parent fe1b4d2200
commit 03d9e9e028
5 changed files with 173 additions and 1143 deletions

File diff suppressed because it is too large Load diff

View file

@ -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;

View file

@ -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() {}

View file

@ -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);
} }

View file

@ -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"