mirror of
https://github.com/isledecomp/isle.git
synced 2026-01-24 00:31:16 +00:00
implement/match several mxsmkpresenter functions
This commit is contained in:
parent
6594cc78ea
commit
042f5aa05e
54
3rdparty/smk/smk.h
vendored
Normal file
54
3rdparty/smk/smk.h
vendored
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
#ifndef SMK_H
|
||||||
|
#define SMK_H
|
||||||
|
|
||||||
|
struct SmackSum {
|
||||||
|
unsigned long m_totalTime;
|
||||||
|
unsigned long m_ms100PerFrame;
|
||||||
|
unsigned long m_totalOpenTime;
|
||||||
|
unsigned long m_totalFrames;
|
||||||
|
unsigned long m_skippedFrames;
|
||||||
|
unsigned long m_totalBlitTime;
|
||||||
|
unsigned long m_totalReadTime;
|
||||||
|
unsigned long m_totalDecompressTime;
|
||||||
|
unsigned long m_totalBackReadTime;
|
||||||
|
unsigned long m_totalReadSpeed;
|
||||||
|
unsigned long m_slowestFrameTime;
|
||||||
|
unsigned long m_slowestTwoFrameTime;
|
||||||
|
unsigned long m_slowestFrameNum;
|
||||||
|
unsigned long m_slowestTwoFrameNum;
|
||||||
|
unsigned long m_averageFrameSize;
|
||||||
|
unsigned long m_highestOneSecRate;
|
||||||
|
unsigned long m_highestOneSecFrame;
|
||||||
|
unsigned long m_highestMemAmount;
|
||||||
|
unsigned long m_totalExtraMemory;
|
||||||
|
unsigned long m_highestExtraUsed;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct Smack {
|
||||||
|
unsigned long m_version;
|
||||||
|
unsigned long m_width;
|
||||||
|
unsigned long m_height;
|
||||||
|
unsigned long m_frames;
|
||||||
|
unsigned long m_msInAFrame;
|
||||||
|
unsigned long m_smkType;
|
||||||
|
unsigned long m_audioTrackSize[7];
|
||||||
|
unsigned long m_treeSize;
|
||||||
|
unsigned long m_codeSize;
|
||||||
|
unsigned long m_abSize;
|
||||||
|
unsigned long m_detailSize;
|
||||||
|
unsigned long m_typeSize;
|
||||||
|
unsigned long m_trackType[7];
|
||||||
|
unsigned long m_extra;
|
||||||
|
unsigned long m_newPalette;
|
||||||
|
unsigned char m_palette[772];
|
||||||
|
unsigned long m_frameNum;
|
||||||
|
unsigned long m_lastRectX;
|
||||||
|
unsigned long m_lastRectY;
|
||||||
|
unsigned long m_lastRectW;
|
||||||
|
unsigned long m_lastRectH;
|
||||||
|
unsigned long m_openFlags;
|
||||||
|
unsigned long m_leftOfs;
|
||||||
|
unsigned long m_topOfs;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SMK_H
|
||||||
@ -232,6 +232,9 @@ if (ISLE_USE_DX5)
|
|||||||
target_link_directories(lego1 PRIVATE "${CMAKE_SOURCE_DIR}/3rdparty/dx5/lib")
|
target_link_directories(lego1 PRIVATE "${CMAKE_SOURCE_DIR}/3rdparty/dx5/lib")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Additional include directories
|
||||||
|
include_directories("${CMAKE_SOURCE_DIR}/3rdparty/smk")
|
||||||
|
|
||||||
# Link libraries
|
# Link libraries
|
||||||
target_link_libraries(lego1 PRIVATE ddraw dsound dxguid dinput winmm)
|
target_link_libraries(lego1 PRIVATE ddraw dsound dxguid dinput winmm)
|
||||||
|
|
||||||
|
|||||||
@ -4,16 +4,37 @@
|
|||||||
|
|
||||||
DECOMP_SIZE_ASSERT(MxSmkPresenter, 0x720);
|
DECOMP_SIZE_ASSERT(MxSmkPresenter, 0x720);
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100b3650 STUB
|
// OFFSET: LEGO1 0x100b3650
|
||||||
MxSmkPresenter::MxSmkPresenter()
|
MxSmkPresenter::MxSmkPresenter()
|
||||||
{
|
{
|
||||||
// TODO
|
Init();
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100b38d0 STUB
|
// OFFSET: LEGO1 0x100b3870
|
||||||
|
MxSmkPresenter::~MxSmkPresenter()
|
||||||
|
{
|
||||||
|
FUN_100b3900(TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100b3900
|
||||||
|
void MxSmkPresenter::FUN_100b3900(MxBool p_fromDestructor)
|
||||||
|
{
|
||||||
|
m_criticalSection.Enter();
|
||||||
|
FUN_100c5d40(&m_mxSmack);
|
||||||
|
Init();
|
||||||
|
m_criticalSection.Leave();
|
||||||
|
if (!p_fromDestructor) {
|
||||||
|
MxVideoPresenter::Destroy(FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100b38d0
|
||||||
void MxSmkPresenter::Init()
|
void MxSmkPresenter::Init()
|
||||||
{
|
{
|
||||||
// TODO
|
m_unk0x71c = 0;
|
||||||
|
memset(&m_mxSmack, 0, sizeof(m_mxSmack));
|
||||||
|
m_flags &= 0xfd;
|
||||||
|
m_flags &= 0xfb;
|
||||||
}
|
}
|
||||||
|
|
||||||
// OFFSET: LEGO1 0x100b3960
|
// OFFSET: LEGO1 0x100b3960
|
||||||
@ -24,5 +45,20 @@ void MxSmkPresenter::VTable0x60()
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_bitmap = new MxBitmap();
|
m_bitmap = new MxBitmap();
|
||||||
m_bitmap->SetSize(m_smkWidth, m_smkHeight, NULL, FALSE);
|
m_bitmap->SetSize(m_mxSmack.m_smack.m_width, m_mxSmack.m_smack.m_height, NULL, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
// OFFSET: LEGO1 0x100c5d40
|
||||||
|
void MxSmkPresenter::FUN_100c5d40(MxSmack* p_mxSmack)
|
||||||
|
{
|
||||||
|
if (p_mxSmack->m_unk0x6a0)
|
||||||
|
delete p_mxSmack->m_unk0x6a0;
|
||||||
|
if (p_mxSmack->m_unk0x6a4)
|
||||||
|
delete p_mxSmack->m_unk0x6a4;
|
||||||
|
if (p_mxSmack->m_unk0x6a8)
|
||||||
|
delete p_mxSmack->m_unk0x6a8;
|
||||||
|
if (p_mxSmack->m_unk0x6ac)
|
||||||
|
delete p_mxSmack->m_unk0x6ac;
|
||||||
|
if (p_mxSmack->m_unk0x6b4)
|
||||||
|
delete p_mxSmack->m_unk0x6b4;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,8 @@
|
|||||||
#ifndef MXSMKPRESENTER_H
|
#ifndef MXSMKPRESENTER_H
|
||||||
#define MXSMKPRESENTER_H
|
#define MXSMKPRESENTER_H
|
||||||
|
|
||||||
|
#include <smk.h>
|
||||||
|
|
||||||
#include "decomp.h"
|
#include "decomp.h"
|
||||||
#include "mxvideopresenter.h"
|
#include "mxvideopresenter.h"
|
||||||
|
|
||||||
@ -9,17 +11,33 @@
|
|||||||
class MxSmkPresenter : public MxVideoPresenter {
|
class MxSmkPresenter : public MxVideoPresenter {
|
||||||
public:
|
public:
|
||||||
MxSmkPresenter();
|
MxSmkPresenter();
|
||||||
|
~MxSmkPresenter();
|
||||||
|
|
||||||
virtual void VTable0x60() override;
|
virtual void VTable0x60() override;
|
||||||
|
|
||||||
undefined4 m_unk64;
|
struct MxSmack
|
||||||
MxS32 m_smkWidth; // 0x68
|
{
|
||||||
MxS32 m_smkHeight; // 0x6c
|
Smack m_smack;
|
||||||
undefined4 m_unk70[427];
|
|
||||||
undefined4 m_unk71c;
|
// Unknown for the time being. Not an immediately
|
||||||
|
// recognizable part of the SMK standard...
|
||||||
|
|
||||||
|
undefined m_unk0x3f4[784];
|
||||||
|
undefined4* m_unk0x6a0;
|
||||||
|
undefined4* m_unk0x6a4;
|
||||||
|
undefined4* m_unk0x6a8;
|
||||||
|
undefined4* m_unk0x6ac;
|
||||||
|
undefined4* m_unk0x6b0;
|
||||||
|
undefined4* m_unk0x6b4;
|
||||||
|
};
|
||||||
|
|
||||||
|
MxSmack m_mxSmack;
|
||||||
|
undefined4 m_unk0x71c;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void Init();
|
void Init();
|
||||||
|
void FUN_100b3900(MxBool p_fromDestructor);
|
||||||
|
void FUN_100c5d40(MxSmack* p_mxSmack);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // MXSMKPRESENTER_H
|
#endif // MXSMKPRESENTER_H
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user