home *** CD-ROM | disk | FTP | other *** search
- // v2fConnector.HPOS is set to be the homogenous space coordinate
- // v2f.texture is set to be the texture coordinate
- // InverseTransposes not used, as we assume no nonuniform scales.
-
-
- // vecMul(matrix, float3) multiplies like a vector instead of point (no translate)
- float3 vecMul(const float4x4 matrix, const float3 vec){
- return(float3(dot(vec, matrix._11_12_13),
- dot(vec, matrix._21_22_23),
- dot(vec, matrix._31_32_33)));
- }
-
- struct a2vConnector : application2vertex {
- float4 coord;
- float3 normal;
- float3 coordMorph0;
- float3 normalMorph0;
- float3 coordMorph1;
- float3 normalMorph1;
- float3 coordMorph2;
- float3 normalMorph2;
- float3 coordMorph3;
- float3 normalMorph3;
- float3 coordMorph4;
- float3 normalMorph4;
- float boneWeight0;
- float boneIndex0;
- float2 texture;
- };
-
- struct v2fConnector : vertex2fragment {
- float4 HPOS :HPOS;
- float2 texture :TEX0;
- };
-
- v2fConnector main(a2vConnector a2v,
- const uniform float morphWeight0,
- const uniform float morphWeight1,
- const uniform float morphWeight2,
- const uniform float morphWeight3,
- const uniform float morphWeight4,
- const uniform float4x4 modelViewProj[1]){
- v2fConnector v2f;
-
-
- v2f.texture = a2v.texture;
-
- float4 objectCoord = a2v.coord;
- objectCoord.xyz = objectCoord.xyz + morphWeight0 * a2v.coordMorph0;
- objectCoord.xyz = objectCoord.xyz + morphWeight1 * a2v.coordMorph1;
- objectCoord.xyz = objectCoord.xyz + morphWeight2 * a2v.coordMorph2;
- objectCoord.xyz = objectCoord.xyz + morphWeight3 * a2v.coordMorph3;
- objectCoord.xyz = objectCoord.xyz + morphWeight4 * a2v.coordMorph4;
- float4x4 projSkinMatrix;
- projSkinMatrix[0] = a2v.boneWeight0.x * modelViewProj[a2v.boneIndex0.x][0];
- projSkinMatrix[1] = a2v.boneWeight0.x * modelViewProj[a2v.boneIndex0.x][1];
- projSkinMatrix[2] = a2v.boneWeight0.x * modelViewProj[a2v.boneIndex0.x][2];
- projSkinMatrix[3] = a2v.boneWeight0.x * modelViewProj[a2v.boneIndex0.x][3];
- float4 hpos = mul(projSkinMatrix, objectCoord);
- v2f.HPOS = hpos;
-
- return v2f;
- }