SunSizeHack INI option

This commit is contained in:
Silent 2016-07-26 18:26:14 +02:00
parent cb80efbf53
commit 5816666e55

View file

@ -1942,13 +1942,19 @@ BOOL InjectDelayedPatches_10()
ReadRotorFixExceptions(wcModulePath); ReadRotorFixExceptions(wcModulePath);
if ( GetPrivateProfileIntW(L"SilentPatch", L"SunSizeHack", FALSE, wcModulePath) != FALSE )
{
// PS2 sun - more // PS2 sun - more
static const float fSunMult = (1050.0f * 0.95f) / 1500.0f;
Patch<const void*>(0x6FC5B0, &fSunMult);
if ( !bSAMP ) if ( !bSAMP )
{ {
DoSunAndMoon = (void(*)())(*(int*)0x53C137 + 0x53C136 + 5); DoSunAndMoon = (void(*)())(*(int*)0x53C137 + 0x53C136 + 5);
InjectHook(0x53C136, SunAndMoonFarClip); InjectHook(0x53C136, SunAndMoonFarClip);
Patch<const void*>(0x6FC5AA, &fSunFarClip); Patch<const void*>(0x6FC5AA, &fSunFarClip);
} }
}
if ( !bSARender ) if ( !bSARender )
{ {
@ -2162,7 +2168,12 @@ BOOL InjectDelayedPatches_11()
ReadRotorFixExceptions(wcModulePath); ReadRotorFixExceptions(wcModulePath);
if ( GetPrivateProfileIntW(L"SilentPatch", L"SunSizeHack", FALSE, wcModulePath) != FALSE )
{
// PS2 sun - more // PS2 sun - more
static const float fSunMult = (1050.0f * 0.95f) / 1500.0f;
Patch<const void*>(0x6FCDE0, &fSunMult);
if ( !bSAMP ) if ( !bSAMP )
{ {
DoSunAndMoon = (void(*)())(*(int*)0x53C5D7 + 0x53C5D6 + 5); DoSunAndMoon = (void(*)())(*(int*)0x53C5D7 + 0x53C5D6 + 5);
@ -2170,6 +2181,7 @@ BOOL InjectDelayedPatches_11()
Patch<const void*>(0x6FCDDA, &fSunFarClip); Patch<const void*>(0x6FCDDA, &fSunFarClip);
} }
}
if ( !bSARender ) if ( !bSARender )
{ {
@ -2379,7 +2391,12 @@ BOOL InjectDelayedPatches_Steam()
ReadRotorFixExceptions(wcModulePath); ReadRotorFixExceptions(wcModulePath);
if ( GetPrivateProfileIntW(L"SilentPatch", L"SunSizeHack", FALSE, wcModulePath) != FALSE )
{
// PS2 sun - more // PS2 sun - more
static const double dSunMult = (1050.0 * 0.95) / 1500.0;
Patch<const void*>(0x734DF0, &dSunMult);
if ( !bSAMP ) if ( !bSAMP )
{ {
DoSunAndMoon = (void(*)())(*(int*)0x54E0B7 + 0x54E0B6 + 5); DoSunAndMoon = (void(*)())(*(int*)0x54E0B7 + 0x54E0B6 + 5);
@ -2387,6 +2404,7 @@ BOOL InjectDelayedPatches_Steam()
Patch<const void*>(0x734DEA, &fSunFarClip); Patch<const void*>(0x734DEA, &fSunFarClip);
} }
}
if ( !bSARender ) if ( !bSARender )
{ {
@ -2677,12 +2695,7 @@ void Patch_SA_10()
InjectHook(0x6A2EF7, ResetAlphaFuncRefAfterRender, PATCH_JUMP); InjectHook(0x6A2EF7, ResetAlphaFuncRefAfterRender, PATCH_JUMP);
// PS2 SUN!!!!!!!!!!!!!!!!! // PS2 SUN!!!!!!!!!!!!!!!!!
static const float fSunMult = (1050.0f * 0.95f) / 1500.0f;
Nop(0x6FB17C, 3); Nop(0x6FB17C, 3);
Patch<const void*>(0x6FC5B0, &fSunMult);
//Patch<WORD>(0x6FB172, 0x0BEB);
//Patch<BYTE>(0x6FB1A7, 8);
#if defined EXPAND_ALPHA_ENTITY_LISTS #if defined EXPAND_ALPHA_ENTITY_LISTS
// Bigger alpha entity lists // Bigger alpha entity lists
@ -3049,10 +3062,7 @@ void Patch_SA_11()
InjectHook(0x6A3717, ResetAlphaFuncRefAfterRender, PATCH_JUMP); InjectHook(0x6A3717, ResetAlphaFuncRefAfterRender, PATCH_JUMP);
// PS2 SUN!!!!!!!!!!!!!!!!! // PS2 SUN!!!!!!!!!!!!!!!!!
static const float fSunMult = (1050.0f * 0.95f) / 1500.0f;
Nop(0x6FB9AC, 3); Nop(0x6FB9AC, 3);
Patch<const void*>(0x6FCDE0, &fSunMult);
// Unlocked widescreen resolutions // Unlocked widescreen resolutions
Patch<DWORD>(0x74619C, 0x9090127D); Patch<DWORD>(0x74619C, 0x9090127D);
@ -3398,10 +3408,7 @@ void Patch_SA_Steam()
InjectHook(0x6CFF69, ResetAlphaFuncRefAfterRender_Steam, PATCH_JUMP); InjectHook(0x6CFF69, ResetAlphaFuncRefAfterRender_Steam, PATCH_JUMP);
// PS2 SUN!!!!!!!!!!!!!!!!! // PS2 SUN!!!!!!!!!!!!!!!!!
static const double dSunMult = (1050.0 * 0.95) / 1500.0;
Nop(0x73362F, 2); Nop(0x73362F, 2);
Patch<const void*>(0x734DF0, &dSunMult);
// Unlocked widescreen resolutions // Unlocked widescreen resolutions
//Patch<WORD>(0x77F9F0, 0x6E7D); //Patch<WORD>(0x77F9F0, 0x6E7D);