mirror of
https://github.com/hedge-dev/UnleashedRecomp
synced 2026-06-08 20:30:02 -04:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 460bc583a5 | |||
| 5e8695a157 |
@@ -89,6 +89,9 @@ PPC_FUNC(sub_822C1130)
|
||||
if (Config::EnableObjectCollisionDebugView)
|
||||
*SWA::SGlobals::ms_IsObjectCollisionRender = true;
|
||||
|
||||
if (Config::EnableStageCollisionDebugView)
|
||||
*SWA::SGlobals::ms_IsCollisionRender = true;
|
||||
|
||||
__imp__sub_822C1130(ctx, base);
|
||||
}
|
||||
|
||||
|
||||
@@ -1,5 +1,8 @@
|
||||
#pragma once
|
||||
|
||||
// 6 hour long timeout between checks.
|
||||
static constexpr double g_timeBetweenUpdateChecksInSeconds = 6 * 60 * 60;
|
||||
|
||||
struct UpdateChecker
|
||||
{
|
||||
enum class Result
|
||||
|
||||
@@ -307,11 +307,11 @@ int main(int argc, char *argv[])
|
||||
}
|
||||
#endif
|
||||
|
||||
// Check the time since the last time an update was checked. Store the new time if the difference is more than six hours.
|
||||
constexpr double TimeBetweenUpdateChecksInSeconds = 6 * 60 * 60;
|
||||
// Check the time since the last time an update was checked.
|
||||
// Store the new time if the difference is more than g_timeBetweenUpdateChecksInSeconds hours.
|
||||
time_t timeNow = std::time(nullptr);
|
||||
double timeDifferenceSeconds = difftime(timeNow, Config::LastChecked);
|
||||
if (timeDifferenceSeconds > TimeBetweenUpdateChecksInSeconds)
|
||||
if (timeDifferenceSeconds > g_timeBetweenUpdateChecksInSeconds)
|
||||
{
|
||||
UpdateChecker::initialize();
|
||||
UpdateChecker::start();
|
||||
|
||||
@@ -129,7 +129,9 @@ PPC_FUNC(sub_822C55B0)
|
||||
|
||||
void PressStartSaveLoadThreadMidAsmHook()
|
||||
{
|
||||
if (UpdateChecker::check() == UpdateChecker::Result::UpdateAvailable)
|
||||
time_t timeNow = std::time(nullptr);
|
||||
double timeDifferenceSeconds = difftime(timeNow, Config::LastChecked);
|
||||
if (UpdateChecker::check() == UpdateChecker::Result::UpdateAvailable && timeDifferenceSeconds > g_timeBetweenUpdateChecksInSeconds)
|
||||
{
|
||||
g_updateAvailableMessageOpen = true;
|
||||
g_updateAvailableMessageOpen.wait(true);
|
||||
|
||||
@@ -195,3 +195,11 @@ bool SparkleLocusMidAsmHook()
|
||||
// This has the side effect of the locus particle eventually snapping to the rest position during pause, but it's better than vertices exploding.
|
||||
return App::s_deltaTime < (1.0 / 60.0);
|
||||
}
|
||||
|
||||
void CEvilSonicContext_CStateWall_LeaveRotationMidAsmHook(PPCRegister& f1)
|
||||
{
|
||||
// The code in the Werehog's "wall" state for leaving walls adds a constant
|
||||
// value of 0.05 to his transform every frame. This makes the value respect
|
||||
// delta time whilst maintaining the original behaviour at 30 FPS.
|
||||
f1.f64 = f1.f64 * (std::min(App::s_deltaTime, 1.0 / 15.0) / (1.0 / 30.0));
|
||||
}
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
#include "misc_patches.h"
|
||||
#include <api/SWA.h>
|
||||
#include <ui/game_window.h>
|
||||
#include <user/achievement_manager.h>
|
||||
@@ -194,54 +193,3 @@ PPC_FUNC(sub_824EE620)
|
||||
|
||||
ctx.r3.u32 = PersistentStorageManager::ShouldDisplayDLCMessage(true);
|
||||
}
|
||||
|
||||
bool StageCollisionDebugViewMidAsmHook(PPCRegister& r27)
|
||||
{
|
||||
if (Config::EnableStageCollisionDebugView)
|
||||
{
|
||||
r27.u32 = true;
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
// The game is set up so that after parsing the Stage.set.xml it checks if TerrainInfoFile is found or not.
|
||||
// Based on the result of that it will either draw terrain or debug collision (if enabled).
|
||||
//
|
||||
// The XMLs in the game are populated like this generally speaking:
|
||||
// <Terrain>
|
||||
// <TerrainInfoFile>terrain</TerrainInfoFile>
|
||||
// <GIAtlas>1</GIAtlas>
|
||||
// </Terrain>
|
||||
// <Terrain>
|
||||
// <RigidBodyContainer>collision</RigidBodyContainer>
|
||||
// <IsCollisionRender>false</IsCollisionRender>
|
||||
// </Terrain>
|
||||
//
|
||||
// In some cases however, the information in these two Terrain blocks is combined into one block,
|
||||
// which makes the logic checking TerrainInfoFile's contents only fire once, and with success only, as such
|
||||
// the logic for drawing collision will never execute.
|
||||
//
|
||||
// To combat this we check if both types returned with some value from the XML file, which indicates that its
|
||||
// a single Terrain block, and if so we store that information so we can later on re-use to manually fire the
|
||||
// logic controlling the drawing of the debug collision view.
|
||||
void StageCollisionDebugViewStoreXmlTypeMidAsmHook(PPCRegister& r1)
|
||||
{
|
||||
uint8_t* base = g_memory.base;
|
||||
|
||||
const char* rigidBodyContainer = (const char*)(base + PPC_LOAD_U32(r1.u32 + 108));
|
||||
const char* terrainInfoFile = (const char*)(base + PPC_LOAD_U32(r1.u32 + 132));
|
||||
if (*rigidBodyContainer != '\0' && *terrainInfoFile != '\0')
|
||||
{
|
||||
g_singleTerrainBlockXml = true;
|
||||
}
|
||||
}
|
||||
|
||||
bool StageCollisionDebugViewSingleTerrainBlockXmlMidAsmHook()
|
||||
{
|
||||
bool runCollisionViewDrawLogic = g_singleTerrainBlockXml;
|
||||
g_singleTerrainBlockXml = false;
|
||||
|
||||
return runCollisionViewDrawLogic;
|
||||
}
|
||||
|
||||
@@ -1,3 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
static bool g_singleTerrainBlockXml = false;
|
||||
@@ -1142,18 +1142,14 @@ name = "EndingTextPositionMidAsmHook"
|
||||
address = 0x82580168
|
||||
registers = ["r31", "f13"]
|
||||
|
||||
# Wall Leave - Left
|
||||
[[midasm_hook]]
|
||||
name = "StageCollisionDebugViewMidAsmHook"
|
||||
address = 0x825648F8
|
||||
registers = ["r27"]
|
||||
jump_address_on_true = 0x825648FC
|
||||
name = "CEvilSonicContext_CStateWall_LeaveRotationMidAsmHook"
|
||||
address = 0x824067BC
|
||||
registers = ["f1"]
|
||||
|
||||
# Wall Leave - Right
|
||||
[[midasm_hook]]
|
||||
name = "StageCollisionDebugViewStoreXmlTypeMidAsmHook"
|
||||
address = 0x8256422C
|
||||
registers = ["r1"]
|
||||
|
||||
[[midasm_hook]]
|
||||
name = "StageCollisionDebugViewSingleTerrainBlockXmlMidAsmHook"
|
||||
address = 0x82564B00
|
||||
jump_address_on_true = 0x82564764
|
||||
name = "CEvilSonicContext_CStateWall_LeaveRotationMidAsmHook"
|
||||
address = 0x82406774
|
||||
registers = ["f1"]
|
||||
|
||||
Reference in New Issue
Block a user