將物體描一層邊可以使游戲看起來具有卡通風格,一種簡單的實現方法如下:
將物體渲染2次,即使用2個通道。
第一個通道將頂點沿法線(或中心點到頂點的方向)做一個偏移,即將模型擴大一點,並將顏色渲染成輪廓的顏色。
第二個通道正常渲染物體。
轉載請注明出處:http://www.cnblogs.com/jietian331/p/7814894.html
效果如下:
shader如下:
Shader "Custom/Study/Simple Outline" { Properties { _MainTex ("Texture", 2D) = "white" {} _Outline ("Outline", Range(0, 1)) = 0.1 _OutlineColor ("Outline Color", Color) = (1,1,1,1) } SubShader { Tags { "RenderType"="Opaque" } LOD 100 Pass { Cull Front CGPROGRAM #pragma vertex vert #pragma fragment frag float _Outline; float4 _OutlineColor; struct appdata { float4 vertex : POSITION; float3 normal : NORMAL; }; struct v2f { float4 pos : SV_POSITION; }; v2f vert (appdata v) { v2f o; o.pos = UnityObjectToClipPos(v.vertex + normalize(v.vertex) * _Outline); return o; } fixed4 frag (v2f i) : SV_Target { return _OutlineColor; } ENDCG } Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag sampler2D _MainTex; struct appdata { float4 vertex : POSITION; float2 uv : TEXCOORD0; }; struct v2f { float2 uv : TEXCOORD0; float4 vertex : SV_POSITION; }; v2f vert (appdata v) { v2f o; o.vertex = UnityObjectToClipPos(v.vertex); o.uv = v.uv; return o; } fixed4 frag (v2f i) : SV_Target { return tex2D(_MainTex, i.uv); } ENDCG } } }
注意:可能將頂點沿中心點到頂點方向擴展效果更好,沿法線方向擴展時效果如下: