将顶点程序实现漫反射放至片段程序后处理效果如下:
看到和左边内建实现的漫反射一样了
片段程序特点:
1.采用三角面的形式渲染,而顶点程序是按顶点形式渲染
注意事项:直接将计算好的顶点法线向量和光向量 直接传给片段程序使用
效果如下:为啥不一样呢?
顶点程序:
1.按顶点计算,一个顶点一个顶点处理程序
片段程序:
1.先进行光栅化,把面片分割成三角形,
2.一个片段程序,可以看成一个一个像素处理
原因:
1.由于面片程序,分割成很多个小三角形处理,但是一下三角形上的法线和光向量相同,就导致了这种现象,一大段黑、一大段灰,不像左边系统内置的一样有过度的效果。
解决办法:
1.将原始数据传入片段程序,然后再处理
Shader "Sbin/vf48" { Properties { _MainColor("MainColor",color) = (1,1,1) _SpecalarColor("SpecularColor",color) = (1,1,1) _Shininess("Shininess",Range(1,94)) = 8 } SubShader { pass{ Tags{"LightMode" = "ForwardBase"} CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc" #include "Lighting.cginc" struct v2f{ float4 pos : POSITION; float3 normal:NORMAL; float4 vertex:COLOR; }; float4 _MainColor; float4 _SpecalarColor; float _Shininess; v2f vert(appdata_base v){ v2f o; o.pos = mul(UNITY_MATRIX_MVP,v.vertex); o.normal = v.normal; o.vertex = v.vertex; return o; } fixed4 frag(v2f v):COLOR { //Ambient Color 环境光 float4 col = UNITY_LIGHTMODEL_AMBIENT; float3 N = UnityObjectToWorldNormal(v.normal); float3 L = normalize(WorldSpaceLightDir(v.vertex)); float3 V = normalize(WorldSpaceViewDir(v.vertex)); //deffuse Color 漫反射 float ndot = saturate(dot(N,L));//saturate把点积的结果限定在[0-1] col += _LightColor0*_MainColor * ndot; //Specular Color镜面高光 float3 R = 2*dot(N,L)*N-L; R = normalize(R); //dot:向量点积 float specularScale = pow(saturate(dot(R,V)),_Shininess);//pow:数的n次幂 col += _SpecalarColor * specularScale; //点光源 float3 wpos = mul(_Object2World,v.vertex).xyz; col.rgb += Shade4PointLights(unity_4LightPosX0,unity_4LightPosY0,unity_4LightPosZ0 ,unity_LightColor[0].rgb,unity_LightColor[1].rgb,unity_LightColor[2].rgb,unity_LightColor[3].rgb, unity_4LightAtten0,wpos,N); return col; } ENDCG } } }
时间: 2024-11-13 17:15:45