mirror of
https://github.com/CookiePLMonster/SilentPatch.git
synced 2024-12-28 23:03:01 +05:00
Basketball fix
Gym glitch fix Shaders are now a toggle Twopass as a toggle SilentpatchIII fixed
This commit is contained in:
parent
4d97733c03
commit
d226dcc055
7 changed files with 247 additions and 32 deletions
|
@ -95,6 +95,7 @@
|
||||||
<ClCompile Include="..\SilentPatch\General.cpp" />
|
<ClCompile Include="..\SilentPatch\General.cpp" />
|
||||||
<ClCompile Include="..\SilentPatch\ModelInfoSA.cpp" />
|
<ClCompile Include="..\SilentPatch\ModelInfoSA.cpp" />
|
||||||
<ClCompile Include="..\SilentPatch\PNGFile.cpp" />
|
<ClCompile Include="..\SilentPatch\PNGFile.cpp" />
|
||||||
|
<ClCompile Include="..\SilentPatch\Script.cpp" />
|
||||||
<ClCompile Include="..\SilentPatch\StdAfx.cpp">
|
<ClCompile Include="..\SilentPatch\StdAfx.cpp">
|
||||||
<PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Create</PrecompiledHeader>
|
<PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Create</PrecompiledHeader>
|
||||||
<PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Create</PrecompiledHeader>
|
<PrecompiledHeader Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Create</PrecompiledHeader>
|
||||||
|
@ -128,6 +129,7 @@
|
||||||
<ClInclude Include="..\SilentPatch\MemoryMgr.h" />
|
<ClInclude Include="..\SilentPatch\MemoryMgr.h" />
|
||||||
<ClInclude Include="..\SilentPatch\ModelInfoSA.h" />
|
<ClInclude Include="..\SilentPatch\ModelInfoSA.h" />
|
||||||
<ClInclude Include="..\SilentPatch\PNGFile.h" />
|
<ClInclude Include="..\SilentPatch\PNGFile.h" />
|
||||||
|
<ClInclude Include="..\SilentPatch\Script.h" />
|
||||||
<ClInclude Include="..\SilentPatch\StdAfx.h" />
|
<ClInclude Include="..\SilentPatch\StdAfx.h" />
|
||||||
<ClInclude Include="..\SilentPatch\Timer.h" />
|
<ClInclude Include="..\SilentPatch\Timer.h" />
|
||||||
<ClInclude Include="..\SilentPatch\Vehicle.h" />
|
<ClInclude Include="..\SilentPatch\Vehicle.h" />
|
||||||
|
|
|
@ -45,6 +45,9 @@
|
||||||
<ClCompile Include="..\SilentPatch\AudioHardware.cpp">
|
<ClCompile Include="..\SilentPatch\AudioHardware.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\SilentPatch\Script.cpp">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="..\SilentPatch\win2000.asm">
|
<None Include="..\SilentPatch\win2000.asm">
|
||||||
|
@ -100,6 +103,9 @@
|
||||||
<ClInclude Include="..\SilentPatch\AudioHardware.h">
|
<ClInclude Include="..\SilentPatch\AudioHardware.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\SilentPatch\Script.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<CustomBuild Include="..\SilentPatch\nvc.fx">
|
<CustomBuild Include="..\SilentPatch\nvc.fx">
|
||||||
|
|
|
@ -40,8 +40,6 @@ unsigned int CAEDataStream::Seek(long nToSeek, int nPoint)
|
||||||
|
|
||||||
unsigned int CAEDataStream::FillBuffer(void* pBuf, unsigned long nLen)
|
unsigned int CAEDataStream::FillBuffer(void* pBuf, unsigned long nLen)
|
||||||
{
|
{
|
||||||
//auto nSize = min(nLen, dwCurrentPosition - dwLength - dwStartPosition);
|
|
||||||
//auto nHah = dwCurrentPosition - dwLength - dwStartPosition;
|
|
||||||
ReadFile(hHandle, pBuf, nLen, &nLen, nullptr);
|
ReadFile(hHandle, pBuf, nLen, &nLen, nullptr);
|
||||||
|
|
||||||
dwCurrentPosition += nLen;
|
dwCurrentPosition += nLen;
|
||||||
|
@ -111,7 +109,7 @@ bool CAEWaveDecoder::Initialise()
|
||||||
|
|
||||||
nDataSize = chunkHeader.sectionSize;
|
nDataSize = chunkHeader.sectionSize;
|
||||||
|
|
||||||
return formatChunk.numChannels <= 2 && (formatChunk.bitsPerSample == 8 || formatChunk.bitsPerSample == 16 || formatChunk.bitsPerSample == 24);
|
return formatChunk.sampleRate <= 48000 && formatChunk.numChannels <= 2 && (formatChunk.bitsPerSample == 8 || formatChunk.bitsPerSample == 16 || formatChunk.bitsPerSample == 24);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int CAEWaveDecoder::FillBuffer(void* pBuf, unsigned long nLen)
|
unsigned int CAEWaveDecoder::FillBuffer(void* pBuf, unsigned long nLen)
|
||||||
|
|
22
SilentPatch/Script.cpp
Normal file
22
SilentPatch/Script.cpp
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
#include "StdAfx.h"
|
||||||
|
#include "Script.h"
|
||||||
|
|
||||||
|
static int* StatTypesInt = *(int**)0x55C0D8;
|
||||||
|
|
||||||
|
std::pair<int,int>* CRunningScript::GetDay_GymGlitch()
|
||||||
|
{
|
||||||
|
static std::pair<int,int> Out;
|
||||||
|
|
||||||
|
if ( !strncmp(Name, "gymbike", 8) || !strncmp(Name, "gymbenc", 8) || !strncmp(Name, "gymtrea", 8) || !strncmp(Name, "gymdumb", 8) )
|
||||||
|
{
|
||||||
|
Out.first = 0xFFFFFFFF;
|
||||||
|
Out.second = StatTypesInt[134-120];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Out.first = nGameClockMonths;
|
||||||
|
Out.second = nGameClockDays;
|
||||||
|
}
|
||||||
|
|
||||||
|
return &Out;
|
||||||
|
}
|
75
SilentPatch/Script.h
Normal file
75
SilentPatch/Script.h
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
#ifndef __CRUNNINGSCRIPT
|
||||||
|
#define __CRUNNINGSCRIPT
|
||||||
|
|
||||||
|
#define NUM_SCRIPTS 96
|
||||||
|
#define GOSUB_STACK_SIZE 8
|
||||||
|
|
||||||
|
union SCRIPT_VAR
|
||||||
|
{
|
||||||
|
DWORD dwParam;
|
||||||
|
int iParam;
|
||||||
|
WORD wParam;
|
||||||
|
BYTE bParam;
|
||||||
|
float fParam;
|
||||||
|
void* pParam;
|
||||||
|
char* pcParam;
|
||||||
|
};
|
||||||
|
|
||||||
|
enum eOperandType
|
||||||
|
{
|
||||||
|
globalVar = 2,
|
||||||
|
localVar = 3,
|
||||||
|
globalArr = 7,
|
||||||
|
localArr = 8,
|
||||||
|
imm8 = 4,
|
||||||
|
imm16 = 5,
|
||||||
|
imm32 = 6,
|
||||||
|
imm32f = 1,
|
||||||
|
vstring = 0x0E,
|
||||||
|
sstring = 9,
|
||||||
|
globalVarVString = 0x10,
|
||||||
|
localVarVString = 0x11,
|
||||||
|
globalVarSString = 0x0A,
|
||||||
|
localVarSString = 0x0B,
|
||||||
|
globalVarSArrString = 0x0C,
|
||||||
|
localVarSArrString = 0x0D,
|
||||||
|
globalVarVArrString = 0x12,
|
||||||
|
localVarVArrString = 0x13,
|
||||||
|
lstring = 0x0F
|
||||||
|
};
|
||||||
|
|
||||||
|
class CRunningScript
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
CRunningScript* Previous;
|
||||||
|
CRunningScript* Next;
|
||||||
|
char Name[8];
|
||||||
|
void* BaseIP;
|
||||||
|
void* CurrentIP;
|
||||||
|
void* Stack[GOSUB_STACK_SIZE];
|
||||||
|
WORD SP;
|
||||||
|
SCRIPT_VAR LocalVar[34];
|
||||||
|
bool bIsActive;
|
||||||
|
bool bCondResult;
|
||||||
|
bool bUseMissionCleanup;
|
||||||
|
bool bIsExternal;
|
||||||
|
bool bTextBlockOverride;
|
||||||
|
signed char extrnAttachType;
|
||||||
|
DWORD WakeTime;
|
||||||
|
WORD LogicalOp;
|
||||||
|
bool NotFlag;
|
||||||
|
bool bWastedBustedCheck;
|
||||||
|
bool bWastedOrBusted;
|
||||||
|
void* SceneSkipIP;
|
||||||
|
bool bIsMission;
|
||||||
|
/* CLEO class extension */
|
||||||
|
BYTE scmFunction[2];
|
||||||
|
BYTE IsCustom;
|
||||||
|
|
||||||
|
public:
|
||||||
|
std::pair<int,int>* GetDay_GymGlitch();
|
||||||
|
};
|
||||||
|
|
||||||
|
static_assert(sizeof(CRunningScript) == 0xE0, "Wrong size: CRunningScript");
|
||||||
|
|
||||||
|
#endif
|
|
@ -28,6 +28,9 @@
|
||||||
// SA operator delete
|
// SA operator delete
|
||||||
void GTAdelete(void* data);
|
void GTAdelete(void* data);
|
||||||
|
|
||||||
|
extern unsigned char& nGameClockDays;
|
||||||
|
extern unsigned char& nGameClockMonths;
|
||||||
|
|
||||||
//#define HIDE_MATERIAL
|
//#define HIDE_MATERIAL
|
||||||
//#define EXPAND_ALPHA_ENTITY_LISTS 800
|
//#define EXPAND_ALPHA_ENTITY_LISTS 800
|
||||||
//#define EXPAND_BOAT_ALPHA_ATOMIC_LISTS 400
|
//#define EXPAND_BOAT_ALPHA_ATOMIC_LISTS 400
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
#include "LinkList.h"
|
#include "LinkList.h"
|
||||||
#include "ModelInfoSA.h"
|
#include "ModelInfoSA.h"
|
||||||
#include "AudioHardware.h"
|
#include "AudioHardware.h"
|
||||||
|
#include "Script.h"
|
||||||
|
|
||||||
struct RsGlobalType
|
struct RsGlobalType
|
||||||
{
|
{
|
||||||
|
@ -762,7 +763,7 @@ __forceinline void Patch_III_Steam()
|
||||||
InjectHook(0x507D60, AlteredPrintString<0x507D59,0x507D2E>);
|
InjectHook(0x507D60, AlteredPrintString<0x507D59,0x507D2E>);
|
||||||
InjectHook(0x508061, AlteredPrintStringYOnly<0x508024>);
|
InjectHook(0x508061, AlteredPrintStringYOnly<0x508024>);
|
||||||
InjectHook(0x508CDE, AlteredPrintString<0x508CD7,0x508CB6>);
|
InjectHook(0x508CDE, AlteredPrintString<0x508CD7,0x508CB6>);
|
||||||
InjectHook(0x508F7B, AlteredPrintStringXOnly<0x508F72>);
|
InjectHook(0x508F79, AlteredPrintStringXOnly<0x508F72>);
|
||||||
InjectHook(0x426446, AlteredPrintString<0x42643F,0x426418>);
|
InjectHook(0x426446, AlteredPrintString<0x42643F,0x426418>);
|
||||||
InjectHook(0x426584, AlteredPrintString<0x42657D,0x426556>);
|
InjectHook(0x426584, AlteredPrintString<0x42657D,0x426556>);
|
||||||
InjectHook(0x42665F, AlteredPrintStringMinus<0x426658,0x426637>);
|
InjectHook(0x42665F, AlteredPrintStringMinus<0x426658,0x426637>);
|
||||||
|
@ -1007,7 +1008,8 @@ static const BYTE gMoonMaskPNG[] = {
|
||||||
// TODO: EXEs
|
// TODO: EXEs
|
||||||
#ifndef SA_STEAM_TEST
|
#ifndef SA_STEAM_TEST
|
||||||
|
|
||||||
static unsigned char& nGameClockDays = **(unsigned char**)0x4E841D;
|
unsigned char& nGameClockDays = **(unsigned char**)0x4E841D;
|
||||||
|
unsigned char& nGameClockMonths = **(unsigned char**)0x4E842D;
|
||||||
static float& fFarClipZ = **(float**)0x70D21F;
|
static float& fFarClipZ = **(float**)0x70D21F;
|
||||||
static RwTexture** const gpCoronaTexture = *(RwTexture***)0x6FAA8C;
|
static RwTexture** const gpCoronaTexture = *(RwTexture***)0x6FAA8C;
|
||||||
static int& MoonSize = **(int**)0x713B0C;
|
static int& MoonSize = **(int**)0x713B0C;
|
||||||
|
@ -1017,7 +1019,7 @@ static RwTexture* gpMoonMask = nullptr;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
static unsigned char& nGameClockDays = *(unsigned char*)0xBFCC60;
|
unsigned char& nGameClockDays = *(unsigned char*)0xBFCC60;
|
||||||
static float& fFarClipZ = *(float*)0xCCE6F8;
|
static float& fFarClipZ = *(float*)0xCCE6F8;
|
||||||
static RwTexture** const gpCoronaTexture = (RwTexture**)0xCCD768;
|
static RwTexture** const gpCoronaTexture = (RwTexture**)0xCCD768;
|
||||||
static int& MoonSize = *(int*)0x9499F4;
|
static int& MoonSize = *(int*)0x9499F4;
|
||||||
|
@ -1336,7 +1338,7 @@ void __declspec(naked) ResetAlphaFuncRefAfterRender()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool bUseTwoPass = true;
|
static bool bUseTwoPass;
|
||||||
|
|
||||||
void SetRendererForAtomic(RpAtomic* pAtomic)
|
void SetRendererForAtomic(RpAtomic* pAtomic)
|
||||||
{
|
{
|
||||||
|
@ -1858,35 +1860,132 @@ FLACInit_DontFallBack:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static BOOL (*IsAlreadyRunning)();
|
||||||
|
static void (*TheScriptsLoad)();
|
||||||
|
|
||||||
|
static unsigned char* ScriptSpace = *(unsigned char**)0x5D5380;
|
||||||
|
static int* ScriptParams = *(int**)0x48995B;
|
||||||
|
|
||||||
|
static void BasketballFix(unsigned char* pBuf, int nSize)
|
||||||
|
{
|
||||||
|
for ( int i = 0, hits = 0; i < nSize && hits < 7; i++, pBuf++ )
|
||||||
|
{
|
||||||
|
// Pattern check for save pickup XYZ
|
||||||
|
if ( *(unsigned int*)pBuf == 0x449DE19A ) // Save pickup X
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = 1291.8f;
|
||||||
|
}
|
||||||
|
else if ( *(unsigned int*)pBuf == 0xC4416AE1 ) // Save pickup Y
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = -797.8284f;
|
||||||
|
}
|
||||||
|
else if ( *(unsigned int*)pBuf == 0x44886C7B ) // Save pickup Z
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = 1089.5f;
|
||||||
|
}
|
||||||
|
else if ( *(unsigned int*)pBuf == 0x449DF852 ) // Save point X
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = 1286.8f;
|
||||||
|
}
|
||||||
|
else if ( *(unsigned int*)pBuf == 0xC44225C3 ) // Save point Y
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = -797.69f;
|
||||||
|
}
|
||||||
|
else if ( *(unsigned int*)pBuf == 0x44885C7B ) // Save point Z
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = 1089.1f;
|
||||||
|
}
|
||||||
|
else if ( *(unsigned int*)pBuf == 0x43373AE1 ) // Save point A
|
||||||
|
{
|
||||||
|
hits++;
|
||||||
|
*(float*)pBuf = 90.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void TheScriptsLoad_BasketballFix()
|
||||||
|
{
|
||||||
|
TheScriptsLoad();
|
||||||
|
|
||||||
|
BasketballFix(ScriptSpace+8, *(int*)(ScriptSpace+3));
|
||||||
|
}
|
||||||
|
|
||||||
|
void StartNewMission_BasketballFix()
|
||||||
|
{
|
||||||
|
if ( ScriptParams[0] == 0 )
|
||||||
|
BasketballFix(ScriptSpace+200000, 69000);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOL InjectDelayedPatches_10()
|
||||||
|
{
|
||||||
|
if ( !IsAlreadyRunning() )
|
||||||
|
{
|
||||||
|
using namespace MemoryVP;
|
||||||
|
|
||||||
|
bUseTwoPass = GetPrivateProfileInt("SilentPatch", "TwoPassRendering", FALSE, ".\\SilentPatchSA.ini") != FALSE;
|
||||||
|
|
||||||
|
if ( GetPrivateProfileInt("SilentPatch", "EnableScriptFixes", TRUE, ".\\SilentPatchSA.ini") != FALSE )
|
||||||
|
{
|
||||||
|
// Gym glitch fix
|
||||||
|
Patch<WORD>(0x470B03, 0xCD8B);
|
||||||
|
Patch<DWORD>(0x470B0A, 0x8B04508B);
|
||||||
|
Patch<WORD>(0x470B0E, 0x9000);
|
||||||
|
Nop(0x470B10, 1);
|
||||||
|
InjectMethodVP(0x470B05, CRunningScript::GetDay_GymGlitch, PATCH_CALL);
|
||||||
|
|
||||||
|
// Basketball fix
|
||||||
|
TheScriptsLoad = (void(*)())(*(int*)0x5D18F1 + 0x5D18F0 + 5);
|
||||||
|
InjectHook(0x5D18F0, TheScriptsLoad_BasketballFix);
|
||||||
|
InjectHook(0x464BC0, StartNewMission_BasketballFix, PATCH_JUMP);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( GetPrivateProfileInt("SilentPatch", "NVCShader", TRUE, ".\\SilentPatchSA.ini") != FALSE )
|
||||||
|
{
|
||||||
|
// Shaders!
|
||||||
|
InjectHook(0x5DA743, SetShader);
|
||||||
|
InjectHook(0x5D66F1, SetShader2);
|
||||||
|
InjectHook(0x5D6116, UsageIndex1, PATCH_JUMP);
|
||||||
|
InjectHook(0x5D63B7, PassDayColoursToShader, PATCH_JUMP);
|
||||||
|
InjectHook(0x5D637B, HijackEsi, PATCH_JUMP);
|
||||||
|
InjectHook(0x5BF3A1, ShaderAttach);
|
||||||
|
InjectHook(0x53D910, ShaderDetach);
|
||||||
|
Patch<const void*>(0x5D67F4, HijackAtomic);
|
||||||
|
Patch<BYTE>(0x5D7200, 0xC3);
|
||||||
|
Patch<WORD>(0x5D67BB, 0x6890);
|
||||||
|
Patch<WORD>(0x5D67D7, 0x6890);
|
||||||
|
Patch<DWORD>(0x5D67BD, 0x5D5FE0);
|
||||||
|
Patch<DWORD>(0x5D67D9, 0x5D5FE0);
|
||||||
|
Patch<DWORD>(0x5DA73F, 0x90909056);
|
||||||
|
|
||||||
|
Patch<BYTE>(0x5D60D9, D3DDECLTYPE_D3DCOLOR);
|
||||||
|
Patch<BYTE>(0x5D60E2, D3DDECLUSAGE_COLOR);
|
||||||
|
Patch<BYTE>(0x5D60CF, sizeof(D3DCOLOR));
|
||||||
|
Patch<BYTE>(0x5D60EA, sizeof(D3DCOLOR));
|
||||||
|
Patch<BYTE>(0x5D60C2, 0x13);
|
||||||
|
Patch<BYTE>(0x5D62F0, 0xEB);
|
||||||
|
|
||||||
|
// PostFX fix
|
||||||
|
Patch<float>(*(float**)0x7034C0, 0.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
__forceinline void Patch_SA_10()
|
__forceinline void Patch_SA_10()
|
||||||
{
|
{
|
||||||
using namespace MemoryVP;
|
using namespace MemoryVP;
|
||||||
|
|
||||||
// TEMP - shaders!
|
// IsAlreadyRunning needs to be read relatively late - the later, the better
|
||||||
InjectHook(0x5DA743, SetShader);
|
IsAlreadyRunning = (BOOL(*)())(*(int*)0x74872E + 0x74872D + 5);
|
||||||
InjectHook(0x5D66F1, SetShader2);
|
InjectHook(0x74872D, InjectDelayedPatches_10);
|
||||||
InjectHook(0x5D6116, UsageIndex1, PATCH_JUMP);
|
|
||||||
InjectHook(0x5D63B7, PassDayColoursToShader, PATCH_JUMP);
|
|
||||||
InjectHook(0x5D637B, HijackEsi, PATCH_JUMP);
|
|
||||||
InjectHook(0x5BF3A1, ShaderAttach);
|
|
||||||
InjectHook(0x53D910, ShaderDetach);
|
|
||||||
Patch<const void*>(0x5D67F4, HijackAtomic);
|
|
||||||
Patch<BYTE>(0x5D7200, 0xC3);
|
|
||||||
Patch<WORD>(0x5D67BB, 0x6890);
|
|
||||||
Patch<WORD>(0x5D67D7, 0x6890);
|
|
||||||
Patch<DWORD>(0x5D67BD, 0x5D5FE0);
|
|
||||||
Patch<DWORD>(0x5D67D9, 0x5D5FE0);
|
|
||||||
Patch<DWORD>(0x5DA73F, 0x90909056);
|
|
||||||
|
|
||||||
Patch<BYTE>(0x5D60D9, D3DDECLTYPE_D3DCOLOR);
|
|
||||||
Patch<BYTE>(0x5D60E2, D3DDECLUSAGE_COLOR);
|
|
||||||
Patch<BYTE>(0x5D60CF, sizeof(D3DCOLOR));
|
|
||||||
Patch<BYTE>(0x5D60EA, sizeof(D3DCOLOR));
|
|
||||||
Patch<BYTE>(0x5D60C2, 0x13);
|
|
||||||
Patch<BYTE>(0x5D62F0, 0xEB);
|
|
||||||
|
|
||||||
// PostFX fix
|
|
||||||
Patch<float>(*(float**)0x7034C0, 0.0);
|
|
||||||
|
|
||||||
//Patch<BYTE>(0x5D7265, 0xEB);
|
//Patch<BYTE>(0x5D7265, 0xEB);
|
||||||
|
|
||||||
|
@ -2024,6 +2123,16 @@ __forceinline void Patch_SA_10()
|
||||||
Patch<DWORD>(0x733B55, EXPAND_ALPHA_ENTITY_LISTS * 20);
|
Patch<DWORD>(0x733B55, EXPAND_ALPHA_ENTITY_LISTS * 20);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Unlocked widescreen resolutions
|
||||||
|
Patch<DWORD>(0x745B71, 0x9090687D);
|
||||||
|
Patch<DWORD>(0x74596C, 0x9090127D);
|
||||||
|
Nop(0x745970, 2);
|
||||||
|
Nop(0x745B75, 2);
|
||||||
|
Nop(0x7459E1, 2);
|
||||||
|
|
||||||
|
// Heap corruption fix
|
||||||
|
Nop(0x5C25D3, 5);
|
||||||
|
|
||||||
// User Tracks fix
|
// User Tracks fix
|
||||||
InjectHook(0x4D9B66, UserTracksFix);
|
InjectHook(0x4D9B66, UserTracksFix);
|
||||||
InjectHook(0x4D9BB5, 0x4F2FD0);
|
InjectHook(0x4D9BB5, 0x4F2FD0);
|
||||||
|
|
Loading…
Reference in a new issue