简单写写,练下手~

Shader "James/VP Shader/RimLight"
{
Properties
{
_MainTex("MainTex", 2D) = "white" {}
_Color("Color", Color) = (, , , )
_RimColor("RimColor", Color) = (, , , )
_RimPower("RimPower", Range(, )) = 0.1
_RimIntensity("RimIntensity", Range(, )) =
} SubShader
{
Tags { "Queue" = "Transparent" }
Pass
{
ZWrite Off
Blend SrcAlpha OneMinusSrcAlpha CGPROGRAM #pragma vertex vert
#pragma fragment frag
#include "UnityCG.cginc" struct v2f
{
float4 pos : SV_POSITION;
float3 color : COLOR0;
float2 uv : TEXCOORD0;
float3 normal : TEXCOORD1;
float3 objViewDir : TEXCOORD2;
}; sampler2D _MainTex;
float4 _MainTex_ST;
float4 _Color; v2f vert(appdata_base v)
{
v2f o;
o.pos = mul (UNITY_MATRIX_MVP, v.vertex);
o.normal = v.normal;
o.objViewDir = normalize(ObjSpaceViewDir(v.vertex));
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex);
return o;
} float4 _RimColor;
float _RimPower;
float _RimIntensity; half4 frag(v2f i) : COLOR
{
float rimSin = - max(, dot(i.normal, i.objViewDir));
float rimFactor = pow(rimSin, _RimPower) * _RimIntensity;
float3 rimColor = rimFactor * _RimColor; float4 mainColor = tex2D(_MainTex, i.uv);
float4 finalColor = mainColor * _Color;
finalColor.rgb +=rimColor;
return finalColor;
} ENDCG
}
}
FallBack "VertexLit"
}

   将上面的Shader改写一下,添加BumpTex,并使用一张RimTex来映射边缘光的强度:

Shader "James/VP Shader/BumpRimLight"
{
Properties
{
_MainTex("MainTex", 2D) = "white" {}
_BumpTex("BumpTex", 2D) = "bump" {}
_Color("Color", Color) = (, , , )
_RimColor("RimColor", Color) = (, , , )
_RimIntensity("RimIntensity", Range(, )) = 0.1
_RimTex("RimTex", 2D) = "white" {}
} SubShader
{
Tags { "Queue" = "Transparent" }
Pass
{
Blend SrcAlpha OneMinusSrcAlpha CGPROGRAM #pragma vertex vert
#pragma fragment frag
#include "UnityCG.cginc" struct v2f
{
float4 pos : SV_POSITION;
float3 color : COLOR0;
float2 uv : TEXCOORD0;
float3 tangentSpackLightDir : TEXCOORD1;
}; sampler2D _MainTex;
sampler2D _BumpTex;
sampler2D _RimTex;
float4 _MainTex_ST;
float4 _BumpTex_ST;
float4 _RimTex_ST;
float4 _Color;
float4 _RimColor;
float _RimIntensity; v2f vert(appdata_tan v)
{
v2f o;
o.pos = mul (UNITY_MATRIX_MVP, v.vertex);
float3 objViewDir = normalize(ObjSpaceViewDir(v.vertex));
o.uv = TRANSFORM_TEX(v.texcoord, _MainTex); // 副法向量
float3 binormal = cross(normalize(v.vertex), normalize(v.tangent.xyz));
// 切空间矩阵
float3x3 rotation = float3x3(v.tangent.xyz, binormal, v.normal);
// 切空间视线方向
o.tangentSpackLightDir = mul(rotation, objViewDir); return o;
} half4 frag(v2f i) : COLOR
{
// 切空间法线,NormalMap默认带的是切空间的值
half3 tangentSpaceNormal = (tex2D(_BumpTex, i.uv).rgb * 2.0) - 1.0;
float rimFactor = - max(, dot(tangentSpaceNormal, i.tangentSpackLightDir));
float rimIntensity = tex2D(_RimTex, rimFactor.xx).r;
float3 rimColor = rimIntensity * _RimColor * _RimIntensity; float4 mainColor = tex2D(_MainTex, i.uv);
float4 finalColor = mainColor * _Color;
finalColor.rgb += rimColor;
return finalColor;
} ENDCG
}
}
FallBack "VertexLit"
}

   注意上述代码是在切空间中计算rim的颜色强度。

