Ambient、Phong与BlinnPhong光照模型shader实现

本文档详细介绍了计算机图形学中的光照模型,包括 Ambient、Phong 和 Blinn-Phong 模型,并通过 Shader 实现了这些光照效果。读者将学习如何在 Unity 中编写 Shader 代码,以控制物体表面的反射和高光,增强场景的真实感。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在研究学习计算机图形学,用shader做个光照练习,以加深记忆。

Shader "Custom/frag"

{

    Properties

    {

        _SpecularColor("SpecularColor",color)=(1,1,1,1)

        _Shininess("Shininess",range(1,32))=8

    }

    SubShader

    {

        pass{

            Tags { "LightMode"="ForwardBase" }

    

            CGPROGRAM

            

            #pragma multi_compile_fwdbase

            #pragma vertex vert

            #pragma fragment frag

            #include "unitycg.cginc"

            #include "lighting.cginc"

 

            float4 _SpecularColor;

            float _Shininess;

 

            struct v2f{

                float4 pos: POSITION;

                float3 normal: TEXCOORD1;

                float4 vertex: COLOR;

            };

 

            v2f vert(appdata_base v){

                v2f o;

                o.pos = UnityObjectToClipPos(v.vertex);

                o.normal = v.normal;

                o.vertex = v.vertex;

                return o;

            }

 

            fixed4 frag(v2f IN):COLOR

            {

                //Ambient Color

                fixed4 col = UNITY_LIGHTMODEL_AMBIENT;

 

                //Disffuse Color

                float3 N = UnityObjectToWorldNormal(IN.normal);

                float3 L = normalize(WorldSpaceLightDir(IN.vertex));

 

                float diffuseScale = saturate(dot(N,L));

                col += _LightColor0 * diffuseScale;

 

                //Specular Color  Phong模型 可以用cg reflect函数求得R,这里自己实现

                // float3 V = normalize(WorldSpaceViewDir(IN.vertex));

                // float3 R = 2*dot(N,L)*N - L;

                // float specularScale = saturate(dot(R,V));

                // col += _SpecularColor * pow(specularScale,_Shininess);

 

                //Specular Color 半角向量H, BlinnPhong模型

                float3 V = normalize(WorldSpaceViewDir(IN.vertex));

                float3 H = normalize(L+V);

                float specularScale = saturate(dot(H,N));

                col += _SpecularColor * pow(specularScale,_Shininess);

 

                return col;

            }

 

            ENDCG

        }

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值