2023-09-21 13:47:30 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "BMap.hpp"
|
2023-10-07 22:33:55 +08:00
|
|
|
#include <algorithm>
|
2023-09-21 13:47:30 +08:00
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
/**
|
|
|
|
@note
|
|
|
|
# Design Note:
|
|
|
|
|
|
|
|
## Function Declaration
|
|
|
|
|
|
|
|
All exported interface functions will always return a bool to indicate whether current operations is successful.
|
|
|
|
The layout of interface functions' parameters is Essential Param -> Input Param -> Out Param.
|
|
|
|
A example is in there: `LIBCMO_EXPORT bool BMSomeFunc(BMPARAM_OBJECT_DECL, BMPARAM_IN(LibCmo::CK2::CK_ID, someobj), BMPARAM_OUT(LibCmo::CKSTRING, out_name))`
|
|
|
|
First param is `BMPARAM_OBJECT_DECL`. It is essential param for this function. In this exmaple, it is the combination of BMFile* and CK_ID. If your provide invalid value for them, the function will failed immediately.
|
|
|
|
Second param is `BMPARAM_IN(LibCmo::CK2::CK_ID, someobj)`. It declare this function accept a Object ID for underlying function calling.
|
|
|
|
Last param is `BMPARAM_OUT(LibCmo::CKSTRING, out_name)`. It is the return value of this function. Only will be filled when this function success.
|
|
|
|
Input Param and Out Param can be multiple. No count limit.
|
|
|
|
|
|
|
|
## CK_ID Interface.
|
|
|
|
|
|
|
|
We use CK_ID as CKObject visitor to ensure the visiting is safe.
|
|
|
|
We choose CK_ID because checking a valid CK_ID is more easy and cost lower performance than checking a valid CKObject*.
|
|
|
|
Another reason is that CKObject* relate to class inheritance and need cast. Use CK_ID can leyt them get safe cast in C++, not in other binding languages.
|
|
|
|
Each CK_ID also should be used with its corresponding BMFile*, because each BMfile* will create a unique CKContext*. CK_ID between different BMFile* is not shared.
|
2023-10-05 21:08:58 +08:00
|
|
|
|
|
|
|
+ We use raw pointer for BMFile and BMMeshTransition
|
|
|
|
- These 2 class do no involve class inheritance so we can safely pass them to this DLL.
|
|
|
|
- These 2 class is not a part of CK core. It is more easy to check them validation. It is enough checking them in a std::set.
|
2023-10-08 15:03:44 +08:00
|
|
|
|
2023-10-05 21:08:58 +08:00
|
|
|
|
|
|
|
*/
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
// ===== Interface Used Macro =====
|
2023-10-08 10:42:07 +08:00
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
/** The first param used by BMFile function family */
|
|
|
|
#define BMPARAM_FILE_DECL(_bmfile) BMap::BMFile* _bmfile
|
|
|
|
/** The first param used by BMMeshTrans function family */
|
|
|
|
#define BMPARAM_MESHTRANS_DECL(_trans) BMap::BMMeshTransition* _trans
|
|
|
|
/** The first param used by BMObject, BMGroup, BM3dObject, BMMesh, BMMaterial and BMTexture function family */
|
|
|
|
#define BMPARAM_OBJECT_DECL(_bmfile, _objid) BMap::BMFile* _bmfile, LibCmo::CK2::CK_ID _objid
|
|
|
|
/** Declare an input parameter */
|
2023-10-08 10:42:07 +08:00
|
|
|
#define BMPARAM_IN(_t, _name) _t _name
|
2023-10-08 15:03:44 +08:00
|
|
|
/**
|
|
|
|
Declare an output parameter.
|
|
|
|
A pointer will be added automatically for caller receive it.
|
|
|
|
See BMPARAM_OUT_ASSIGN and BMPARAM_OUT_VAL to know how to use output param in function body.
|
|
|
|
@remark
|
|
|
|
There is an example:
|
|
|
|
```
|
|
|
|
bool some_interface_func(BMPARAM_OUT(Type_t, param_name)) {
|
|
|
|
BMPARAM_OUT_ASSIGN(param_name, some_value); // assign to out param.
|
|
|
|
return BMPARAM_OUT_VAL(param_name) != other_value; // use out param value.
|
|
|
|
}
|
|
|
|
@see BMPARAM_OUT_ASSIGN, BMPARAM_OUT_VAL
|
|
|
|
```
|
|
|
|
*/
|
2023-10-08 10:42:07 +08:00
|
|
|
#define BMPARAM_OUT(_t, _name) _t* _name
|
2023-10-08 15:03:44 +08:00
|
|
|
/** Assign value for out param in function body. */
|
|
|
|
#define BMPARAM_OUT_ASSIGN(_name, _val) (*(_name)) = (_val)
|
|
|
|
/** Visit value for out param in function body. */
|
|
|
|
#define BMPARAM_OUT_VAL(_name) (*(_name))
|
2023-10-08 10:42:07 +08:00
|
|
|
|
2023-09-21 13:47:30 +08:00
|
|
|
#pragma region Init / Dispose
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT bool BMInit();
|
|
|
|
LIBCMO_EXPORT bool BMDispose();
|
2023-09-21 13:47:30 +08:00
|
|
|
|
|
|
|
#pragma endregion
|
|
|
|
|
2023-09-23 15:55:57 +08:00
|
|
|
#pragma region BMFile
|
2023-09-21 13:47:30 +08:00
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT bool BMFile_Load(
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING, file_name),
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING, temp_folder),
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING, texture_folder),
|
|
|
|
BMPARAM_IN(LibCmo::CKDWORD, encoding_count),
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING*, encodings),
|
|
|
|
BMPARAM_OUT(BMap::BMFile*, out_file)
|
|
|
|
);
|
|
|
|
LIBCMO_EXPORT bool BMFile_Create(
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING, temp_folder),
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING, texture_folder),
|
|
|
|
BMPARAM_IN(LibCmo::CKDWORD, encoding_count),
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING*, encodings),
|
|
|
|
BMPARAM_OUT(BMap::BMFile*, out_file)
|
|
|
|
);
|
|
|
|
LIBCMO_EXPORT bool BMFile_Save(
|
|
|
|
BMPARAM_IN(BMap::BMFile*, map_file),
|
|
|
|
BMPARAM_IN(LibCmo::CKSTRING, file_name),
|
|
|
|
BMPARAM_IN(LibCmo::CKINT, compreess_level)
|
|
|
|
);
|
|
|
|
LIBCMO_EXPORT bool BMFile_Free(
|
|
|
|
BMPARAM_IN(BMap::BMFile*, map_file)
|
|
|
|
);
|
|
|
|
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetGroupCount(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CKDWORD, out_count));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetGroup(BMPARAM_FILE_DECL(bmfile), BMPARAM_IN(LibCmo::CKDWORD, idx), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_CreateGroup(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_Get3dObjectCount(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CKDWORD, out_count));
|
|
|
|
LIBCMO_EXPORT bool BMFile_Get3dObject(BMPARAM_FILE_DECL(bmfile), BMPARAM_IN(LibCmo::CKDWORD, idx), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_Create3dObject(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetMeshCount(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CKDWORD, out_count));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetMesh(BMPARAM_FILE_DECL(bmfile), BMPARAM_IN(LibCmo::CKDWORD, idx), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_CreateMesh(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetMaterialCount(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CKDWORD, out_count));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetMaterial(BMPARAM_FILE_DECL(bmfile), BMPARAM_IN(LibCmo::CKDWORD, idx), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_CreateMaterial(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetTextureCount(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CKDWORD, out_count));
|
|
|
|
LIBCMO_EXPORT bool BMFile_GetTexture(BMPARAM_FILE_DECL(bmfile), BMPARAM_IN(LibCmo::CKDWORD, idx), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
|
|
|
LIBCMO_EXPORT bool BMFile_CreateTexture(BMPARAM_FILE_DECL(bmfile), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_id));
|
2023-10-02 20:54:31 +08:00
|
|
|
|
2023-09-21 13:47:30 +08:00
|
|
|
#pragma endregion
|
|
|
|
|
2023-09-23 15:55:57 +08:00
|
|
|
#pragma region BMMeshTransition
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_New(BMPARAM_OUT(BMap::BMMeshTransition*, out_trans));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_Delete(BMPARAM_IN(BMap::BMMeshTransition*, trans));
|
|
|
|
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareVertexCount(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_IN(LibCmo::CKDWORD, count));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareVertex(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::VxMath::VxVector3*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareNormalCount(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_IN(LibCmo::CKDWORD, count));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareNormal(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::VxMath::VxVector3*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareUVCount(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_IN(LibCmo::CKDWORD, count));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareUV(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::VxMath::VxVector2*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareMtlSlotCount(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_IN(LibCmo::CKDWORD, count));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareMtlSlot(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::CK2::CK_ID*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareFaceCount(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_IN(LibCmo::CKDWORD, count));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareFaceVertexIndices(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::CKDWORD*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareFaceNormalIndices(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::CKDWORD*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareFaceUVIndices(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::CKDWORD*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_PrepareFaceMtlSlot(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_OUT(LibCmo::CKDWORD*, out_mem));
|
|
|
|
LIBCMO_EXPORT bool BMMeshTrans_Parse(BMPARAM_MESHTRANS_DECL(trans), BMPARAM_IN(LibCmo::CK2::ObjImpls::CKMesh*, write_into_mesh));
|
2023-10-05 21:08:58 +08:00
|
|
|
|
|
|
|
#pragma endregion
|
|
|
|
|
|
|
|
#pragma region CKObject
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT bool BMObject_GetName(BMPARAM_OBJECT_DECL(bmfile, objid), BMPARAM_OUT(LibCmo::CKSTRING, out_name));
|
|
|
|
LIBCMO_EXPORT bool BMObject_SetName(BMPARAM_OBJECT_DECL(bmfile, objid), BMPARAM_IN(LibCmo::CKSTRING name));
|
2023-10-05 21:08:58 +08:00
|
|
|
|
|
|
|
#pragma endregion
|
|
|
|
|
|
|
|
#pragma region CKGroup
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT bool BMGroup_AddObject(BMPARAM_OBJECT_DECL(bmfile, objid), BMPARAM_IN(LibCmo::CK2::CK_ID memberid));
|
|
|
|
LIBCMO_EXPORT bool BMGroup_GetObjectCount(BMPARAM_OBJECT_DECL(bmfile, objid), BMPARAM_OUT(LibCmo::CKDWORD, out_count));
|
|
|
|
LIBCMO_EXPORT bool BMGroup_GetObject(BMPARAM_OBJECT_DECL(bmfile, objid), BMPARAM_IN(LibCmo::CKDWORD pos), BMPARAM_OUT(LibCmo::CK2::CK_ID, out_objid));
|
2023-10-05 21:08:58 +08:00
|
|
|
|
|
|
|
#pragma endregion
|
|
|
|
|
|
|
|
#pragma region CKTexture
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT LibCmo::CKSTRING BMTexture_GetFileName();
|
2023-10-08 10:42:07 +08:00
|
|
|
LIBCMO_EXPORT bool BMTexture_LoadImage(LibCmo::CKSTRING filename);
|
|
|
|
LIBCMO_EXPORT bool BMTexture_SaveImage(LibCmo::CKSTRING filename);
|
|
|
|
LIBCMO_EXPORT LibCmo::CK2::CK_TEXTURE_SAVEOPTIONS BMTexture_GetSaveOptions();
|
|
|
|
LIBCMO_EXPORT bool BMTexture_SetSaveOptions(LibCmo::CK2::CK_TEXTURE_SAVEOPTIONS saveopt);
|
|
|
|
|
2023-09-23 15:55:57 +08:00
|
|
|
#pragma endregion
|
|
|
|
|
2023-10-05 21:08:58 +08:00
|
|
|
#pragma region CKMaterial
|
|
|
|
|
|
|
|
#pragma endregion
|
2023-09-21 13:47:30 +08:00
|
|
|
|
2023-10-05 21:08:58 +08:00
|
|
|
#pragma region CKMesh
|
|
|
|
|
|
|
|
#pragma endregion
|
|
|
|
|
|
|
|
#pragma region CK3dObject
|
|
|
|
|
2023-10-07 22:33:55 +08:00
|
|
|
// This struct is designed to prevent C4190 warning
|
|
|
|
struct CStyleVxMatrix {
|
|
|
|
LibCmo::CKBYTE placeholder[sizeof(LibCmo::VxMath::VxMatrix)];
|
|
|
|
void FromVxMatrix(const LibCmo::VxMath::VxMatrix& mat) {
|
|
|
|
std::memcpy(this, &mat, std::min(sizeof(LibCmo::VxMath::VxMatrix), sizeof(CStyleVxMatrix)));
|
|
|
|
}
|
|
|
|
void ToVxMatrix(LibCmo::VxMath::VxMatrix& mat) {
|
|
|
|
std::memcpy(&mat, this, std::min(sizeof(LibCmo::VxMath::VxMatrix), sizeof(CStyleVxMatrix)));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2023-10-08 15:03:44 +08:00
|
|
|
LIBCMO_EXPORT CStyleVxMatrix BM3dEntity_GetWorldMatrix(BMPARAM_OBJECT_DECL(bmfile, objid));
|
|
|
|
LIBCMO_EXPORT bool BM3dEntity_SetWorldMatrix(BMPARAM_OBJECT_DECL(bmfile, objid), CStyleVxMatrix mat);
|
|
|
|
LIBCMO_EXPORT LibCmo::CK2::CK_ID BM3dEntity_GetCurrentMesh(BMPARAM_OBJECT_DECL(bmfile, objid));
|
|
|
|
LIBCMO_EXPORT bool BM3dEntity_SetCurrentMesh(BMPARAM_OBJECT_DECL(bmfile, objid), LibCmo::CK2::CK_ID meshid);
|
|
|
|
LIBCMO_EXPORT bool BM3dEntity_GetVisibility(BMPARAM_OBJECT_DECL(bmfile, objid));
|
|
|
|
LIBCMO_EXPORT bool BM3dEntity_SetVisibility(BMPARAM_OBJECT_DECL(bmfile, objid), bool is_visible);
|
2023-10-07 22:33:55 +08:00
|
|
|
|
2023-10-05 21:08:58 +08:00
|
|
|
#pragma endregion
|