mirror of
https://github.com/nillerusr/source-engine.git
synced 2025-01-15 09:30:00 +00:00
80 lines
1.8 KiB
Plaintext
80 lines
1.8 KiB
Plaintext
ps.1.1
|
|
|
|
;------------------------------------------------------------------------------
|
|
; Computes the diffuse component of lighting using lightmap + bumpmap
|
|
; t0 - Normalmap
|
|
; t1 - Lightmap1
|
|
; t2 - Lightmap2
|
|
; t3 - Lightmap3
|
|
;
|
|
; The texture coordinates need to be defined as follows:
|
|
; tc0 - Normalmap and lightmap texture coordinates
|
|
; c0, c1, c2 - Axes of the lightmap coordinate system in tangent space
|
|
;------------------------------------------------------------------------------
|
|
|
|
; Get the 3-vector from the normal map
|
|
tex t0
|
|
|
|
; Sample the lightmaps
|
|
tex t1
|
|
tex t2
|
|
tex t3
|
|
|
|
; output = lightmapColor[0] * ( ( N dot basis[0] )^2 ) +
|
|
; lightmapColor[1] * ( ( N dot basis[1] )^2 ) +
|
|
; lightmapColor[2] * ( ( N dot basis[2] )^2 ) +
|
|
|
|
; r0 = ( N dot basis[0] )
|
|
; don't "_sat" here so that everything adds up to one even if the normal is outside of the basis!!!!!
|
|
dp3 r0, t0_bx2, c0
|
|
|
|
; r1 = ( N dot basis[1] )
|
|
dp3 r1, t0_bx2, c1
|
|
|
|
;----
|
|
; r0 = ( N dot basis[0] )
|
|
; r1 = ( N dot basis[1] )
|
|
;----
|
|
|
|
; r0.rgb = ( N dot basis[0] )^2
|
|
mul r0.rgb, r0, r0
|
|
|
|
; r1.a = ( N dot basis[1] )^2
|
|
+mul r1.a, r1, r1
|
|
|
|
;----
|
|
; r0.rgb = ( N dot basis[0] )^2
|
|
; r1.a = ( N dot basis[1] )^2
|
|
;----
|
|
|
|
mul t1, r0, t1
|
|
|
|
;----
|
|
; r1.a = ( N dot basis[1] )^2
|
|
; t1 = lightmapColor[0] * ( N dot basis[0] )^2
|
|
;----
|
|
|
|
dp3 r0, t0_bx2, c2
|
|
|
|
;----
|
|
; r1.a = ( N dot basis[1] )^2
|
|
; t1 = lightmapColor[0] * ( N dot basis[0] )^2
|
|
; r0 = ( N dot basis[2] )
|
|
;----
|
|
|
|
mad t1.rgb, r1.a, t2, t1
|
|
+mul r0.a, r0, r0
|
|
|
|
;----
|
|
; t1.rgb = lightmapColor[0] * ( N dot basis[0] )^2 + lightmapColor[1] * ( N dot basis[1] )^2
|
|
; r0.a = ( N dot basis[2] )^2
|
|
;----
|
|
|
|
mad r0.rgba, r0.a, t3, t1
|
|
|
|
;----
|
|
; r0.rgb = lightmapColor[0] * ( N dot basis[0] )^2 +
|
|
; lightmapColor[1] * ( N dot basis[1] )^2 +
|
|
; lightmapColor[2] * ( N dot basis[2] )^2
|
|
;----
|