2019-09-19 22:42:45 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
/*
|
|
|
|
Copyright (C) 2010-2019 EDuke32 developers and contributors
|
|
|
|
Copyright (C) 2019 Nuke.YKT
|
|
|
|
|
|
|
|
This file is part of NBlood.
|
|
|
|
|
|
|
|
NBlood is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License version 2
|
|
|
|
as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
//-------------------------------------------------------------------------
|
2019-09-21 18:59:54 +00:00
|
|
|
|
|
|
|
#include "ns.h" // Must come before everything else!
|
|
|
|
|
2019-09-19 22:42:45 +00:00
|
|
|
#include "build.h"
|
|
|
|
#include "common.h"
|
|
|
|
#include "mmulti.h"
|
|
|
|
#include "fx_man.h"
|
|
|
|
#include "common_game.h"
|
|
|
|
#include "blood.h"
|
|
|
|
#include "endgame.h"
|
|
|
|
#include "globals.h"
|
|
|
|
#include "levels.h"
|
|
|
|
#include "loadsave.h"
|
|
|
|
#include "menu.h"
|
|
|
|
#include "network.h"
|
|
|
|
#include "player.h"
|
|
|
|
#include "sound.h"
|
|
|
|
#include "view.h"
|
2019-09-19 06:10:18 +00:00
|
|
|
#include "messages.h"
|
2019-09-19 22:42:45 +00:00
|
|
|
|
2019-09-22 06:39:22 +00:00
|
|
|
BEGIN_BLD_NS
|
|
|
|
|
2019-09-19 22:42:45 +00:00
|
|
|
CEndGameMgr::CEndGameMgr()
|
|
|
|
{
|
|
|
|
at0 = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CEndGameMgr::Draw(void)
|
|
|
|
{
|
|
|
|
viewLoadingScreenWide();
|
|
|
|
int nHeight;
|
|
|
|
gMenuTextMgr.GetFontInfo(1, NULL, NULL, &nHeight);
|
|
|
|
rotatesprite(160<<16, 20<<16, 65536, 0, 2038, -128, 0, 6, 0, 0, xdim-1, ydim-1);
|
|
|
|
int nY = 20 - nHeight / 2;
|
|
|
|
if (gGameOptions.nGameType == 0)
|
|
|
|
{
|
|
|
|
viewDrawText(1, "LEVEL STATS", 160, nY, -128, 0, 1, 0);
|
|
|
|
if (CCheatMgr::m_bPlayerCheated)
|
|
|
|
{
|
|
|
|
viewDrawText(3, ">>> YOU CHEATED! <<<", 160, 32, -128, 0, 1, 1);
|
|
|
|
}
|
|
|
|
gKillMgr.Draw();
|
|
|
|
gSecretMgr.Draw();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
viewDrawText(1, "FRAG STATS", 160, nY, -128, 0, 1, 0);
|
|
|
|
gKillMgr.Draw();
|
|
|
|
}
|
2019-09-07 13:15:39 +00:00
|
|
|
if (/*dword_28E3D4 != 1 && */((int)totalclock&32))
|
2019-09-19 22:42:45 +00:00
|
|
|
{
|
|
|
|
viewDrawText(3, "PRESS A KEY TO CONTINUE", 160, 134, -128, 0, 1, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CEndGameMgr::ProcessKeys(void)
|
|
|
|
{
|
|
|
|
//if (dword_28E3D4 == 1)
|
|
|
|
//{
|
|
|
|
// if (gGameOptions.gameType >= 0 || numplayers > 1)
|
|
|
|
// netWaitForEveryone(0);
|
|
|
|
// Finish();
|
|
|
|
//}
|
|
|
|
//else
|
|
|
|
{
|
|
|
|
char ch = keyGetScan();
|
|
|
|
if (!ch)
|
|
|
|
return;
|
|
|
|
if (gGameOptions.nGameType > 0 || numplayers > 1)
|
|
|
|
netWaitForEveryone(0);
|
|
|
|
Finish();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
extern void EndLevel(void);
|
|
|
|
|
|
|
|
void CEndGameMgr::Setup(void)
|
|
|
|
{
|
|
|
|
at1 = gInputMode;
|
|
|
|
gInputMode = INPUT_MODE_3;
|
|
|
|
at0 = 1;
|
|
|
|
EndLevel();
|
|
|
|
sndStartSample(268, 128, -1, 1);
|
|
|
|
keyFlushScans();
|
|
|
|
}
|
|
|
|
|
|
|
|
//int gNextLevel;
|
|
|
|
|
|
|
|
extern int gInitialNetPlayers;
|
|
|
|
extern bool gStartNewGame;
|
|
|
|
|
|
|
|
void CEndGameMgr::Finish(void)
|
|
|
|
{
|
|
|
|
levelSetupOptions(gGameOptions.nEpisode, gNextLevel);
|
|
|
|
gInitialNetPlayers = numplayers;
|
|
|
|
//if (FXDevice != -1)
|
|
|
|
FX_StopAllSounds();
|
|
|
|
sndKillAllSounds();
|
|
|
|
gStartNewGame = 1;
|
|
|
|
gInputMode = (INPUT_MODE)at1;
|
|
|
|
at0 = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
CKillMgr::CKillMgr()
|
|
|
|
{
|
|
|
|
Clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CKillMgr::SetCount(int nCount)
|
|
|
|
{
|
|
|
|
at0 = nCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CKillMgr::sub_263E0(int nCount)
|
|
|
|
{
|
|
|
|
at0 += nCount;
|
|
|
|
}
|
|
|
|
|
2019-10-13 22:29:19 +00:00
|
|
|
void CKillMgr::AddKill(spritetype* pSprite)
|
|
|
|
{
|
|
|
|
if (pSprite->statnum == kStatDude && pSprite->type != kDudeBat && pSprite->type != kDudeRat && pSprite->type != kDudeInnocent && pSprite->type != kDudeBurningInnocent)
|
|
|
|
at4++;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CKillMgr::sub_2641C(void)
|
|
|
|
{
|
|
|
|
at0 = 0;
|
|
|
|
for (int nSprite = headspritestat[kStatDude]; nSprite >= 0; nSprite = nextspritestat[nSprite])
|
|
|
|
{
|
|
|
|
spritetype* pSprite = &sprite[nSprite];
|
|
|
|
if (pSprite->type < kDudeBase || pSprite->type >= kDudeMax)
|
|
|
|
ThrowError("Non-enemy sprite (%d) in the enemy sprite list.", nSprite);
|
|
|
|
if (pSprite->statnum == kStatDude && pSprite->type != kDudeBat && pSprite->type != kDudeRat && pSprite->type != kDudeInnocent && pSprite->type != kDudeBurningInnocent)
|
|
|
|
at0++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2019-10-11 21:59:39 +00:00
|
|
|
void CKillMgr::AddKill(spritetype *pSprite) {
|
|
|
|
if (pSprite->statnum == kStatDude) {
|
|
|
|
switch (pSprite->type) {
|
|
|
|
case kDudeBat:
|
|
|
|
case kDudeRat:
|
|
|
|
case kDudeBurningInnocent:
|
|
|
|
case kDudeInnocent:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-09-19 22:42:45 +00:00
|
|
|
at4++;
|
2019-10-11 21:59:39 +00:00
|
|
|
}
|
2019-09-19 22:42:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void CKillMgr::sub_2641C(void)
|
|
|
|
{
|
|
|
|
at0 = 0;
|
2019-10-11 21:59:39 +00:00
|
|
|
for (int nSprite = headspritestat[kStatDude]; nSprite >= 0; nSprite = nextspritestat[nSprite]) {
|
|
|
|
|
2019-09-19 22:42:45 +00:00
|
|
|
spritetype *pSprite = &sprite[nSprite];
|
2019-10-12 20:45:46 +00:00
|
|
|
if (IsDudeSprite(pSprite)) {
|
|
|
|
if (pSprite->statnum == kStatDude) {
|
|
|
|
switch (pSprite->type) {
|
|
|
|
case kDudeBat:
|
|
|
|
case kDudeRat:
|
|
|
|
case kDudeBurningInnocent:
|
|
|
|
case kDudeInnocent:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
at0++;
|
2019-10-11 21:59:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-19 22:42:45 +00:00
|
|
|
}
|
|
|
|
}
|
2019-10-13 22:29:19 +00:00
|
|
|
*/
|
2019-09-19 22:42:45 +00:00
|
|
|
|
|
|
|
void CKillMgr::Draw(void)
|
|
|
|
{
|
|
|
|
char pBuffer[40];
|
|
|
|
if (gGameOptions.nGameType == 0)
|
|
|
|
{
|
|
|
|
viewDrawText(1, "KILLS:", 75, 50, -128, 0, 0, 1);
|
|
|
|
sprintf(pBuffer, "%2d", at4);
|
|
|
|
viewDrawText(1, pBuffer, 160, 50, -128, 0, 0, 1);
|
|
|
|
viewDrawText(1, "OF", 190, 50, -128, 0, 0, 1);
|
|
|
|
sprintf(pBuffer, "%2d", at0);
|
|
|
|
viewDrawText(1, pBuffer, 220, 50, -128, 0, 0, 1);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
viewDrawText(3, "#", 85, 35, -128, 0, 0, 1);
|
|
|
|
viewDrawText(3, "NAME", 100, 35, -128, 0, 0, 1);
|
|
|
|
viewDrawText(3, "FRAGS", 210, 35, -128, 0, 0, 1);
|
|
|
|
int nStart = 0;
|
|
|
|
int nEnd = gInitialNetPlayers;
|
|
|
|
//if (dword_28E3D4 == 1)
|
|
|
|
//{
|
|
|
|
// nStart++;
|
|
|
|
// nEnd++;
|
|
|
|
//}
|
|
|
|
for (int i = nStart; i < nEnd; i++)
|
|
|
|
{
|
|
|
|
sprintf(pBuffer, "%-2d", i);
|
|
|
|
viewDrawText(3, pBuffer, 85, 50+8*i, -128, 0, 0, 1);
|
|
|
|
sprintf(pBuffer, "%s", gProfile[i].name);
|
|
|
|
viewDrawText(3, pBuffer, 100, 50+8*i, -128, 0, 0, 1);
|
|
|
|
sprintf(pBuffer, "%d", gPlayer[i].at2c6);
|
|
|
|
viewDrawText(3, pBuffer, 210, 50+8*i, -128, 0, 0, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CKillMgr::Clear(void)
|
|
|
|
{
|
|
|
|
at0 = at4 = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
CSecretMgr::CSecretMgr(void)
|
|
|
|
{
|
|
|
|
Clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CSecretMgr::SetCount(int nCount)
|
|
|
|
{
|
|
|
|
at0 = nCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CSecretMgr::Found(int nType)
|
|
|
|
{
|
2019-10-12 20:45:46 +00:00
|
|
|
if (nType == 0) at4++;
|
|
|
|
else if (nType < 0) {
|
|
|
|
viewSetSystemMessage("Invalid secret type %d triggered.", nType);
|
|
|
|
return;
|
|
|
|
} else at8++;
|
|
|
|
|
|
|
|
if (gGameOptions.nGameType == 0) {
|
|
|
|
switch (Random(2)) {
|
|
|
|
case 0:
|
|
|
|
viewSetMessage("A secret is revealed.", 0, MESSAGE_PRIORITY_SECRET);
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
viewSetMessage("You found a secret.", 0, MESSAGE_PRIORITY_SECRET);
|
|
|
|
break;
|
2019-09-19 22:42:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CSecretMgr::Draw(void)
|
|
|
|
{
|
|
|
|
char pBuffer[40];
|
|
|
|
viewDrawText(1, "SECRETS:", 75, 70, -128, 0, 0, 1);
|
|
|
|
sprintf(pBuffer, "%2d", at4);
|
|
|
|
viewDrawText(1, pBuffer, 160, 70, -128, 0, 0, 1);
|
|
|
|
viewDrawText(1, "OF", 190, 70, -128, 0, 0, 1);
|
|
|
|
sprintf(pBuffer, "%2d", at0);
|
|
|
|
viewDrawText(1, pBuffer, 220, 70, -128, 0, 0, 1);
|
|
|
|
if (at8 > 0)
|
|
|
|
viewDrawText(1, "YOU FOUND A SUPER SECRET!", 160, 100, -128, 2, 1, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CSecretMgr::Clear(void)
|
|
|
|
{
|
|
|
|
at0 = at4 = at8 = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
class EndGameLoadSave : public LoadSave {
|
|
|
|
public:
|
|
|
|
virtual void Load(void);
|
|
|
|
virtual void Save(void);
|
|
|
|
};
|
|
|
|
|
|
|
|
void EndGameLoadSave::Load(void)
|
|
|
|
{
|
|
|
|
Read(&gSecretMgr.at0, 4);
|
|
|
|
Read(&gSecretMgr.at4, 4);
|
|
|
|
Read(&gSecretMgr.at8, 4);
|
|
|
|
Read(&gKillMgr.at0, 4);
|
|
|
|
Read(&gKillMgr.at4, 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
void EndGameLoadSave::Save(void)
|
|
|
|
{
|
|
|
|
Write(&gSecretMgr.at0, 4);
|
|
|
|
Write(&gSecretMgr.at4, 4);
|
|
|
|
Write(&gSecretMgr.at8, 4);
|
|
|
|
Write(&gKillMgr.at0, 4);
|
|
|
|
Write(&gKillMgr.at4, 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
CEndGameMgr gEndGameMgr;
|
|
|
|
CSecretMgr gSecretMgr;
|
|
|
|
CKillMgr gKillMgr;
|
|
|
|
static EndGameLoadSave *myLoadSave;
|
|
|
|
|
|
|
|
void EndGameLoadSaveConstruct(void)
|
|
|
|
{
|
|
|
|
myLoadSave = new EndGameLoadSave();
|
|
|
|
}
|
2019-09-22 06:39:22 +00:00
|
|
|
|
|
|
|
END_BLD_NS
|