63 lines
1.9 KiB
63 lines
1.9 KiB
//ps.1.1 |
|
|
|
// def c0, 1.0, 0.0, 0.0, 1.0 |
|
|
|
// mov r0, c0 |
|
|
|
// Short pixel shader. Use the texm3x3vspec to do a per-pixel |
|
// reflected lookup into our environment map. |
|
// Input: |
|
// t0 - Normal map in tangent space. Apply _bx2 modifier to shift |
|
// [0..255] -> [-1..1] |
|
// t1 - UVW = tangent + eye2pos.x, map ignored. |
|
// t2 - UVW = binormal + eye2pos.y, map ignored |
|
// t3 - UVW = normal + eye2pos.z, map = environment cube map |
|
// v0 - attenuating color/alpha. |
|
// See docs on texm3x3vspec for explanation of the eye2pos wackiness. |
|
// Output: |
|
// r0 = reflected lookup from environment map X input v0. |
|
// Since environment map has alpha = 255, the output of this |
|
// shader can be used for either alpha or additive blending, |
|
// as long as v0 is fed in appropriately. |
|
|
|
ps.1.1 |
|
|
|
//def c0, 1.0, 1.0, 1.0, 1.0 // Temp Hack |
|
//def c1, 2.0, 2.0, 2.0, 1.0 |
|
|
|
//texcoord t0; |
|
//texcoord t1; |
|
//texcoord t2; |
|
//texcoord t3; |
|
|
|
tex t0 // Bind texture in stage 0 to register t0. |
|
texm3x3pad t1, t0_bx2 // First row of matrix multiply. |
|
texm3x3pad t2, t0_bx2 // Second row of matrix multiply. |
|
texm3x3vspec t3, t0_bx2 // Third row of matrix multiply to get a 3-vector. |
|
// Reflect 3-vector by the eye-ray vector. |
|
// Use reflected vector to do a texture lookup |
|
// at stage 3. |
|
|
|
// t3 now has our reflected environment map value |
|
// We've (presumably) attenuated the effect on a vertex basis |
|
// and have our color w/ attenuated alpha in v0. So all we need |
|
// is to multiply t3 by v0 into r0 and we're done. |
|
mad r0.rgb, t3, v1, v0; |
|
//add r0.rgb, t3, v0; |
|
+mov r0.a, v1; |
|
|
|
//mov r0.rgb, v1.a; // HACKAGE |
|
//mov r0.a, v1.a; // HACKAGE |
|
//mov r0, v1; // HACKAGE |
|
|
|
//mov r0, c0 |
|
|
|
//mul r0, r0, t0; |
|
|
|
//mov r0, v1; |
|
//mov r0, t3; |
|
|
|
//mov r0.rgb, t3; |
|
//+mov r0.a, c0; |
|
|
|
|
|
|