漫反射(diffuse reflection)

来源:互联网 发布:化学绘图软件有哪些 编辑:程序博客网 时间:2024/05/05 12:39

漫反射(diffuse reflection)


整理来至《GPU编程与CG语言之阳春白雪下里巴人》

一、原理

粗糙的物体表面向各个方向等强度地反射光,这种等同地向各个方向散射的现象称为光的漫反射(diffuse reflection)。产生光的漫反射现象的物体表面称为理想漫反射体,也称为朗伯(Lambert)反射体。

环境光:



方向光:




Lambert 光照模型

二、shader

/*------------------------漫反射与Lambert模型 ------------------*环境光(UNITY_LIGHTMODEL_AMBIENT)和方向光(Directional Light)**/Shader "JQM/diffuse" {Properties{_MainColor("MainColor" , Color) = (1,1,1,1)_MainTex("MainTex" , 2D) = "white"{}}SubShader {Pass{Tags { "RenderType"="Opaque" }LOD 200CGPROGRAM#pragma vertex vert#pragma fragment fragfloat4 _LightColor0;//第一个平行光的颜色float4 _MainColor;sampler2D _MainTex;struct Input {float4 pos:POSITION;float4 normal:NORMAL;float2 uv:TEXCOORD0;};struct Output{float4 pos:SV_POSITION;float4 normal:NORMAL;float2 uv:TEXCOORD0;float3 pos_world:TEXCOORD1;};Output vert(Input v){Output o;o.pos = mul(UNITY_MATRIX_MVP, v.pos);o.uv = v.uv;o.normal = normalize(v.normal);o.pos_world = mul(_Object2World, v.pos);return o;}float4 frag(Output o):COLOR{float4 color;float3 Kd = tex2D(_MainTex, o.uv).xyz;color = UNITY_LIGHTMODEL_AMBIENT;// + float4(0.5,0.5,0.5,1.0);//法线float3 normalDir= mul(float4(o.normal.xyz,0),_World2Object).xyz;//向量和顶点转到世界空间的运算不一样normalDir = normalize(normalDir);//光源方向//float3 lightDir = -normalize(o.pos_world-_WorldSpaceLightPos0.xyz);//与位置有关系float3 lightDir = normalize(_WorldSpaceLightPos0.xyz);//与位置无关系//1.计算环境光float3 ambient  = Kd*UNITY_LIGHTMODEL_AMBIENT;//2.计算方向光漫反射float3 diffuse=Kd*_LightColor0*max(0.3,dot(normalDir,lightDir)) * _MainColor;color.xyz = ambient + diffuse;color.w = 1;return color;}ENDCG} }FallBack "Diffuse"}




0 0
原创粉丝点击