Merge branch 'master' into feature/easy-armature-lookup
commit
be09110aa8
|
@ -253,7 +253,7 @@ ELSEIF(MSVC)
|
||||||
IF(MSVC12)
|
IF(MSVC12)
|
||||||
ADD_COMPILE_OPTIONS(/wd4351)
|
ADD_COMPILE_OPTIONS(/wd4351)
|
||||||
ENDIF()
|
ENDIF()
|
||||||
SET(CMAKE_CXX_FLAGS_DEBUG "/D_DEBUG /MDd /Ob2 /DEBUG:FULL /Zi")
|
SET(CMAKE_CXX_FLAGS_DEBUG "/D_DEBUG /MDd /Ob2 /Zi")
|
||||||
ELSEIF ( "${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang" )
|
ELSEIF ( "${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang" )
|
||||||
IF(NOT HUNTER_ENABLED)
|
IF(NOT HUNTER_ENABLED)
|
||||||
SET(CMAKE_CXX_FLAGS "-fPIC -std=c++11 ${CMAKE_CXX_FLAGS}")
|
SET(CMAKE_CXX_FLAGS "-fPIC -std=c++11 ${CMAKE_CXX_FLAGS}")
|
||||||
|
|
|
@ -72,7 +72,7 @@ void Discreet3DSImporter::ReplaceDefaultMaterial()
|
||||||
unsigned int idx( NotSet );
|
unsigned int idx( NotSet );
|
||||||
for (unsigned int i = 0; i < mScene->mMaterials.size();++i)
|
for (unsigned int i = 0; i < mScene->mMaterials.size();++i)
|
||||||
{
|
{
|
||||||
std::string &s = mScene->mMaterials[i].mName;
|
std::string s = mScene->mMaterials[i].mName;
|
||||||
for ( std::string::iterator it = s.begin(); it != s.end(); ++it ) {
|
for ( std::string::iterator it = s.begin(); it != s.end(); ++it ) {
|
||||||
*it = static_cast< char >( ::tolower( *it ) );
|
*it = static_cast< char >( ::tolower( *it ) );
|
||||||
}
|
}
|
||||||
|
|
|
@ -583,7 +583,7 @@ struct Image
|
||||||
/** Embedded image data */
|
/** Embedded image data */
|
||||||
std::vector<uint8_t> mImageData;
|
std::vector<uint8_t> mImageData;
|
||||||
|
|
||||||
/** File format hint ofembedded image data */
|
/** File format hint of embedded image data */
|
||||||
std::string mEmbeddedFormat;
|
std::string mEmbeddedFormat;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1735,6 +1735,7 @@ void ColladaLoader::BuildMaterials(ColladaParser& pParser, aiScene* /*pScene*/)
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
// Resolves the texture name for the given effect texture entry
|
// Resolves the texture name for the given effect texture entry
|
||||||
|
// and loads the texture data
|
||||||
aiString ColladaLoader::FindFilenameForEffectTexture(const ColladaParser& pParser,
|
aiString ColladaLoader::FindFilenameForEffectTexture(const ColladaParser& pParser,
|
||||||
const Collada::Effect& pEffect, const std::string& pName)
|
const Collada::Effect& pEffect, const std::string& pName)
|
||||||
{
|
{
|
||||||
|
@ -1762,7 +1763,7 @@ aiString ColladaLoader::FindFilenameForEffectTexture(const ColladaParser& pParse
|
||||||
|
|
||||||
//set default texture file name
|
//set default texture file name
|
||||||
result.Set(name + ".jpg");
|
result.Set(name + ".jpg");
|
||||||
ConvertPath(result);
|
ColladaParser::UriDecodePath(result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1781,7 +1782,7 @@ aiString ColladaLoader::FindFilenameForEffectTexture(const ColladaParser& pParse
|
||||||
|
|
||||||
|
|
||||||
// setup format hint
|
// setup format hint
|
||||||
if (imIt->second.mEmbeddedFormat.length() > 3) {
|
if (imIt->second.mEmbeddedFormat.length() >= HINTMAXTEXTURELEN) {
|
||||||
ASSIMP_LOG_WARN("Collada: texture format hint is too long, truncating to 3 characters");
|
ASSIMP_LOG_WARN("Collada: texture format hint is too long, truncating to 3 characters");
|
||||||
}
|
}
|
||||||
strncpy(tex->achFormatHint, imIt->second.mEmbeddedFormat.c_str(), 3);
|
strncpy(tex->achFormatHint, imIt->second.mEmbeddedFormat.c_str(), 3);
|
||||||
|
@ -1802,61 +1803,10 @@ aiString ColladaLoader::FindFilenameForEffectTexture(const ColladaParser& pParse
|
||||||
}
|
}
|
||||||
|
|
||||||
result.Set(imIt->second.mFileName);
|
result.Set(imIt->second.mFileName);
|
||||||
ConvertPath(result);
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
|
||||||
// Convert a path read from a collada file to the usual representation
|
|
||||||
void ColladaLoader::ConvertPath(aiString& ss)
|
|
||||||
{
|
|
||||||
// TODO: collada spec, p 22. Handle URI correctly.
|
|
||||||
// For the moment we're just stripping the file:// away to make it work.
|
|
||||||
// Windows doesn't seem to be able to find stuff like
|
|
||||||
// 'file://..\LWO\LWO2\MappingModes\earthSpherical.jpg'
|
|
||||||
if (0 == strncmp(ss.data, "file://", 7))
|
|
||||||
{
|
|
||||||
ss.length -= 7;
|
|
||||||
memmove(ss.data, ss.data + 7, ss.length);
|
|
||||||
ss.data[ss.length] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Maxon Cinema Collada Export writes "file:///C:\andsoon" with three slashes...
|
|
||||||
// I need to filter it without destroying linux paths starting with "/somewhere"
|
|
||||||
#if defined( _MSC_VER )
|
|
||||||
if (ss.data[0] == '/' && isalpha((unsigned char)ss.data[1]) && ss.data[2] == ':') {
|
|
||||||
#else
|
|
||||||
if (ss.data[0] == '/' && isalpha(ss.data[1]) && ss.data[2] == ':') {
|
|
||||||
#endif
|
|
||||||
--ss.length;
|
|
||||||
::memmove(ss.data, ss.data + 1, ss.length);
|
|
||||||
ss.data[ss.length] = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// find and convert all %xy special chars
|
|
||||||
char* out = ss.data;
|
|
||||||
for (const char* it = ss.data; it != ss.data + ss.length; /**/)
|
|
||||||
{
|
|
||||||
if (*it == '%' && (it + 3) < ss.data + ss.length)
|
|
||||||
{
|
|
||||||
// separate the number to avoid dragging in chars from behind into the parsing
|
|
||||||
char mychar[3] = { it[1], it[2], 0 };
|
|
||||||
size_t nbr = strtoul16(mychar);
|
|
||||||
it += 3;
|
|
||||||
*out++ = (char)(nbr & 0xFF);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
*out++ = *it++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// adjust length and terminator of the shortened string
|
|
||||||
*out = 0;
|
|
||||||
ss.length = (ptrdiff_t)(out - ss.data);
|
|
||||||
}
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
// Reads a float value from an accessor and its data array.
|
// Reads a float value from an accessor and its data array.
|
||||||
ai_real ColladaLoader::ReadFloat(const Collada::Accessor& pAccessor, const Collada::Data& pData, size_t pIndex, size_t pOffset) const
|
ai_real ColladaLoader::ReadFloat(const Collada::Accessor& pAccessor, const Collada::Data& pData, size_t pIndex, size_t pOffset) const
|
||||||
|
|
|
@ -94,7 +94,7 @@ public:
|
||||||
public:
|
public:
|
||||||
/** Returns whether the class can handle the format of the given file.
|
/** Returns whether the class can handle the format of the given file.
|
||||||
* See BaseImporter::CanRead() for details. */
|
* See BaseImporter::CanRead() for details. */
|
||||||
bool CanRead( const std::string& pFile, IOSystem* pIOHandler, bool checkSig) const override;
|
bool CanRead(const std::string& pFile, IOSystem* pIOHandler, bool checkSig) const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/** Return importer meta information.
|
/** Return importer meta information.
|
||||||
|
@ -184,9 +184,6 @@ protected:
|
||||||
aiString FindFilenameForEffectTexture( const ColladaParser& pParser,
|
aiString FindFilenameForEffectTexture( const ColladaParser& pParser,
|
||||||
const Collada::Effect& pEffect, const std::string& pName);
|
const Collada::Effect& pEffect, const std::string& pName);
|
||||||
|
|
||||||
/** Converts a path read from a collada file to the usual representation */
|
|
||||||
void ConvertPath( aiString& ss);
|
|
||||||
|
|
||||||
/** Reads a float value from an accessor and its data array.
|
/** Reads a float value from an accessor and its data array.
|
||||||
* @param pAccessor The accessor to use for reading
|
* @param pAccessor The accessor to use for reading
|
||||||
* @param pData The data array to read from
|
* @param pData The data array to read from
|
||||||
|
|
|
@ -183,13 +183,67 @@ std::string ColladaParser::ReadZaeManifest(ZipArchiveIOSystem &zip_archive) {
|
||||||
if (filepath == nullptr)
|
if (filepath == nullptr)
|
||||||
return std::string();
|
return std::string();
|
||||||
|
|
||||||
return std::string(filepath);
|
aiString ai_str(filepath);
|
||||||
|
UriDecodePath(ai_str);
|
||||||
|
|
||||||
|
return std::string(ai_str.C_Str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return std::string();
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
// Convert a path read from a collada file to the usual representation
|
||||||
|
void ColladaParser::UriDecodePath(aiString& ss)
|
||||||
|
{
|
||||||
|
// TODO: collada spec, p 22. Handle URI correctly.
|
||||||
|
// For the moment we're just stripping the file:// away to make it work.
|
||||||
|
// Windows doesn't seem to be able to find stuff like
|
||||||
|
// 'file://..\LWO\LWO2\MappingModes\earthSpherical.jpg'
|
||||||
|
if (0 == strncmp(ss.data, "file://", 7))
|
||||||
|
{
|
||||||
|
ss.length -= 7;
|
||||||
|
memmove(ss.data, ss.data + 7, ss.length);
|
||||||
|
ss.data[ss.length] = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Maxon Cinema Collada Export writes "file:///C:\andsoon" with three slashes...
|
||||||
|
// I need to filter it without destroying linux paths starting with "/somewhere"
|
||||||
|
#if defined( _MSC_VER )
|
||||||
|
if (ss.data[0] == '/' && isalpha((unsigned char)ss.data[1]) && ss.data[2] == ':') {
|
||||||
|
#else
|
||||||
|
if (ss.data[0] == '/' && isalpha(ss.data[1]) && ss.data[2] == ':') {
|
||||||
|
#endif
|
||||||
|
--ss.length;
|
||||||
|
::memmove(ss.data, ss.data + 1, ss.length);
|
||||||
|
ss.data[ss.length] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// find and convert all %xy special chars
|
||||||
|
char* out = ss.data;
|
||||||
|
for (const char* it = ss.data; it != ss.data + ss.length; /**/)
|
||||||
|
{
|
||||||
|
if (*it == '%' && (it + 3) < ss.data + ss.length)
|
||||||
|
{
|
||||||
|
// separate the number to avoid dragging in chars from behind into the parsing
|
||||||
|
char mychar[3] = { it[1], it[2], 0 };
|
||||||
|
size_t nbr = strtoul16(mychar);
|
||||||
|
it += 3;
|
||||||
|
*out++ = (char)(nbr & 0xFF);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
*out++ = *it++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// adjust length and terminator of the shortened string
|
||||||
|
*out = 0;
|
||||||
|
ai_assert(out > ss.data);
|
||||||
|
ss.length = static_cast<ai_uint32>(out - ss.data);
|
||||||
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
// Read bool from text contents of current element
|
// Read bool from text contents of current element
|
||||||
bool ColladaParser::ReadBoolFromTextContent()
|
bool ColladaParser::ReadBoolFromTextContent()
|
||||||
|
@ -1120,7 +1174,12 @@ void ColladaParser::ReadImage(Collada::Image& pImage)
|
||||||
if (!mReader->isEmptyElement()) {
|
if (!mReader->isEmptyElement()) {
|
||||||
// element content is filename - hopefully
|
// element content is filename - hopefully
|
||||||
const char* sz = TestTextContent();
|
const char* sz = TestTextContent();
|
||||||
if (sz)pImage.mFileName = sz;
|
if (sz)
|
||||||
|
{
|
||||||
|
aiString filepath(sz);
|
||||||
|
UriDecodePath(filepath);
|
||||||
|
pImage.mFileName = filepath.C_Str();
|
||||||
|
}
|
||||||
TestClosing("init_from");
|
TestClosing("init_from");
|
||||||
}
|
}
|
||||||
if (!pImage.mFileName.length()) {
|
if (!pImage.mFileName.length()) {
|
||||||
|
@ -1153,7 +1212,12 @@ void ColladaParser::ReadImage(Collada::Image& pImage)
|
||||||
{
|
{
|
||||||
// element content is filename - hopefully
|
// element content is filename - hopefully
|
||||||
const char* sz = TestTextContent();
|
const char* sz = TestTextContent();
|
||||||
if (sz)pImage.mFileName = sz;
|
if (sz)
|
||||||
|
{
|
||||||
|
aiString filepath(sz);
|
||||||
|
UriDecodePath(filepath);
|
||||||
|
pImage.mFileName = filepath.C_Str();
|
||||||
|
}
|
||||||
TestClosing("ref");
|
TestClosing("ref");
|
||||||
}
|
}
|
||||||
else if (IsElement("hex") && !pImage.mFileName.length())
|
else if (IsElement("hex") && !pImage.mFileName.length())
|
||||||
|
@ -3056,7 +3120,7 @@ void ColladaParser::ReadMaterialVertexInputBinding(Collada::SemanticMappingTable
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Assimp::ColladaParser::ReadEmbeddedTextures(ZipArchiveIOSystem& zip_archive)
|
void ColladaParser::ReadEmbeddedTextures(ZipArchiveIOSystem& zip_archive)
|
||||||
{
|
{
|
||||||
// Attempt to load any undefined Collada::Image in ImageLibrary
|
// Attempt to load any undefined Collada::Image in ImageLibrary
|
||||||
for (ImageLibrary::iterator it = mImageLibrary.begin(); it != mImageLibrary.end(); ++it) {
|
for (ImageLibrary::iterator it = mImageLibrary.begin(); it != mImageLibrary.end(); ++it) {
|
||||||
|
|
|
@ -66,12 +66,15 @@ namespace Assimp
|
||||||
{
|
{
|
||||||
friend class ColladaLoader;
|
friend class ColladaLoader;
|
||||||
|
|
||||||
|
/** Converts a path read from a collada file to the usual representation */
|
||||||
|
static void UriDecodePath(aiString& ss);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/** Map for generic metadata as aiString */
|
/** Map for generic metadata as aiString */
|
||||||
typedef std::map<std::string, aiString> StringMetaData;
|
typedef std::map<std::string, aiString> StringMetaData;
|
||||||
|
|
||||||
/** Constructor from XML file */
|
/** Constructor from XML file */
|
||||||
ColladaParser( IOSystem* pIOHandler, const std::string& pFile);
|
ColladaParser(IOSystem* pIOHandler, const std::string& pFile);
|
||||||
|
|
||||||
/** Destructor */
|
/** Destructor */
|
||||||
~ColladaParser();
|
~ColladaParser();
|
||||||
|
|
|
@ -46,8 +46,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include <assimp/scene.h>
|
#include <assimp/scene.h>
|
||||||
#include "ScenePrivate.h"
|
#include "ScenePrivate.h"
|
||||||
|
|
||||||
static const unsigned int MajorVersion = 5;
|
#include "revision.h"
|
||||||
static const unsigned int MinorVersion = 0;
|
|
||||||
|
|
||||||
// --------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------
|
||||||
// Legal information string - don't remove this.
|
// Legal information string - don't remove this.
|
||||||
|
@ -56,9 +55,9 @@ static const char* LEGAL_INFORMATION =
|
||||||
"Open Asset Import Library (Assimp).\n"
|
"Open Asset Import Library (Assimp).\n"
|
||||||
"A free C/C++ library to import various 3D file formats into applications\n\n"
|
"A free C/C++ library to import various 3D file formats into applications\n\n"
|
||||||
|
|
||||||
"(c) 2008-2017, assimp team\n"
|
"(c) 2006-2019, assimp team\n"
|
||||||
"License under the terms and conditions of the 3-clause BSD license\n"
|
"License under the terms and conditions of the 3-clause BSD license\n"
|
||||||
"http://assimp.sourceforge.net\n"
|
"http://assimp.org\n"
|
||||||
;
|
;
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
@ -70,13 +69,13 @@ ASSIMP_API const char* aiGetLegalString () {
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
// Get Assimp minor version
|
// Get Assimp minor version
|
||||||
ASSIMP_API unsigned int aiGetVersionMinor () {
|
ASSIMP_API unsigned int aiGetVersionMinor () {
|
||||||
return MinorVersion;
|
return VER_MINOR;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
// Get Assimp major version
|
// Get Assimp major version
|
||||||
ASSIMP_API unsigned int aiGetVersionMajor () {
|
ASSIMP_API unsigned int aiGetVersionMajor () {
|
||||||
return MajorVersion;
|
return VER_MAJOR;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
@ -104,9 +103,6 @@ ASSIMP_API unsigned int aiGetCompileFlags () {
|
||||||
return flags;
|
return flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
// include current build revision, which is even updated from time to time -- :-)
|
|
||||||
#include "revision.h"
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
ASSIMP_API unsigned int aiGetVersionRevision() {
|
ASSIMP_API unsigned int aiGetVersionRevision() {
|
||||||
return GitVersion;
|
return GitVersion;
|
||||||
|
|
|
@ -358,7 +358,7 @@ namespace glTF2 {
|
||||||
WriteVec(pbrSpecularGlossiness, pbrSG.specularFactor, "specularFactor", defaultSpecularFactor, w.mAl);
|
WriteVec(pbrSpecularGlossiness, pbrSG.specularFactor, "specularFactor", defaultSpecularFactor, w.mAl);
|
||||||
|
|
||||||
if (pbrSG.glossinessFactor != 1) {
|
if (pbrSG.glossinessFactor != 1) {
|
||||||
WriteFloat(obj, pbrSG.glossinessFactor, "glossinessFactor", w.mAl);
|
WriteFloat(pbrSpecularGlossiness, pbrSG.glossinessFactor, "glossinessFactor", w.mAl);
|
||||||
}
|
}
|
||||||
|
|
||||||
WriteTex(pbrSpecularGlossiness, pbrSG.diffuseTexture, "diffuseTexture", w.mAl);
|
WriteTex(pbrSpecularGlossiness, pbrSG.diffuseTexture, "diffuseTexture", w.mAl);
|
||||||
|
|
|
@ -320,7 +320,9 @@ void glTF2Exporter::GetMatTex(const aiMaterial* mat, Ref<Texture>& texture, aiTe
|
||||||
if (path[0] == '*') { // embedded
|
if (path[0] == '*') { // embedded
|
||||||
aiTexture* tex = mScene->mTextures[atoi(&path[1])];
|
aiTexture* tex = mScene->mTextures[atoi(&path[1])];
|
||||||
|
|
||||||
uint8_t* data = reinterpret_cast<uint8_t*>(tex->pcData);
|
// copy data since lifetime control is handed over to the asset
|
||||||
|
uint8_t* data = new uint8_t[tex->mWidth];
|
||||||
|
memcpy(data, tex->pcData, tex->mWidth);
|
||||||
texture->source->SetData(data, tex->mWidth, *mAsset);
|
texture->source->SetData(data, tex->mWidth, *mAsset);
|
||||||
|
|
||||||
if (tex->achFormatHint[0]) {
|
if (tex->achFormatHint[0]) {
|
||||||
|
|
Binary file not shown.
|
@ -44,6 +44,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include "AbstractImportExportBase.h"
|
#include "AbstractImportExportBase.h"
|
||||||
|
|
||||||
#include <assimp/Importer.hpp>
|
#include <assimp/Importer.hpp>
|
||||||
|
#include <assimp/scene.h>
|
||||||
#include <assimp/postprocess.h>
|
#include <assimp/postprocess.h>
|
||||||
|
|
||||||
using namespace Assimp;
|
using namespace Assimp;
|
||||||
|
@ -52,8 +53,19 @@ class utColladaImportExport : public AbstractImportExportBase {
|
||||||
public:
|
public:
|
||||||
virtual bool importerTest() {
|
virtual bool importerTest() {
|
||||||
Assimp::Importer importer;
|
Assimp::Importer importer;
|
||||||
const aiScene *scene = importer.ReadFile( ASSIMP_TEST_MODELS_DIR "/Collada/duck.dae", aiProcess_ValidateDataStructure );
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/Collada/duck.dae", aiProcess_ValidateDataStructure);
|
||||||
return nullptr != scene;
|
if (scene == nullptr)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Expected number of items
|
||||||
|
EXPECT_EQ(scene->mNumMeshes, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumMaterials, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumAnimations, 0u);
|
||||||
|
EXPECT_EQ(scene->mNumTextures, 0u);
|
||||||
|
EXPECT_EQ(scene->mNumLights, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumCameras, 1u);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -64,9 +76,37 @@ TEST_F(utColladaImportExport, importBlenFromFileTest) {
|
||||||
class utColladaZaeImportExport : public AbstractImportExportBase {
|
class utColladaZaeImportExport : public AbstractImportExportBase {
|
||||||
public:
|
public:
|
||||||
virtual bool importerTest() {
|
virtual bool importerTest() {
|
||||||
Assimp::Importer importer;
|
{
|
||||||
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/Collada/duck.zae", aiProcess_ValidateDataStructure);
|
Assimp::Importer importer;
|
||||||
return nullptr != scene;
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/Collada/duck.zae", aiProcess_ValidateDataStructure);
|
||||||
|
if (scene == nullptr)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Expected number of items
|
||||||
|
EXPECT_EQ(scene->mNumMeshes, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumMaterials, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumAnimations, 0u);
|
||||||
|
EXPECT_EQ(scene->mNumTextures, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumLights, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumCameras, 1u);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
Assimp::Importer importer;
|
||||||
|
const aiScene *scene = importer.ReadFile(ASSIMP_TEST_MODELS_DIR "/Collada/duck_nomanifest.zae", aiProcess_ValidateDataStructure);
|
||||||
|
if (scene == nullptr)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Expected number of items
|
||||||
|
EXPECT_EQ(scene->mNumMeshes, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumMaterials, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumAnimations, 0u);
|
||||||
|
EXPECT_EQ(scene->mNumTextures, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumLights, 1u);
|
||||||
|
EXPECT_EQ(scene->mNumCameras, 1u);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,7 @@ TEST_F( utVersion, aiGetLegalStringTest ) {
|
||||||
EXPECT_NE( lv, nullptr );
|
EXPECT_NE( lv, nullptr );
|
||||||
std::string text( lv );
|
std::string text( lv );
|
||||||
|
|
||||||
size_t pos( text.find( std::string( "2017" ) ) );
|
size_t pos( text.find( std::string( "2019" ) ) );
|
||||||
EXPECT_NE( pos, std::string::npos );
|
EXPECT_NE( pos, std::string::npos );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue