Material Capture制作玉石效果

最后的效果:

非常节省的算法。

下面记录一下Unity的写法,unity版本搞了很久没搞出来,结果最后发现是矩阵顺序乘错了(对unity还是不太熟啊),最后请教了CG-bull大佬,赶快记下小笔记,别忘了!

Shader "Unlit/S_MaterialCapture"
{
	Properties
	{
		_MatCapTexure ("MaterialCaptureTexture", 2D) = "white" {}
		_Normaltexture ("Normaltexture", 2D) = "bump" {}
	}
	SubShader
	{
		Tags { "RenderType"="Opaque" }
		LOD 100

		Pass
		{
			CGPROGRAM
			#pragma vertex vert
			#pragma fragment frag
			// make fog work
			#pragma multi_compile_fog
			
			#include "UnityCG.cginc"

			struct appdata
			{
				float4 vertex : POSITION;
				float2 uv : TEXCOORD0;
				float4 tangent : TANGENT;
				float4 normal : NORMAL;
			};

			struct v2f
			{
				float2 uv : TEXCOORD0;
				float3 tangent : TEXCOORD2;
				float3 normal : TEXCOORD3;
				float3 binormal : TEXCOORD4;
				UNITY_FOG_COORDS(1)
				float4 vertex : SV_POSITION;
			};

			sampler2D _MatCapTexure;
			float4 _MatCapTexure_ST;
			sampler2D _Normaltexture;
			float4 _Normaltexture_ST;
			
			v2f vert (appdata v)
			{
				v2f o;
				o.vertex = UnityObjectToClipPos(v.vertex);
				o.uv = TRANSFORM_TEX(v.uv, _MatCapTexure);
				o.tangent = UnityObjectToWorldDir(v.tangent);
				o.normal = UnityObjectToWorldDir(v.normal);
				o.binormal = cross(v.tangent, v.normal);
				UNITY_TRANSFER_FOG(o,o.vertex);
				return o;
			}
			
			fixed4 frag (v2f i) : SV_Target
			{
				half4 finalcolor = half4(1, 1, 1, 1);
				
				// sample the texture
				float3 texnorm = UnpackNormal(tex2D(_Normaltexture, i.uv));
				float3x3 transmatrix = float3x3(i.tangent, i.binormal, i.normal);

				float3 texnorm_ws = normalize(mul(texnorm, transmatrix));
				float3 texnorm_vs = mul(UNITY_MATRIX_V, texnorm_ws);

				
				float3 vv = float3(0, 0, 1);
				float3 rv = vv - (dot(vv, texnorm_vs) * -2 * texnorm_vs);
				float2 matcapuv = rv.xy / (sqrt((rv.x * rv.x) + (rv.y * rv.y) + (rv.z + 1) * (rv.z + 1)) * 0.75) + 0.5;

				fixed4 MatCapColor = tex2D(_MatCapTexure, matcapuv);

				finalcolor.rgb = MatCapColor;

				// apply fog
				UNITY_APPLY_FOG(i.fogCoord, finalcolor);
				return finalcolor;
			}
			ENDCG
		}
	}
}

 

最后的效果:

Thanks CG-Bull

Enjoy it!

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值