[置顶] Cg入门16:Fragment shader - 片段级光照

[置顶] Cg入门16:Fragment shader - 片段级光照_第1张图片
将顶点程序实现漫反射放至片段程序后处理效果如下:
[置顶] Cg入门16:Fragment shader - 片段级光照_第2张图片

看到和左边内建实现的漫反射一样了

片段程序特点:
1.采用三角面的形式渲染,而顶点程序是按顶点形式渲染

注意事项:直接将计算好的顶点法线向量和光向量 直接传给片段程序使用
[置顶] Cg入门16:Fragment shader - 片段级光照_第3张图片
效果如下:为啥不一样呢?

顶点程序:
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
		}
	} 
}
[置顶] Cg入门16:Fragment shader - 片段级光照_第4张图片


你可能感兴趣的:([置顶] Cg入门16:Fragment shader - 片段级光照)