Unity Shader渐变纹理、不使用渐变纹理实现渐变效果、遮罩纹理

本文介绍了如何在Unity Shader中利用渐变纹理控制漫反射光照,通过平滑和颜色离散化不使用渐变纹理也能实现渐变效果。同时,通过遮罩纹理来精细控制模型表面的高光反射强度,实现特定区域的反光强度调整。详细步骤包括属性声明、坐标空间变换和遮罩纹理应用等。
摘要由CSDN通过智能技术生成

渐变纹理

之前我们计算漫反射光照时,都是使用表面法线和光照方向的点击结果与材质的反射率相乘来得到表面的漫反射光照,有时,我们需要更加灵活地控制光照结果,就可以使用渐变纹理来控制漫反射光照的结果.

Shader "RampTexture"
{
   
   Properties
   {
   
		_Color("Color Tint",Color) = (1, 1, 1, 1)
		_RampTex("Ramp Tex",2D) = "white"{
   }

		_Specular("Specular",Color) = (1, 1, 1, 1)
		_Gloss("Gloss", Range(8.0, 256)) = 20
   }

   SubShader
   {
   
		pass
		{
   
			Tags {
   "LightMode" = "ForwardBase"}
			CGPROGRAM

			#pragma vertex vert 
			#pragma fragment frag 
			#include "Lighting.cginc" //使用Unity内置变量 如_LightColor0




			fixed4 _Color;
			sampler2D _RampTex;
			float4 _RampTex_ST;//使用纹理名_ST来声明某个纹理的属性,ST是缩放scale和平移translation的缩写
			//_MainTex_ST.xy存储缩放值,_MainTex_ST.zw存储偏移值,
			fixed4 _Specular;
			float _Gloss;



			struct a2v
			{
   
				float4 vertex : POSITION;
				float3 normal : NORMAL;
				float4 texcoord : TEXCOORD0;
			};

			struct v2f
			{
   
				float4 pos : SV_POSITION;
				float3 worldNormal : TEXCOORD0;
				float3 worldPos : TEXCOORD1;//存储变换后的光照方向
				float2 uv : TEXCOORD2;//存储变换后的视角方向
			};

			v2f vert(a2v v)
			{
   
				v2f o;
				o.pos =  UnityObjectToClipPos(v.vertex);
				o.worldNormal = UnityObjectToWorldNormal(v.normal);
				o.worldPos = mul(unity_ObjectToWorld, v.vertex).xyz;
				o.uv = TRANSFORM_TEX(v.texcoord, _RampTex);//内置宏计算平铺和偏移后的纹理坐标
				return o;

			}
			fixed4 frag(v2f i) : SV_Target
			{
   
				fixed3 worldNormal = normalize(i.worldNormal);
				fixed3 worldLightDir = normalize(UnityWorldSpaceLightDir(i.worldPos));
				fixed3 ambient = UNITY_LIGHTMODEL_AMBIENT.xyz;

				fixed halfLambert 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值