///////////// // GLOBALS // ///////////// cbuffer MatrixBuffer : register(b0) { matrix knochenMatrix[128]; }; // The projection and view matrix cbuffer Kamera : register(b1) { matrix view; matrix projection; } cbuffer Light : register(b2) { int lightLength; float3 light[24]; } ////////////// // TYPEDEFS // ////////////// struct VertexInputType { float4 position : POSITION; float2 tex : TEXCOORD0; float3 normal : NORMAL; uint knochen : KNOCHEN_ID0; half id : VERTEX_ID; }; struct PixelInputType { float4 worldPos : POSITION; float4 position : SV_POSITION; float2 tex : TEXCOORD0; float3 normal : TEXCOORD1; float4 light : TEXCOORD2; }; //////////////////////////////////////////////////////////////////////////////// // Vertex Shader //////////////////////////////////////////////////////////////////////////////// PixelInputType TextureVertexShader(VertexInputType input) { //return input; PixelInputType output; output.normal = normalize(mul(input.normal, (float3x3)knochenMatrix[input.knochen])); // Change the position vector to be 4 units for proper matrix calculations. input.position.w = 1.0f; // Store the texture coordinates for the pixel shader. output.tex = input.tex; // Calculate the position of the vertex against the world, view, and projection matrices. output.worldPos = mul(input.position, knochenMatrix[input.knochen]); output.position = mul(output.worldPos, view); output.position = mul(output.position, projection); output.light = float4(1.0f, 1.0f, 1.0f, 0.f); if (input.id < lightLength) { output.light.xyz = light[input.id]; output.light.w = 1.f; } return output; }