练手之RimLight的更多相关文章

  1. Python学习路径及练手项目合集

    Python学习路径及练手项目合集 https://zhuanlan.zhihu.com/p/23561159

  2. Cocos2d-Lua (练手) 微信打飞机

    学习下lua,目前入门级,使用版本为 v3.3 Final For Win,空闲时间不足,只能断断续续写点东西.   一.子弹效果          子弹只做了一种,扇形发射,可以增加扇形大小,子弹的 ...

  3. web前端学习部落22群分享给需要前端练手项目

    前端学习还是很有趣的,可以较快的上手然后自己开发一些好玩的项目来练手,网上也可以一抓一大把关于前端开发的小项目,可是还是有新手在学习的时候不知道可以做什么,以及怎么做,因此,就整理了一些前端项目教程, ...

  4. webpack练手项目之easySlide(三):commonChunks(转)

    Hello,大家好. 在之前两篇文章中: webpack练手项目之easySlide(一):初探webpack webpack练手项目之easySlide(二):代码分割 与大家分享了webpack的 ...

  5. webpack练手项目之easySlide(二):代码分割(转)

    在上一篇 webpack练手项目之easySlide(一):初探webpack  中我们一起为大家介绍了webpack的基本用法,使用webpack对前端代码进行模块化打包. 但是乍一看webpack ...

  6. webpack练手项目之easySlide(一):初探webpack (转)

    最近在学习webpack,正好拿了之前做的一个小组件,图片轮播来做了下练手,让我们一起来初步感受下webpack的神奇魅力.     webpack是一个前端的打包管理工具,大家可以前往:http:/ ...

  7. JAVA大数类练手

    今天突然看到了OJ上的大数类题目,由于学习了一点大数类的知识.果断水了6道题......都是非常基础的.就当的练手的吧. 学到的只是一些大数类的基本操作.以后多做点这样的题,争取熟练运用水大数题... ...

  8. Python之路【第二十四篇】:Python学习路径及练手项目合集

      Python学习路径及练手项目合集 Wayne Shi· 2 个月前 参照:https://zhuanlan.zhihu.com/p/23561159 更多文章欢迎关注专栏:学习编程. 本系列Py ...

  9. node论坛练手

    当时学node,自己写了个论坛练手,现在看还是有很多问题,有时间好好改改 https://github.com/hitbs228/countdown

随机推荐

  1. flask第十篇——url_for【3】

      继续url_for的知识点 # coding: utf-8 from flask import Flask, url_forimport flask app = Flask(__name__)   ...

  2. BZOJ.3140.[HNOI2013]消毒(二分图匹配 匈牙利)

    题目链接 不难想到每次一定是切一片. 如果是平面,很容易想到直接做二分图匹配.对于3维的? 可以发现min(a,b,c)的最大值只有\(\sqrt[3]{n}≈17\),我们暴力枚举这一最小值代表的是 ...

  3. 洛谷.4717.[模板]快速沃尔什变换(FWT)

    题目链接 https://www.mina.moe/archives/7598 //285ms 3.53MB #include <cstdio> #include <cctype&g ...

  4. LOJ.6282.数列分块入门6(块状链表/分块)

    题目链接 1.分块(vector)+重构 //直接上vector(本机还是比较慢的...) 某块size较大时O(n)重构 //注意细节 #include <cmath> #include ...

  5. HDU.6155.Subsequence Count(线段树 矩阵)

    题目链接 首先考虑询问[1,n]怎么做 设 f[i][0/1]表示[1,i]以0/1结尾的不同子序列个数 则 \(if(A[i]) f[i][1] = f[i-1][0] + f[i-1][1] + ...

  6. PHP文本处理 中文汉字字符串 转换为数组

    在PHP中我们可以通过str_split 将字符串转换为数组,但是却对中文无效,下面记录一下个人将中文字符串转换为数组的方法. 用到的PHP函数 mb_strlen — 获取字符串的长度 functi ...

  7. [HihoCoder1393]网络流三·二分图多重匹配

    题目大意: 班级有$N$名学生,运动会有$M$项不同的比赛,第$i$项比赛每个班需要派出$m_i$名选手参加,编号为i的学生最多同时参加给定的$b_i$项比赛中的任意$a_i$项比赛.根据统计的结果, ...

  8. System类与Runtime类

    PS: Java程序在不同操作系统上运行时,可能需要取得平台相关的属性,或者调用平台命令来完成特定功能.java提供了System类与Runtime类来与程序的运行平台进行交互. System类: 1 ...

  9. 20172302 《Java软件结构与数据结构》第二周学习总结

    2018年学习总结博客总目录:第一周 第二周 教材学习内容总结 第三章 集合概述-栈 3.1 集合 (1) 集合是一种聚集,组织了其他对象的对象.它定义一张破那个特定的方式,可以访问.管理所包含的对象 ...

  10. Codeforces 932G Palindrome Partition 回文树+DP

    题意:给定一个串,把串分为偶数段 假设分为$s_1,s_2,s_3....s_k$ 求满足$ s_1=s_k,s_2=s_{ k-1 }... $的方案数模$10^9+7$ $|S|\leq 10^6 ...