Add support for importing both glTF and glTF2 files
parent
2ee7991558
commit
19876e9822
|
@ -181,6 +181,7 @@ corresponding preprocessor flag to selectively disable formats.
|
|||
# include "AssbinLoader.h"
|
||||
#endif
|
||||
#ifndef ASSIMP_BUILD_NO_GLTF_IMPORTER
|
||||
# include "glTFImporter.h"
|
||||
# include "glTF2Importer.h"
|
||||
#endif
|
||||
#ifndef ASSIMP_BUILD_NO_C4D_IMPORTER
|
||||
|
@ -335,6 +336,7 @@ void GetImporterInstanceList(std::vector< BaseImporter* >& out)
|
|||
out.push_back( new AssbinImporter() );
|
||||
#endif
|
||||
#if ( !defined ASSIMP_BUILD_NO_GLTF_IMPORTER )
|
||||
out.push_back( new glTFImporter() );
|
||||
out.push_back( new glTF2Importer() );
|
||||
#endif
|
||||
#if ( !defined ASSIMP_BUILD_NO_C4D_IMPORTER )
|
||||
|
|
|
@ -58,6 +58,8 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||
#include "glTF2Asset.h"
|
||||
// This is included here so WriteLazyDict<T>'s definition is found.
|
||||
#include "glTF2AssetWriter.h"
|
||||
#include <rapidjson/document.h>
|
||||
#include <rapidjson/rapidjson.h>
|
||||
|
||||
using namespace Assimp;
|
||||
using namespace glTF2;
|
||||
|
@ -102,22 +104,16 @@ bool glTF2Importer::CanRead(const std::string& pFile, IOSystem* pIOHandler, bool
|
|||
{
|
||||
const std::string &extension = GetExtension(pFile);
|
||||
|
||||
if (extension == "gltf" || extension == "glb")
|
||||
return true;
|
||||
if (extension != "gltf") // We currently can't read glTF2 binary files (.glb)
|
||||
return false;
|
||||
|
||||
if ((checkSig || !extension.length()) && pIOHandler) {
|
||||
char buffer[4];
|
||||
|
||||
std::unique_ptr<IOStream> pStream(pIOHandler->Open(pFile));
|
||||
if (pStream && pStream->Read(buffer, sizeof(buffer), 1) == 1) {
|
||||
if (memcmp(buffer, AI_GLB_MAGIC_NUMBER, sizeof(buffer)) == 0) {
|
||||
return true; // Has GLB header
|
||||
}
|
||||
else if (memcmp(buffer, "{\r\n ", sizeof(buffer)) == 0
|
||||
|| memcmp(buffer, "{\n ", sizeof(buffer)) == 0) {
|
||||
// seems a JSON file, and we're the only format that can read them
|
||||
return true;
|
||||
}
|
||||
if (checkSig && pIOHandler) {
|
||||
glTF2::Asset asset(pIOHandler);
|
||||
try {
|
||||
asset.Load(pFile, extension == "glb");
|
||||
return asset.asset.version >= 2;
|
||||
} catch (...) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -1243,10 +1243,6 @@ inline void AssetMetadata::Read(Document& doc)
|
|||
}
|
||||
|
||||
version = std::max(statedVersion, version);
|
||||
if (version == 0) {
|
||||
// if missing version, we'll assume version 1...
|
||||
version = 1;
|
||||
}
|
||||
|
||||
if (version != 1) {
|
||||
char msg[128];
|
||||
|
|
|
@ -102,22 +102,16 @@ bool glTFImporter::CanRead(const std::string& pFile, IOSystem* pIOHandler, bool
|
|||
{
|
||||
const std::string &extension = GetExtension(pFile);
|
||||
|
||||
if (extension == "gltf" || extension == "glb")
|
||||
return true;
|
||||
if (extension != "gltf" && extension != "glb")
|
||||
return false;
|
||||
|
||||
if ((checkSig || !extension.length()) && pIOHandler) {
|
||||
char buffer[4];
|
||||
|
||||
std::unique_ptr<IOStream> pStream(pIOHandler->Open(pFile));
|
||||
if (pStream && pStream->Read(buffer, sizeof(buffer), 1) == 1) {
|
||||
if (memcmp(buffer, AI_GLB_MAGIC_NUMBER, sizeof(buffer)) == 0) {
|
||||
return true; // Has GLB header
|
||||
}
|
||||
else if (memcmp(buffer, "{\r\n ", sizeof(buffer)) == 0
|
||||
|| memcmp(buffer, "{\n ", sizeof(buffer)) == 0) {
|
||||
// seems a JSON file, and we're the only format that can read them
|
||||
return true;
|
||||
}
|
||||
if (checkSig && pIOHandler) {
|
||||
glTF::Asset asset(pIOHandler);
|
||||
try {
|
||||
asset.Load(pFile, extension == "glb");
|
||||
return asset.asset.version < 2;
|
||||
} catch (...) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue