2008-05-09 17:24:28 +00:00
|
|
|
/*
|
2008-05-22 10:20:31 +00:00
|
|
|
Open Asset Import Library (ASSIMP)
|
2008-05-09 17:24:28 +00:00
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
|
|
|
Copyright (c) 2006-2008, ASSIMP Development 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 Development 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.
|
|
|
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2009-04-11 14:31:57 +00:00
|
|
|
/** @file MaterialSystem.h
|
|
|
|
* Definition of the #MaterialHelper utility class.
|
|
|
|
*/
|
2008-05-05 12:36:31 +00:00
|
|
|
#ifndef AI_MATERIALSYSTEM_H_INC
|
|
|
|
#define AI_MATERIALSYSTEM_H_INC
|
|
|
|
|
|
|
|
#include "../include/aiMaterial.h"
|
2009-01-12 22:06:54 +00:00
|
|
|
namespace Assimp {
|
2008-05-05 12:36:31 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
2009-04-11 14:31:57 +00:00
|
|
|
/** Internal material helper class deriving from aiMaterial.
|
|
|
|
*
|
|
|
|
* Intended to be used to fill an aiMaterial structure more easily.
|
|
|
|
*/
|
2008-07-24 11:19:24 +00:00
|
|
|
class ASSIMP_API MaterialHelper : public ::aiMaterial
|
2008-05-05 12:36:31 +00:00
|
|
|
{
|
2008-05-09 17:24:28 +00:00
|
|
|
public:
|
2008-05-05 12:36:31 +00:00
|
|
|
|
2009-04-11 14:31:57 +00:00
|
|
|
// Construction and destruction
|
2008-08-06 23:01:38 +00:00
|
|
|
MaterialHelper();
|
|
|
|
~MaterialHelper();
|
2008-05-05 12:36:31 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
|
|
|
/** @brief Add a property with a given key and type info to the material
|
2008-05-09 17:24:28 +00:00
|
|
|
* structure
|
|
|
|
*
|
2009-01-12 22:06:54 +00:00
|
|
|
* @param pInput Pointer to input data
|
|
|
|
* @param pSizeInBytes Size of input data
|
|
|
|
* @param pKey Key/Usage of the property (AI_MATKEY_XXX)
|
|
|
|
* @param type Set by the AI_MATKEY_XXX macro
|
|
|
|
* @param index Set by the AI_MATKEY_XXX macro
|
|
|
|
* @param pType Type information hint
|
2008-05-09 17:24:28 +00:00
|
|
|
*/
|
2008-05-05 12:36:31 +00:00
|
|
|
aiReturn AddBinaryProperty (const void* pInput,
|
2008-11-16 21:56:45 +00:00
|
|
|
unsigned int pSizeInBytes,
|
2008-05-05 12:36:31 +00:00
|
|
|
const char* pKey,
|
2009-01-12 22:06:54 +00:00
|
|
|
unsigned int type ,
|
|
|
|
unsigned int index ,
|
2008-05-05 12:36:31 +00:00
|
|
|
aiPropertyTypeInfo pType);
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
|
|
|
/** @brief Add a string property with a given key and type info to the
|
2008-05-09 17:24:28 +00:00
|
|
|
* material structure
|
|
|
|
*
|
2009-01-12 22:06:54 +00:00
|
|
|
* @param pInput Input string
|
|
|
|
* @param pKey Key/Usage of the property (AI_MATKEY_XXX)
|
|
|
|
* @param type Set by the AI_MATKEY_XXX macro
|
|
|
|
* @param index Set by the AI_MATKEY_XXX macro
|
2008-05-09 17:24:28 +00:00
|
|
|
*/
|
2008-05-05 12:36:31 +00:00
|
|
|
aiReturn AddProperty (const aiString* pInput,
|
2008-11-16 21:56:45 +00:00
|
|
|
const char* pKey,
|
2009-01-12 22:06:54 +00:00
|
|
|
unsigned int type = 0,
|
|
|
|
unsigned int index = 0);
|
2008-05-05 12:36:31 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
|
|
|
/** @brief Add a property with a given key to the material structure
|
|
|
|
* @param pInput Pointer to the input data
|
|
|
|
* @param pNumValues Number of values in the array
|
|
|
|
* @param pKey Key/Usage of the property (AI_MATKEY_XXX)
|
|
|
|
* @param type Set by the AI_MATKEY_XXX macro
|
|
|
|
* @param index Set by the AI_MATKEY_XXX macro
|
2008-05-09 17:24:28 +00:00
|
|
|
*/
|
2008-05-05 12:36:31 +00:00
|
|
|
template<class TYPE>
|
|
|
|
aiReturn AddProperty (const TYPE* pInput,
|
2008-11-16 21:56:45 +00:00
|
|
|
unsigned int pNumValues,
|
|
|
|
const char* pKey,
|
2009-01-12 22:06:54 +00:00
|
|
|
unsigned int type = 0,
|
|
|
|
unsigned int index = 0);
|
2008-05-09 17:24:28 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
|
|
|
/** @brief Remove a given key from the list.
|
2008-05-13 23:26:52 +00:00
|
|
|
*
|
2009-01-12 22:06:54 +00:00
|
|
|
* The function fails if the key isn't found
|
|
|
|
* @param pKey Key to be deleted
|
2008-05-13 23:26:52 +00:00
|
|
|
*/
|
2008-11-16 21:56:45 +00:00
|
|
|
aiReturn RemoveProperty (const char* pKey,
|
2009-01-12 22:06:54 +00:00
|
|
|
unsigned int type = 0,
|
|
|
|
unsigned int index = 0);
|
2008-05-13 23:26:52 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
|
|
|
/** @brief Removes all properties from the material.
|
|
|
|
*
|
2009-04-11 14:31:57 +00:00
|
|
|
* The data array remains allocated so adding new properties is quite fast.
|
2008-10-19 11:32:33 +00:00
|
|
|
*/
|
|
|
|
void Clear();
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
2008-07-30 23:00:25 +00:00
|
|
|
/** Computes a hash (hopefully unique) from all material properties
|
2009-01-12 22:06:54 +00:00
|
|
|
* The hash value reflects the current property state, so if you add any
|
|
|
|
* proprty and call this method again, the resulting hash value will be
|
|
|
|
* different.
|
2008-07-30 23:00:25 +00:00
|
|
|
*
|
2009-02-15 20:29:07 +00:00
|
|
|
* @param includeMatName Set to 'true' to take all properties with
|
|
|
|
* '?' as initial character in their name into account.
|
|
|
|
* Currently #AI_MATKEY_NAME is the only example.
|
2009-01-12 22:06:54 +00:00
|
|
|
* @return Unique hash
|
2008-07-30 23:00:25 +00:00
|
|
|
*/
|
2009-01-12 22:06:54 +00:00
|
|
|
uint32_t ComputeHash(bool includeMatName = false);
|
2008-07-30 23:00:25 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ------------------------------------------------------------------------------
|
2008-05-09 17:24:28 +00:00
|
|
|
/** Copy the property list of a material
|
2009-04-11 14:31:57 +00:00
|
|
|
* @param pcDest Destination material
|
|
|
|
* @param pcSrc Source material
|
2008-05-09 17:24:28 +00:00
|
|
|
*/
|
|
|
|
static void CopyPropertyList(MaterialHelper* pcDest,
|
|
|
|
const MaterialHelper* pcSrc);
|
2009-01-12 22:06:54 +00:00
|
|
|
|
2009-04-11 14:31:57 +00:00
|
|
|
public:
|
|
|
|
// For internal use. That's why it's public.
|
2009-01-12 22:06:54 +00:00
|
|
|
void _InternDestruct();
|
2008-05-05 12:36:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
2008-05-05 12:36:31 +00:00
|
|
|
template<class TYPE>
|
|
|
|
aiReturn MaterialHelper::AddProperty (const TYPE* pInput,
|
|
|
|
const unsigned int pNumValues,
|
2008-11-16 21:56:45 +00:00
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
2008-05-05 12:36:31 +00:00
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
return AddBinaryProperty((const void*)pInput,
|
2008-05-05 12:36:31 +00:00
|
|
|
pNumValues * sizeof(TYPE),
|
2008-11-16 21:56:45 +00:00
|
|
|
pKey,type,index,aiPTI_Buffer);
|
2008-05-05 12:36:31 +00:00
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
2008-05-05 12:36:31 +00:00
|
|
|
template<>
|
|
|
|
inline aiReturn MaterialHelper::AddProperty<float> (const float* pInput,
|
|
|
|
const unsigned int pNumValues,
|
2008-11-16 21:56:45 +00:00
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
2008-05-05 12:36:31 +00:00
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
return AddBinaryProperty((const void*)pInput,
|
2008-05-05 12:36:31 +00:00
|
|
|
pNumValues * sizeof(float),
|
2008-11-16 21:56:45 +00:00
|
|
|
pKey,type,index,aiPTI_Float);
|
2008-05-05 12:36:31 +00:00
|
|
|
}
|
|
|
|
|
2009-02-08 22:55:51 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
|
|
|
template<>
|
|
|
|
inline aiReturn MaterialHelper::AddProperty<aiUVTransform> (const aiUVTransform* pInput,
|
|
|
|
const unsigned int pNumValues,
|
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
|
|
|
{
|
|
|
|
return AddBinaryProperty((const void*)pInput,
|
|
|
|
pNumValues * sizeof(aiUVTransform),
|
|
|
|
pKey,type,index,aiPTI_Float);
|
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
2008-05-05 12:36:31 +00:00
|
|
|
template<>
|
|
|
|
inline aiReturn MaterialHelper::AddProperty<aiColor4D> (const aiColor4D* pInput,
|
|
|
|
const unsigned int pNumValues,
|
2008-11-16 21:56:45 +00:00
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
2008-05-05 12:36:31 +00:00
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
return AddBinaryProperty((const void*)pInput,
|
2008-05-05 12:36:31 +00:00
|
|
|
pNumValues * sizeof(aiColor4D),
|
2008-11-16 21:56:45 +00:00
|
|
|
pKey,type,index,aiPTI_Float);
|
2008-05-05 12:36:31 +00:00
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
2008-05-05 12:36:31 +00:00
|
|
|
template<>
|
|
|
|
inline aiReturn MaterialHelper::AddProperty<aiColor3D> (const aiColor3D* pInput,
|
|
|
|
const unsigned int pNumValues,
|
2008-11-16 21:56:45 +00:00
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
2008-05-05 12:36:31 +00:00
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
return AddBinaryProperty((const void*)pInput,
|
2008-05-05 12:36:31 +00:00
|
|
|
pNumValues * sizeof(aiColor3D),
|
2008-11-16 21:56:45 +00:00
|
|
|
pKey,type,index,aiPTI_Float);
|
2008-05-05 12:36:31 +00:00
|
|
|
}
|
|
|
|
|
2009-02-11 20:56:05 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
|
|
|
template<>
|
|
|
|
inline aiReturn MaterialHelper::AddProperty<aiVector3D> (const aiVector3D* pInput,
|
|
|
|
const unsigned int pNumValues,
|
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
|
|
|
{
|
|
|
|
return AddBinaryProperty((const void*)pInput,
|
|
|
|
pNumValues * sizeof(aiVector3D),
|
|
|
|
pKey,type,index,aiPTI_Float);
|
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// ----------------------------------------------------------------------------------------
|
2008-05-05 12:36:31 +00:00
|
|
|
template<>
|
|
|
|
inline aiReturn MaterialHelper::AddProperty<int> (const int* pInput,
|
|
|
|
const unsigned int pNumValues,
|
2008-11-16 21:56:45 +00:00
|
|
|
const char* pKey,
|
|
|
|
unsigned int type,
|
|
|
|
unsigned int index)
|
2008-05-05 12:36:31 +00:00
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
return AddBinaryProperty((const void*)pInput,
|
2008-05-05 12:36:31 +00:00
|
|
|
pNumValues * sizeof(int),
|
2008-11-16 21:56:45 +00:00
|
|
|
pKey,type,index,aiPTI_Integer);
|
2008-05-05 12:36:31 +00:00
|
|
|
}
|
2009-01-12 22:06:54 +00:00
|
|
|
} // ! namespace Assimp
|
2008-05-05 12:36:31 +00:00
|
|
|
|
2008-06-22 10:09:26 +00:00
|
|
|
#endif //!! AI_MATERIALSYSTEM_H_INC
|