OgreShaderExDualQuaternionSkinning.h

Go to the documentation of this file.
00001 /*
00002 -----------------------------------------------------------------------------
00003 This source file is part of OGRE
00004 (Object-oriented Graphics Rendering Engine)
00005 For the latest info, see http://www.ogre3d.org
00006 
00007 Copyright (c) 2000-2012 Torus Knot Software Ltd
00008 Permission is hereby granted, free of charge, to any person obtaining a copy
00009 of this software and associated documentation files (the "Software"), to deal
00010 in the Software without restriction, including without limitation the rights
00011 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
00012 copies of the Software, and to permit persons to whom the Software is
00013 furnished to do so, subject to the following conditions:
00014 
00015 The above copyright notice and this permission notice shall be included in
00016 all copies or substantial portions of the Software.
00017 
00018 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
00019 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
00020 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
00021 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
00022 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
00023 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
00024 THE SOFTWARE.
00025 -----------------------------------------------------------------------------
00026 */
00027 #ifndef _ShaderExDualQuaternionSkinning_
00028 #define _ShaderExDualQuaternionSkinning_
00029 
00030 #include "OgreShaderPrerequisites.h"
00031 
00032 #ifdef RTSHADER_SYSTEM_BUILD_EXT_SHADERS
00033 #include "OgreShaderExHardwareSkinningTechnique.h"
00034 #include "OgreShaderParameter.h"
00035 #include "OgreRenderSystem.h"
00036 #include "OgreShaderFunctionAtom.h"
00037 
00038 namespace Ogre {
00039 namespace RTShader {
00040 
00048 #define SGX_LIB_DUAL_QUATERNION             "SGXLib_DualQuaternion"
00049 #define SGX_FUNC_BLEND_WEIGHT               "SGX_BlendWeight"
00050 #define SGX_FUNC_ANTIPODALITY_ADJUSTMENT        "SGX_AntipodalityAdjustment"
00051 #define SGX_FUNC_CALCULATE_BLEND_POSITION       "SGX_CalculateBlendPosition"
00052 #define SGX_FUNC_CALCULATE_BLEND_NORMAL         "SGX_CalculateBlendNormal"
00053 #define SGX_FUNC_NORMALIZE_DUAL_QUATERNION      "SGX_NormalizeDualQuaternion"
00054 #define SGX_FUNC_ADJOINT_TRANSPOSE_MATRIX       "SGX_AdjointTransposeMatrix"
00055 #define SGX_FUNC_BUILD_DUAL_QUATERNION_MATRIX       "SGX_BuildDualQuaternionMatrix"
00056 
00061 class _OgreRTSSExport DualQuaternionSkinning : public HardwareSkinningTechnique
00062 {
00063 // Interface.
00064 public:
00066     DualQuaternionSkinning();
00067 
00071     virtual bool resolveParameters (ProgramSet* programSet);
00072 
00076     virtual bool resolveDependencies (ProgramSet* programSet);
00077 
00081     virtual bool addFunctionInvocations (ProgramSet* programSet);
00082 
00083 // Protected methods
00084 protected:
00086     void addPositionCalculations(Function* vsMain, int& funcCounter);
00087 
00089     void adjustForCorrectAntipodality(Function* vsMain, int index, int& funcCounter, const ParameterPtr& pTempWorldMatrix);
00090 
00096     void addIndexedPositionWeight(Function* vsMain, int index, ParameterPtr& pWorldMatrix,
00097                       ParameterPtr& pPositionTempParameter, ParameterPtr& pPositionRelatedOutputParam, int& funcCounter);
00098     
00100     void addNormalRelatedCalculations(Function* vsMain,
00101                         ParameterPtr& pNormalRelatedParam,
00102                         ParameterPtr& pNormalWorldRelatedParam,
00103                         int& funcCounter);
00104 
00105 protected:
00106     UniformParameterPtr mParamInScaleShearMatrices;
00107     ParameterPtr mParamLocalBlendPosition;
00108     ParameterPtr mParamBlendS;
00109     ParameterPtr mParamBlendDQ;
00110     ParameterPtr mParamInitialDQ;
00111     ParameterPtr mParamTempWorldMatrix;
00112 
00113     ParameterPtr mParamTempFloat2x4;
00114     ParameterPtr mParamTempFloat3x3;
00115     ParameterPtr mParamTempFloat3x4;
00116     
00117     ParameterPtr mParamIndex1;
00118     ParameterPtr mParamIndex2;
00119 
00120 };
00121 
00122 }
00123 }
00124 
00125 #endif
00126 #endif
00127 

Copyright © 2012 Torus Knot Software Ltd
Creative Commons License
This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.
Last modified Fri May 25 23:36:26 2012