2014-05-18 08:57:44 +00:00
|
|
|
/*
|
|
|
|
Open Asset Import Library (assimp)
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
|
|
|
Copyright (c) 2006-2012, assimp team
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use of this software in source and binary forms,
|
|
|
|
with or without modification, are permitted provided that the
|
|
|
|
following conditions are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above
|
|
|
|
copyright notice, this list of conditions and the
|
|
|
|
following disclaimer.
|
|
|
|
|
|
|
|
* Redistributions in binary form must reproduce the above
|
|
|
|
copyright notice, this list of conditions and the
|
|
|
|
following disclaimer in the documentation and/or other
|
|
|
|
materials provided with the distribution.
|
|
|
|
|
|
|
|
* Neither the name of the assimp team, nor the names of its
|
|
|
|
contributors may be used to endorse or promote products
|
|
|
|
derived from this software without specific prior
|
|
|
|
written permission of the assimp team.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
*/
|
2012-02-20 10:27:27 +00:00
|
|
|
|
2014-05-01 14:19:03 +00:00
|
|
|
#ifndef AI_OGREIMPORTER_H_INC
|
|
|
|
#define AI_OGREIMPORTER_H_INC
|
|
|
|
|
|
|
|
#ifndef ASSIMP_BUILD_NO_OGRE_IMPORTER
|
|
|
|
|
2014-04-30 02:43:13 +00:00
|
|
|
#include "BaseImporter.h"
|
2014-05-18 08:57:44 +00:00
|
|
|
|
|
|
|
#include "OgreStructs.h"
|
2014-05-01 13:49:26 +00:00
|
|
|
#include "OgreParsingUtils.h"
|
2012-02-20 10:27:27 +00:00
|
|
|
|
2015-04-15 23:00:17 +00:00
|
|
|
#include "../include/assimp/material.h"
|
|
|
|
|
2012-02-20 10:27:27 +00:00
|
|
|
namespace Assimp
|
|
|
|
{
|
|
|
|
namespace Ogre
|
|
|
|
{
|
|
|
|
|
2014-04-30 02:52:59 +00:00
|
|
|
/** Importer for Ogre mesh, skeleton and material formats.
|
2014-05-20 01:52:53 +00:00
|
|
|
@todo Support vertex colors.
|
|
|
|
@todo Support poses/animations from the mesh file.
|
|
|
|
Currently only skeleton file animations are supported. */
|
2012-02-20 10:27:27 +00:00
|
|
|
class OgreImporter : public BaseImporter
|
|
|
|
{
|
|
|
|
public:
|
2014-04-30 02:43:13 +00:00
|
|
|
/// BaseImporter override.
|
2014-05-01 21:19:57 +00:00
|
|
|
virtual bool CanRead(const std::string &pFile, IOSystem *pIOHandler, bool checkSig) const;
|
2014-04-30 02:43:13 +00:00
|
|
|
|
|
|
|
/// BaseImporter override.
|
2014-05-01 21:19:57 +00:00
|
|
|
virtual void InternReadFile(const std::string &pFile, aiScene *pScene, IOSystem *pIOHandler);
|
2014-04-30 02:43:13 +00:00
|
|
|
|
|
|
|
/// BaseImporter override.
|
2014-05-01 21:19:57 +00:00
|
|
|
virtual const aiImporterDesc *GetInfo() const;
|
2014-04-30 02:43:13 +00:00
|
|
|
|
|
|
|
/// BaseImporter override.
|
2014-05-01 21:19:57 +00:00
|
|
|
virtual void SetupProperties(const Importer *pImp);
|
2012-03-13 16:29:29 +00:00
|
|
|
|
2014-04-30 02:43:13 +00:00
|
|
|
private:
|
2014-05-18 08:57:44 +00:00
|
|
|
/// Read materials referenced by the @c mesh to @c pScene.
|
|
|
|
void ReadMaterials(const std::string &pFile, Assimp::IOSystem *pIOHandler, aiScene *pScene, Mesh *mesh);
|
2014-05-20 01:52:53 +00:00
|
|
|
void ReadMaterials(const std::string &pFile, Assimp::IOSystem *pIOHandler, aiScene *pScene, MeshXml *mesh);
|
|
|
|
void AssignMaterials(aiScene *pScene, std::vector<aiMaterial*> &materials);
|
2014-05-18 08:57:44 +00:00
|
|
|
|
2014-05-01 13:33:15 +00:00
|
|
|
/// Reads material
|
2015-06-05 07:52:06 +00:00
|
|
|
aiMaterial* ReadMaterial(const std::string &pFile, Assimp::IOSystem *pIOHandler, const std::string &MaterialName);
|
2014-05-01 13:33:15 +00:00
|
|
|
|
|
|
|
// These functions parse blocks from a material file from @c ss. Starting parsing from "{" and ending it to "}".
|
|
|
|
bool ReadTechnique(const std::string &techniqueName, std::stringstream &ss, aiMaterial *material);
|
|
|
|
bool ReadPass(const std::string &passName, std::stringstream &ss, aiMaterial *material);
|
|
|
|
bool ReadTextureUnit(const std::string &textureUnitName, std::stringstream &ss, aiMaterial *material);
|
2012-03-13 16:29:29 +00:00
|
|
|
|
2014-05-01 13:33:15 +00:00
|
|
|
std::string m_userDefinedMaterialLibFile;
|
|
|
|
bool m_detectTextureTypeFromFilename;
|
|
|
|
|
|
|
|
std::map<aiTextureType, unsigned int> m_textures;
|
2012-02-20 10:27:27 +00:00
|
|
|
};
|
2014-05-01 22:54:42 +00:00
|
|
|
} // Ogre
|
|
|
|
} // Assimp
|
2014-05-01 14:19:03 +00:00
|
|
|
|
|
|
|
#endif // ASSIMP_BUILD_NO_OGRE_IMPORTER
|
|
|
|
#endif // AI_OGREIMPORTER_H_INC
|