mirror of
https://github.com/CookiePLMonster/SilentPatch.git
synced 2025-01-04 10:13:02 +05:00
Look up frames by ID (instead of names) when possible
Add fallback code for ResetFrames
This commit is contained in:
parent
f9a9404fd0
commit
108c2740a7
1 changed files with 41 additions and 2 deletions
|
@ -158,6 +158,8 @@ WRAPPER void CVehicle::Render() { VARJMP(varVehicleRender); }
|
||||||
static void* varIsLawEnforcementVehicle = AddressByVersion<void*>(0x6D2370, 0x6D2BA0, 0x70D8C0);
|
static void* varIsLawEnforcementVehicle = AddressByVersion<void*>(0x6D2370, 0x6D2BA0, 0x70D8C0);
|
||||||
WRAPPER bool CVehicle::IsLawEnforcementVehicle() { VARJMP(varIsLawEnforcementVehicle); }
|
WRAPPER bool CVehicle::IsLawEnforcementVehicle() { VARJMP(varIsLawEnforcementVehicle); }
|
||||||
|
|
||||||
|
auto GetFrameHierarchyId = AddressByVersion<int32_t(*)(RwFrame*)>(0x732A20, 0x733250, 0x76CC30);
|
||||||
|
|
||||||
void (CVehicle::*CVehicle::orgVehiclePreRender)();
|
void (CVehicle::*CVehicle::orgVehiclePreRender)();
|
||||||
void (CAutomobile::*CAutomobile::orgAutomobilePreRender)();
|
void (CAutomobile::*CAutomobile::orgAutomobilePreRender)();
|
||||||
void (CPlane::*CPlane::orgPlanePreRender)();
|
void (CPlane::*CPlane::orgPlanePreRender)();
|
||||||
|
@ -212,6 +214,35 @@ static RwFrame* GetFrameFromName( RwFrame* topFrame, const char* name )
|
||||||
return RwFrameForAllChildren( topFrame, GetFramePredicate(name) ).foundFrame;
|
return RwFrameForAllChildren( topFrame, GetFramePredicate(name) ).foundFrame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static RwFrame* GetFrameFromID( RwFrame* topFrame, int32_t ID )
|
||||||
|
{
|
||||||
|
class GetFramePredicate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RwFrame* foundFrame = nullptr;
|
||||||
|
|
||||||
|
GetFramePredicate( int32_t ID )
|
||||||
|
: ID( ID )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
RwFrame* operator() ( RwFrame* frame )
|
||||||
|
{
|
||||||
|
if ( ID == GetFrameHierarchyId(frame) )
|
||||||
|
{
|
||||||
|
foundFrame = frame;
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
RwFrameForAllChildren( frame, std::forward<GetFramePredicate>(*this) );
|
||||||
|
return foundFrame != nullptr ? nullptr : frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
const int32_t ID;
|
||||||
|
};
|
||||||
|
return RwFrameForAllChildren( topFrame, GetFramePredicate(ID) ).foundFrame;
|
||||||
|
}
|
||||||
|
|
||||||
void ReadRotorFixExceptions(const wchar_t* pPath)
|
void ReadRotorFixExceptions(const wchar_t* pPath)
|
||||||
{
|
{
|
||||||
constexpr size_t SCRATCH_PAD_SIZE = 32767;
|
constexpr size_t SCRATCH_PAD_SIZE = 32767;
|
||||||
|
@ -525,13 +556,21 @@ void CAutomobile::ResetFrames()
|
||||||
if ( m_pCarNode[i] != nullptr )
|
if ( m_pCarNode[i] != nullptr )
|
||||||
{
|
{
|
||||||
// Find a frame in CBaseModelInfo object
|
// Find a frame in CBaseModelInfo object
|
||||||
RwFrame* origFrame = GetFrameFromName( RpClumpGetFrame(pOrigClump), GetFrameNodeName(m_pCarNode[i]) );
|
RwFrame* origFrame = GetFrameFromID( RpClumpGetFrame(pOrigClump), static_cast<int32_t>(i) );
|
||||||
if ( origFrame != nullptr )
|
if ( origFrame != nullptr )
|
||||||
{
|
{
|
||||||
// Found a frame, reset it
|
// Found a frame, reset it
|
||||||
*RwFrameGetMatrix(m_pCarNode[i]) = *RwFrameGetMatrix(origFrame);
|
*RwFrameGetMatrix(m_pCarNode[i]) = *RwFrameGetMatrix(origFrame);
|
||||||
RwMatrixUpdate(RwFrameGetMatrix(m_pCarNode[i]));
|
RwMatrixUpdate(RwFrameGetMatrix(m_pCarNode[i]));
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Same as original code
|
||||||
|
CMatrix matrix( RwFrameGetMatrix(m_pCarNode[i]) );
|
||||||
|
const CVector pos( matrix.GetPos() );
|
||||||
|
matrix.SetTranslate( pos.x, pos.y, pos.z );
|
||||||
|
matrix.UpdateRW();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -544,7 +583,7 @@ void CAutomobile::ProcessPhoenixBlower( int32_t modelID )
|
||||||
RpClump* pOrigClump = reinterpret_cast<RpClump*>(ms_modelInfoPtrs[ modelID ]->pRwObject);
|
RpClump* pOrigClump = reinterpret_cast<RpClump*>(ms_modelInfoPtrs[ modelID ]->pRwObject);
|
||||||
if ( pOrigClump != nullptr )
|
if ( pOrigClump != nullptr )
|
||||||
{
|
{
|
||||||
RwFrame* origFrame = GetFrameFromName( RpClumpGetFrame(pOrigClump), GetFrameNodeName(m_pCarNode[20]) );
|
RwFrame* origFrame = GetFrameFromID( RpClumpGetFrame(pOrigClump), 20 );
|
||||||
if ( origFrame != nullptr )
|
if ( origFrame != nullptr )
|
||||||
{
|
{
|
||||||
*RwFrameGetMatrix(m_pCarNode[20]) = *RwFrameGetMatrix(origFrame);
|
*RwFrameGetMatrix(m_pCarNode[20]) = *RwFrameGetMatrix(origFrame);
|
||||||
|
|
Loading…
Reference in a new issue