mirror of
https://git.rip/DMCA_FUCKER/re3.git
synced 2025-01-11 03:24:10 +00:00
Lil update.
This commit is contained in:
parent
9fed0c040c
commit
29767c1964
|
@ -8,5 +8,6 @@ public:
|
||||||
static int32 &NumberKillFrenziesPassed;
|
static int32 &NumberKillFrenziesPassed;
|
||||||
static int32 &PeopleKilledByOthers;
|
static int32 &PeopleKilledByOthers;
|
||||||
|
|
||||||
|
public:
|
||||||
static void AnotherKillFrenzyPassed();
|
static void AnotherKillFrenzyPassed();
|
||||||
};
|
};
|
|
@ -30,22 +30,22 @@ int32 &CDarkel::ModelToKill3 = *(int32*)0x885B3C;
|
||||||
int32 &CDarkel::ModelToKill4 = *(int32*)0x885B34;
|
int32 &CDarkel::ModelToKill4 = *(int32*)0x885B34;
|
||||||
wchar *CDarkel::pStartMessage = (wchar*)0x8F2C08;
|
wchar *CDarkel::pStartMessage = (wchar*)0x8F2C08;
|
||||||
|
|
||||||
int32 CDarkel::CalcFade(uint32 time, int32 min, uint32 max) {
|
int32 CDarkel::CalcFade(uint32 time, int32 start, uint32 end) {
|
||||||
if (time >= min && time <= max) {
|
if (time >= start && time <= end) {
|
||||||
if (time >= min + 500) {
|
if (time >= start + 500) {
|
||||||
if (time <= max - 500)
|
if (time <= end - 500)
|
||||||
return -1;
|
return 0;
|
||||||
else
|
else
|
||||||
return 255 * (max - time) / 500;
|
return 255 * (end - time) / 500;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return 255 * (time - min) / 500;
|
return 255 * (time - start) / 500;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This function has been cleaned up from unused stuff.
|
||||||
#if 0
|
#if 0
|
||||||
WRAPPER void CDarkel::DrawMessages(void) { EAXJMP(0x420920); }
|
WRAPPER void CDarkel::DrawMessages(void) { EAXJMP(0x420920); }
|
||||||
#else
|
#else
|
||||||
|
@ -101,7 +101,7 @@ void CDarkel::DrawMessages()
|
||||||
|
|
||||||
void CDarkel::Init()
|
void CDarkel::Init()
|
||||||
{
|
{
|
||||||
Status = KILLFRENZY_INIT;
|
Status = KILLFRENZY_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
int16 CDarkel::QueryModelsKilledByPlayer(int32 modelId)
|
int16 CDarkel::QueryModelsKilledByPlayer(int32 modelId)
|
||||||
|
@ -121,16 +121,24 @@ eKillFrenzyStatus CDarkel::ReadStatus()
|
||||||
return Status;
|
return Status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
WRAPPER int32 CDarkel::RegisterCarBlownUpByPlayer(eKillFrenzyStatus status) { EAXJMP(0x421070); }
|
||||||
|
#else
|
||||||
int32 CDarkel::RegisterCarBlownUpByPlayer(eKillFrenzyStatus status)
|
int32 CDarkel::RegisterCarBlownUpByPlayer(eKillFrenzyStatus status)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
WRAPPER void CDarkel::RegisterKillByPlayer(int32 modelid, eWeaponType weapontype, bool flag) { EAXJMP(0x420F60); }
|
||||||
|
#else
|
||||||
void CDarkel::RegisterKillByPlayer(int32 modelid, eWeaponType weapontype, bool flag)
|
void CDarkel::RegisterKillByPlayer(int32 modelid, eWeaponType weapontype, bool flag)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void CDarkel::RegisterKillNotByPlayer()
|
void CDarkel::RegisterKillNotByPlayer()
|
||||||
{
|
{
|
||||||
|
@ -139,49 +147,62 @@ void CDarkel::RegisterKillNotByPlayer()
|
||||||
|
|
||||||
void CDarkel::ResetModelsKilledByPlayer()
|
void CDarkel::ResetModelsKilledByPlayer()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 200; i++) {
|
for (int i = 0; i < 200; i++)
|
||||||
for (int j = 0; j < 8; j++)
|
RegisteredKills[i] = 0;
|
||||||
RegisteredKills[i + j] = 0;
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
WRAPPER void CDarkel::ResetOnPlayerDeath() { EAXJMP(0x420E70); }
|
||||||
|
#else
|
||||||
void CDarkel::ResetOnPlayerDeath()
|
void CDarkel::ResetOnPlayerDeath()
|
||||||
{
|
{
|
||||||
eWeaponType &EWeaponType = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
if (Status != KILLFRENZY_ONGOING)
|
||||||
int32 &CurrentWeapon = CWeaponInfo::GetWeaponInfo(FindPlayerPed()->GetWeapon()->m_eWeaponType)->m_nModelId;
|
return;
|
||||||
int32 &CurrentDarkelWeapon = CDarkel::WeaponType;
|
|
||||||
uint32 &TotalAmmo = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal;
|
|
||||||
|
|
||||||
if (Status == KILLFRENZY_ONGOING) {
|
|
||||||
CPopulation::m_AllRandomPedsThisType = -1;
|
CPopulation::m_AllRandomPedsThisType = -1;
|
||||||
Status = KILLFRENZY_FAILED;
|
Status = KILLFRENZY_FAILED;
|
||||||
TimeOfFrenzyStart = CTimer::GetTimeInMilliseconds();
|
TimeOfFrenzyStart = CTimer::GetTimeInMilliseconds();
|
||||||
|
|
||||||
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
||||||
CurrentDarkelWeapon = WEAPONTYPE_UZI;
|
WeaponType = WEAPONTYPE_UZI;
|
||||||
|
|
||||||
if (CurrentDarkelWeapon < WEAPONTYPE_TOTALWEAPONS) {
|
if (WeaponType < WEAPONTYPE_TOTALWEAPONS) {
|
||||||
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
||||||
TotalAmmo = AmmoInterruptedWeapon;
|
CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal = AmmoInterruptedWeapon;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FindPlayerVehicle()) {
|
if (FindPlayerVehicle()) {
|
||||||
FindPlayerPed()->RemoveWeaponModel(CurrentWeapon);
|
FindPlayerPed()->RemoveWeaponModel(CWeaponInfo::GetWeaponInfo(FindPlayerPed()->GetWeapon()->m_eWeaponType)->m_nModelId);
|
||||||
FindPlayerPed()->m_currentWeapon = EWeaponType;
|
FindPlayerPed()->m_currentWeapon = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
||||||
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
CPopulation::m_AllRandomPedsThisType = -1;
|
||||||
|
Status = KILLFRENZY_FAILED;
|
||||||
|
TimeOfFrenzyStart = CTimer::GetTimeInMilliseconds();
|
||||||
|
|
||||||
|
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
||||||
|
WeaponType = WEAPONTYPE_UZI;
|
||||||
|
|
||||||
|
if (WeaponType < WEAPONTYPE_TOTALWEAPONS) {
|
||||||
|
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
||||||
|
CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal = AmmoInterruptedWeapon;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (FindPlayerVehicle()) {
|
||||||
|
FindPlayerPed()->RemoveWeaponModel(CWeaponInfo::GetWeaponInfo(FindPlayerPed()->GetWeapon()->m_eWeaponType)->m_nModelId);
|
||||||
|
FindPlayerPed()->m_currentWeapon = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
||||||
|
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
WRAPPER void CDarkel::StartFrenzy(eWeaponType weaponType, int32 time, int16 kill, int32 modelId0, wchar *text, int32 modelId2, int32 modelId3, int32 modelId4, bool standardSound, bool needHeadShot) { EAXJMP(0x4210E0); }
|
WRAPPER void CDarkel::StartFrenzy(eWeaponType weaponType, int32 time, int16 kill, int32 modelId0, wchar *text, int32 modelId2, int32 modelId3, int32 modelId4, bool standardSound, bool needHeadShot) { EAXJMP(0x4210E0); }
|
||||||
#else
|
#else
|
||||||
void CDarkel::StartFrenzy(eWeaponType weaponType, int32 time, int16 kill, int32 modelId0, wchar *text, int32 modelId2, int32 modelId3, int32 modelId4, bool standardSound, bool needHeadShot)
|
void CDarkel::StartFrenzy(eWeaponType weaponType, int32 time, int16 kill, int32 modelId0, wchar *text, int32 modelId2, int32 modelId3, int32 modelId4, bool standardSound, bool needHeadShot)
|
||||||
{
|
{
|
||||||
eWeaponType &EWeaponType = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
|
||||||
uint32 &TotalAmmo = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal;
|
|
||||||
uint32 &AmmoInClip = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoInClip;
|
|
||||||
|
|
||||||
if (weaponType == WEAPONTYPE_UZI_DRIVEBY)
|
if (weaponType == WEAPONTYPE_UZI_DRIVEBY)
|
||||||
weaponType = WEAPONTYPE_UZI;
|
weaponType = WEAPONTYPE_UZI;
|
||||||
|
|
||||||
|
@ -210,15 +231,15 @@ void CDarkel::StartFrenzy(eWeaponType weaponType, int32 time, int16 kill, int32
|
||||||
if (weaponType < WEAPONTYPE_TOTALWEAPONS) {
|
if (weaponType < WEAPONTYPE_TOTALWEAPONS) {
|
||||||
InterruptedWeapon = FindPlayerPed()->m_currentWeapon;
|
InterruptedWeapon = FindPlayerPed()->m_currentWeapon;
|
||||||
FindPlayerPed()->GiveWeapon(weaponType, 0);
|
FindPlayerPed()->GiveWeapon(weaponType, 0);
|
||||||
AmmoInterruptedWeapon = TotalAmmo;
|
AmmoInterruptedWeapon = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal;
|
||||||
FindPlayerPed()->GiveWeapon(weaponType, 30000);
|
FindPlayerPed()->GiveWeapon(weaponType, 30000);
|
||||||
FindPlayerPed()->m_bWeaponSlot = EWeaponType;
|
FindPlayerPed()->m_bWeaponSlot = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
||||||
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_bWeaponSlot);
|
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_bWeaponSlot);
|
||||||
|
|
||||||
if (FindPlayerVehicle()) {
|
if (FindPlayerVehicle()) {
|
||||||
FindPlayerPed()->m_currentWeapon = EWeaponType;
|
FindPlayerPed()->m_currentWeapon = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
||||||
if (TotalAmmo <= AmmoInClip)
|
if (CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal <= CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoInClip)
|
||||||
AmmoInClip = TotalAmmo;
|
CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoInClip = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal;
|
||||||
|
|
||||||
FindPlayerPed()->ClearWeaponTarget();
|
FindPlayerPed()->ClearWeaponTarget();
|
||||||
}
|
}
|
||||||
|
@ -230,12 +251,9 @@ void CDarkel::StartFrenzy(eWeaponType weaponType, int32 time, int16 kill, int32
|
||||||
|
|
||||||
void CDarkel::Update()
|
void CDarkel::Update()
|
||||||
{
|
{
|
||||||
eWeaponType &EWeaponType = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
if (Status != KILLFRENZY_ONGOING)
|
||||||
int32 &CurrentWeapon = CWeaponInfo::GetWeaponInfo(FindPlayerPed()->GetWeapon()->m_eWeaponType)->m_nModelId;
|
return;
|
||||||
int32 &CurrentDarkelWeapon = CDarkel::WeaponType;
|
|
||||||
uint32 &TotalAmmo = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal;
|
|
||||||
|
|
||||||
if (Status == KILLFRENZY_ONGOING) {
|
|
||||||
int32 FrameTime = TimeLimit - (CTimer::GetTimeInMilliseconds() - TimeOfFrenzyStart);
|
int32 FrameTime = TimeLimit - (CTimer::GetTimeInMilliseconds() - TimeOfFrenzyStart);
|
||||||
if ((TimeLimit - (CTimer::GetTimeInMilliseconds() - TimeOfFrenzyStart)) > 0 || TimeLimit < 0) {
|
if ((TimeLimit - (CTimer::GetTimeInMilliseconds() - TimeOfFrenzyStart)) > 0 || TimeLimit < 0) {
|
||||||
DMAudio.PlayFrontEndSound(SOUND_RAMPAGE_ONGOING, FrameTime);
|
DMAudio.PlayFrontEndSound(SOUND_RAMPAGE_ONGOING, FrameTime);
|
||||||
|
@ -255,16 +273,16 @@ void CDarkel::Update()
|
||||||
TimeOfFrenzyStart = CTimer::GetTimeInMilliseconds();
|
TimeOfFrenzyStart = CTimer::GetTimeInMilliseconds();
|
||||||
|
|
||||||
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
||||||
CurrentDarkelWeapon = WEAPONTYPE_UZI;
|
WeaponType = WEAPONTYPE_UZI;
|
||||||
|
|
||||||
if (CurrentDarkelWeapon < WEAPONTYPE_TOTALWEAPONS) {
|
if (WeaponType < WEAPONTYPE_TOTALWEAPONS) {
|
||||||
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
||||||
TotalAmmo = AmmoInterruptedWeapon;
|
CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal = AmmoInterruptedWeapon;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FindPlayerVehicle()) {
|
if (FindPlayerVehicle()) {
|
||||||
FindPlayerPed()->RemoveWeaponModel(CurrentWeapon);
|
FindPlayerPed()->RemoveWeaponModel(CWeaponInfo::GetWeaponInfo(FindPlayerPed()->GetWeapon()->m_eWeaponType)->m_nModelId);
|
||||||
FindPlayerPed()->m_currentWeapon = EWeaponType;
|
FindPlayerPed()->m_currentWeapon = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
||||||
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -284,23 +302,22 @@ void CDarkel::Update()
|
||||||
FindPlayerPed()->m_pWanted->SetWantedLevel(NOTWANTED);
|
FindPlayerPed()->m_pWanted->SetWantedLevel(NOTWANTED);
|
||||||
|
|
||||||
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
if (WeaponType == WEAPONTYPE_UZI_DRIVEBY)
|
||||||
CurrentDarkelWeapon = WEAPONTYPE_UZI;
|
WeaponType = WEAPONTYPE_UZI;
|
||||||
|
|
||||||
if (CurrentDarkelWeapon < WEAPONTYPE_TOTALWEAPONS) {
|
if (WeaponType < WEAPONTYPE_TOTALWEAPONS) {
|
||||||
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
FindPlayerPed()->m_bWeaponSlot = InterruptedWeapon;
|
||||||
TotalAmmo = AmmoInterruptedWeapon;
|
CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_nAmmoTotal = AmmoInterruptedWeapon;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FindPlayerVehicle()) {
|
if (FindPlayerVehicle()) {
|
||||||
FindPlayerPed()->RemoveWeaponModel(CurrentWeapon);
|
FindPlayerPed()->RemoveWeaponModel(CWeaponInfo::GetWeaponInfo(FindPlayerPed()->GetWeapon()->m_eWeaponType)->m_nModelId);
|
||||||
FindPlayerPed()->m_currentWeapon = EWeaponType;
|
FindPlayerPed()->m_currentWeapon = CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_weapons[CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_currentWeapon].m_eWeaponType;
|
||||||
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
FindPlayerPed()->MakeChangesForNewWeapon(FindPlayerPed()->m_currentWeapon);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bStandardSoundAndMessages)
|
if (bStandardSoundAndMessages)
|
||||||
DMAudio.PlayFrontEndSound(SOUND_RAMPAGE_PASSED, 0);
|
DMAudio.PlayFrontEndSound(SOUND_RAMPAGE_PASSED, 0);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
STARTPATCHES
|
STARTPATCHES
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
enum eKillFrenzyStatus
|
enum eKillFrenzyStatus
|
||||||
{
|
{
|
||||||
KILLFRENZY_INIT,
|
KILLFRENZY_NONE,
|
||||||
KILLFRENZY_ONGOING,
|
KILLFRENZY_ONGOING,
|
||||||
KILLFRENZY_PASSED,
|
KILLFRENZY_PASSED,
|
||||||
KILLFRENZY_FAILED,
|
KILLFRENZY_FAILED,
|
||||||
|
|
Loading…
Reference in a new issue