226 lines
6.2 KiB
C++
226 lines
6.2 KiB
C++
/*
|
|
Open Asset Import Library (ASSIMP)
|
|
----------------------------------------------------------------------
|
|
|
|
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.
|
|
|
|
----------------------------------------------------------------------
|
|
*/
|
|
|
|
/** @file Definition of a helper step that processes texture transformations */
|
|
#ifndef AI_TEXTURE_TRANSFORM_H_INCLUDED
|
|
#define AI_TEXTURE_TRANSFORM_H_INCLUDED
|
|
|
|
#include "BaseImporter.h"
|
|
#include "BaseProcess.h"
|
|
|
|
struct aiNode;
|
|
|
|
namespace Assimp {
|
|
|
|
#define AI_TT_UV_IDX_LOCK_TBD 0xffffffff
|
|
#define AI_TT_UV_IDX_LOCK_NONE 0xeeeeeeee
|
|
|
|
|
|
#define AI_TT_ROTATION_EPSILON ((float)AI_DEG_TO_RAD(0.5))
|
|
|
|
// ---------------------------------------------------------------------------
|
|
/** Small helper structure representing a shortcut into the material list
|
|
* to be able to update some values quickly.
|
|
*/
|
|
struct TTUpdateInfo
|
|
{
|
|
TTUpdateInfo()
|
|
: mat (NULL)
|
|
, directShortcut (NULL)
|
|
, semantic (0)
|
|
, index (0)
|
|
{}
|
|
|
|
//! Direct shortcut, if available
|
|
unsigned int* directShortcut;
|
|
|
|
//! Material
|
|
MaterialHelper* mat;
|
|
|
|
//! Texture type and index
|
|
unsigned int semantic, index;
|
|
};
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
/** Helper class representing texture coordinate transformations
|
|
*/
|
|
struct STransformVecInfo : public aiUVTransform
|
|
{
|
|
|
|
STransformVecInfo()
|
|
: uvIndex (0)
|
|
, mapU (aiTextureMapMode_Wrap)
|
|
, mapV (aiTextureMapMode_Wrap)
|
|
, lockedPos (AI_TT_UV_IDX_LOCK_NONE)
|
|
{}
|
|
|
|
//! Source texture coordinate index
|
|
unsigned int uvIndex;
|
|
|
|
//! Texture mapping mode in the u, v direction
|
|
aiTextureMapMode mapU,mapV;
|
|
|
|
//! Locked destination UV index
|
|
//! AI_TT_UV_IDX_LOCK_TBD - to be determined
|
|
//! AI_TT_UV_IDX_LOCK_NONE - none (default)
|
|
unsigned int lockedPos;
|
|
|
|
//! Update info - shortcuts into all materials
|
|
//! that are referencing this transform setup
|
|
std::list<TTUpdateInfo> updateList;
|
|
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Compare two transform setups
|
|
*/
|
|
inline bool operator== (const STransformVecInfo& other) const
|
|
{
|
|
// We use a small epsilon here
|
|
const float epsilon = 0.05f;
|
|
|
|
if (fabs( mTranslation.x - other.mTranslation.x ) > epsilon ||
|
|
fabs( mTranslation.y - other.mTranslation.y ) > epsilon)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
if (fabs( mScaling.x - other.mScaling.x ) > epsilon ||
|
|
fabs( mScaling.y - other.mScaling.y ) > epsilon)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
if (fabs( mRotation - other.mRotation) > epsilon)
|
|
{
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
inline bool operator!= (const STransformVecInfo& other) const
|
|
{
|
|
return !(*this == other);
|
|
}
|
|
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Returns whether this is an untransformed texture coordinate set
|
|
*/
|
|
inline bool IsUntransformed() const
|
|
{
|
|
return (1.0f == mScaling.x && 1.f == mScaling.y &&
|
|
!mTranslation.x && !mTranslation.y &&
|
|
mRotation < AI_TT_ROTATION_EPSILON);
|
|
}
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Build a 3x3 matrix from the transformations
|
|
*/
|
|
inline void GetMatrix(aiMatrix3x3& mOut)
|
|
{
|
|
mOut = aiMatrix3x3();
|
|
|
|
if (1.0f != mScaling.x || 1.0f != mScaling.y)
|
|
{
|
|
aiMatrix3x3 mScale;
|
|
mScale.a1 = mScaling.x;
|
|
mScale.b2 = mScaling.y;
|
|
mOut = mScale;
|
|
}
|
|
if (mRotation)
|
|
{
|
|
aiMatrix3x3 mRot;
|
|
mRot.a1 = mRot.b2 = cos(mRotation);
|
|
mRot.a2 = mRot.b1 = sin(mRotation);
|
|
mRot.a2 = -mRot.a2;
|
|
mOut *= mRot;
|
|
}
|
|
if (mTranslation.x || mTranslation.y)
|
|
{
|
|
aiMatrix3x3 mTrans;
|
|
mTrans.a3 = mTranslation.x;
|
|
mTrans.b3 = mTranslation.y;
|
|
mOut *= mTrans;
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
/** Helper step to compute final UV coordinate sets if there are scalings
|
|
* or rotations in the original data read from the file.
|
|
*/
|
|
class ASSIMP_API TextureTransformStep : public BaseProcess
|
|
{
|
|
public:
|
|
|
|
TextureTransformStep();
|
|
~TextureTransformStep();
|
|
|
|
// -------------------------------------------------------------------
|
|
bool IsActive( unsigned int pFlags) const;
|
|
|
|
// -------------------------------------------------------------------
|
|
void Execute( aiScene* pScene);
|
|
|
|
// -------------------------------------------------------------------
|
|
void SetupProperties(const Importer* pImp);
|
|
|
|
|
|
protected:
|
|
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Preprocess a specific UV transformation setup
|
|
*
|
|
* @param info Transformation setup to be preprocessed.
|
|
*/
|
|
void PreProcessUVTransform(STransformVecInfo& info);
|
|
|
|
private:
|
|
|
|
unsigned int configFlags;
|
|
};
|
|
|
|
}
|
|
|
|
#endif //! AI_TEXTURE_TRANSFORM_H_INCLUDED
|