S02 简单卡通风格渲染

先码上效果图:

Sample Toon.png

1、基本思想

  1. 通过物体法线与灯光方向的点积来获得基础的漫反射效果
  2. 通过floor函数 来将漫反射灯光颜色进行离散切割,获得卡通的硬过渡效果
  3. 最后将灯光与贴图颜色相乘获得最后的效果

2、代码展示

Shader "Roystan/Toon/Lit"
{
    Properties
    {
        _Color("Color", Color) = (1,1,1,1)
        _MainTex ("Texture", 2D) = "white" {}
    }
    SubShader
    {
        Tags 
        { 
            "RenderType" = "Opaque"
            "LightMode" = "ForwardBase"
        }

        UsePass "Legacy Shaders/VertexLit/SHADOWCASTER" //引入Unity的Pass通道,此通道用来渲染物体的阴影

        Pass
        {
            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag

            #include "UnityCG.cginc"
           #include "Lighting.cginc"

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

            struct v2f
            {
                float2 uv : TEXCOORD0;
                float3 worldNormal : NORMAL;
                float4 vertex : SV_POSITION;
            };

            sampler2D _MainTex;
            float4 _MainTex_ST;

            v2f vert (appdata v)
            {
                v2f o;
                o.vertex = UnityObjectToClipPos(v.vertex);
                o.uv = TRANSFORM_TEX(v.uv, _MainTex);
                o.worldNormal = UnityObjectToWorldNormal(v.normal);
                return o;
            }

            float4 _Color;

            float4 frag (v2f i) : SV_Target
            {
                float NdotL = dot(i.worldNormal, _WorldSpaceLightPos0);
                //此时场景中的光为平行光,所以_WorldSpaceLightPos0中存储的是光的方向矢量(Vector 3)
                float light = saturate(floor(NdotL * 3 ) / (2 - 0.5)) * _LightColor0;//经验模型,控制颜色的突变,通过floor函数

                float4 col = tex2D(_MainTex, i.uv);
                return (col * _Color) * (light + unity_AmbientSky);//在灯光中引入环境光的颜色
            }
            ENDCG
        }
    }
}

3、总结

本次Shader的关键是片元着色器中的light这行代码,通过对NdotL(返回世界空间法线与光源方向的点积)乘以3,将范围扩充到[-3,3],然后通过floor函数得到固定的数字(-3,-2,-1,0,1,2,3)。如果此时对其进行saturate只能获得0和1的二态光照效果,所以需要进行缩放来获得更多更合适的阴影效果。当然,随着分子的增大,颜色会偏向0,也就是说会变暗,同时对比度下降

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一个三维场景的画面的好坏,百分之四十取决于模型,百分之六十取决于贴图,可见贴图在画面中所占的重要性。在这里我将列举...
    CXYMichael阅读 5,817评论 2 5
  • 光源 我们可以使用光源方向L和表面法线n 之间的夹角的余弦值来得到。需要注意的是,这里默认方向矢量的模都为1 。图...
    李偌闲阅读 4,669评论 0 0
  • Main (主要) 这是您的所有其他节点最终将链接到的节点。它拥有为不同目的服务的多个输入。 以下动画图像显示所有...
    冰冰棒bling阅读 5,987评论 0 1
  • 这篇教程将涵盖美术内容创作的基础知识,以及各种基于物理规则的渲染标准背后的一些理论推导(并没有太过技术性的内...
    DIGITALMAN阅读 13,021评论 16 67
  • 转载自VR设计云课堂[https://www.jianshu.com/u/c7ffdc4b379e]Unity S...
    水月凡阅读 4,733评论 0 0

友情链接更多精彩内容