mirror of
https://github.com/isledecomp/isle-portable.git
synced 2024-11-27 01:45:37 -05:00
494a556f8e
* Adjustments to "decomp" language * Fix a comment * Fix accidental clang-formatting * Fix order * Fix order * Remove junk * Fix OFFSET * Adjustments based on new suggestions * Annotate globals * Globals in ISLE * More globals * Merge from parser2 branch * Allow prepending space for exact marker match * To eliminate noise, require the 0x prefix on offset for marker match * fix test from previous * Count tab stops for indented functions to reduce MISSED_END_OF_FUNCTION noise * FUNCTION to SYNTHETIC where needed * Missed marker conversion on SetAtomId * pylint cleanup, remove unused code * Fix unexpected function end, add more unit tests * Be more strict about synthetic name syntax * Revert "Missed marker conversion on SetAtomId" This reverts commit d87d665127fae7dd6e5bd48d9af14a0a829bf9e2. * Revert "FUNCTION to SYNTHETIC where needed" This reverts commit 8c815418d261ba8c5f67a9a2cae349fe4ac92db8. * Implicit lookup by name for functions * Fix VTABLE SYNTHETIC and other decomp markers * Get vtable class name * Vtable marker should identify struct * No colon for SIZE comment * Update README.md * Update README.md * Update CONTRIBUTING.md * Update README.md * Update README.md * Update CONTRIBUTING.md * Update README.md * Update CONTRIBUTING.md * Fix destructor/annotation * Update README.md * Update README.md * Update README.md * Update README.md * Update README.md --------- Co-authored-by: disinvite <disinvite@users.noreply.github.com>
80 lines
3 KiB
C++
80 lines
3 KiB
C++
#ifndef MXBITMAP_H
|
|
#define MXBITMAP_H
|
|
|
|
#include "mxcore.h"
|
|
#include "mxpalette.h"
|
|
#include "mxtypes.h"
|
|
|
|
#include <stdlib.h>
|
|
|
|
// The stock BITMAPINFO struct from wingdi.h only makes room for one color
|
|
// in the palette. It seems like the expectation (if you use the struct)
|
|
// is to malloc as much as you actually need, and then index into the array
|
|
// anyway even though its stated size is [1].
|
|
// https://learn.microsoft.com/en-us/windows/win32/api/wingdi/ns-wingdi-bitmapinfo
|
|
// In our case, the size 0x428 is used frequently, which matches
|
|
// a 40-byte header plus 256 colors, so just use that as our template.
|
|
|
|
// SIZE 0x428
|
|
struct MxBITMAPINFO {
|
|
BITMAPINFOHEADER bmiHeader;
|
|
RGBQUAD bmiColors[256];
|
|
};
|
|
|
|
// Non-standard value for biCompression in the BITMAPINFOHEADER struct.
|
|
// By default, uncompressed bitmaps (BI_RGB) are stored in bottom-up order.
|
|
// You can specify that the bitmap has top-down order instead by providing
|
|
// a negative number for biHeight. It could be that Mindscape decided on a
|
|
// belt & suspenders approach here.
|
|
#define BI_RGB_TOPDOWN 0x10
|
|
|
|
// SIZE 0x20
|
|
// VTABLE: LEGO1 0x100dc7b0
|
|
class MxBitmap : public MxCore {
|
|
public:
|
|
__declspec(dllexport) MxBitmap();
|
|
__declspec(dllexport) virtual ~MxBitmap(); // vtable+00
|
|
|
|
virtual MxResult ImportBitmap(MxBitmap* p_bitmap); // vtable+14
|
|
virtual MxResult ImportBitmapInfo(MxBITMAPINFO* p_info); // vtable+18
|
|
virtual MxResult SetSize(MxS32 p_width, MxS32 p_height, MxPalette* p_palette, MxBool); // vtable+1c
|
|
virtual MxResult LoadFile(HANDLE p_handle); // vtable+20
|
|
__declspec(dllexport) virtual MxLong Read(const char* p_filename); // vtable+24
|
|
virtual int vtable28(int);
|
|
virtual void vtable2c(int, int, int, int, int, int, int);
|
|
virtual void vtable30(int, int, int, int, int, int, int);
|
|
__declspec(dllexport) virtual MxPalette* CreatePalette(); // vtable+34
|
|
virtual void ImportPalette(MxPalette* p_palette); // vtable+38
|
|
virtual MxResult SetBitDepth(MxBool); // vtable+3c
|
|
virtual MxResult StretchBits(
|
|
HDC p_hdc,
|
|
MxS32 p_xSrc,
|
|
MxS32 p_ySrc,
|
|
MxS32 p_xDest,
|
|
MxS32 p_yDest,
|
|
MxS32 p_destWidth,
|
|
MxS32 p_destHeight
|
|
); // vtable+40
|
|
|
|
inline BITMAPINFOHEADER* GetBmiHeader() const { return m_bmiHeader; }
|
|
inline MxLong GetBmiWidth() const { return m_bmiHeader->biWidth; }
|
|
inline MxLong GetBmiStride() const { return ((m_bmiHeader->biWidth + 3) & -4); }
|
|
inline MxLong GetBmiHeight() const { return m_bmiHeader->biHeight; }
|
|
inline MxLong GetBmiHeightAbs() const
|
|
{
|
|
return m_bmiHeader->biHeight > 0 ? m_bmiHeader->biHeight : -m_bmiHeader->biHeight;
|
|
}
|
|
inline MxU8* GetBitmapData() const { return m_data; }
|
|
|
|
private:
|
|
MxResult ImportColorsToPalette(RGBQUAD*, MxPalette*);
|
|
|
|
MxBITMAPINFO* m_info; // 0x8
|
|
BITMAPINFOHEADER* m_bmiHeader; // 0xc
|
|
RGBQUAD* m_paletteData; // 0x10
|
|
MxU8* m_data; // 0x14
|
|
MxBool m_isHighColor; // 0x18
|
|
MxPalette* m_palette; // 0x1c
|
|
};
|
|
|
|
#endif // MXBITMAP_H
|