某渣渣甩了一个需求给我,并且说我不会写。我明知是激将法,但是想想这需求也太简单了,我好像也不怎么会QAQ。为了表示我对shader的热爱,写就写。


需求是这样的:

这是一个漂亮的MM,但是渣渣不想让人知道,想把她变成影子,但是他自己又不想做多一张图片,毕竟也想影子的颜色随便改变(总之渣渣的世界借口很多就是)。

----------->------------>----------->--------->


分析下如何实现吧:

首先要把MM显示出来,因为图片除了人物,其它地方都是透明的,那么肯定要用到透明混合的。其次,要先把整个人物变成黑色,然后再上其它颜色。

为什么要变成黑色呢?

因为黑色的颜色值是(0,0,0),也就是黑色加什么颜色就等于什么颜色(0+x = x),而黑色乘上任何颜色值都等于黑色(0 * x = 0)。

为什么不白色呢?

因为白色的颜色值是(1,1,1),bralabalala............


好了,分析完了,那么就动手吧(其实实际是先动手了再分析的= =,所以说总结很重要吗!?)

Shader "CharmingShader/Cartoon001/Unlit"
{
Properties
{
_MainTex("Main Tex",2D) = "white"{}
_Tint("Color",Color) = (,,,)
}
SubShader
{
Tags{ "RenderType" = "Transparent" "Queue"="Transparent"}
Pass
{
ZWrite Off
Blend SrcAlpha OneMinusSrcAlpha
CGPROGRAM
#pragma vertex vert
#pragma fragment frag
#include "UnityCG.cginc" sampler2D _MainTex;
float4 _MainTex_ST;
fixed4 _Tint; struct a2v
{
float4 vertex : POSITION;
float2 texcoord : TEXCOORD0;
};
struct v2f
{
float2 uv :TEXCOORD0;
float4 pos : SV_POSITION;
};
v2f vert(a2v a)
{
v2f f;
f.uv = TRANSFORM_TEX(a.texcoord, _MainTex);
f.pos = mul(UNITY_MATRIX_MVP, a.vertex);
return f;
}
fixed4 frag (v2f i) :SV_Target
{
fixed4 col = tex2D(_MainTex,i.uv);
fixed4 colo = col*fixed4(, , , ) + fixed4(_Tint.rgb,);
return colo;
}
ENDCG
}
}
}

代码还是很简单的,关键的代码可能就是这行

                fixed4 colo = col*fixed4(, , , ) + fixed4(_Tint.rgb,);

怎么解释呢?。。。。。

其实就是,因为图片肯定是方形的(包括透明部分),不透明部分的数值相当于(x0,y0,z0,1)。

(x0,y0,z0,1)*(0,0,0,1) = (0,0,0,1) 也就相当于黑色。最后(0,0,0,1)+(_Tint.rgb,0) = (_Tint.rgb,1)也就是要上的颜色了。

对于透明部分,原始数值相当于(x1,y1,z1,0),(x1,y1,z1,0)*(0,0,0,1) = (0,0,0,0)也是透明的。

最后(0,0,0,0)+(_Tint.rgb,0) = (_Tint.rgb,0)同样也是透明的。

综上就可以达到预期的效果了。

当然笔者认为使用内置的clip函数会适用性更广点,但以上的方法更加锻炼思维能力吧(明明就自己不会QAQ)。总之,方法没有好坏,只有适不适合。

ps:眼睛看到的永远是表象,背后的事实有时候不要去了解,毕竟好看就行了。。。

Shader做剪影效果的更多相关文章

  1. 【译】Unity3D Shader 新手教程(1/6)

    本文为翻译,附上原文链接. 转载请注明出处--polobymulberry-博客园. 刚开始接触Unity3D Shader编程时,你会发现有关shader的文档相当散,这也造成初学者对Unity3D ...

  2. Unity3D shader简介

    Unity3D shader简介 可以肯定的说Unity3D使得很多开发者开发游戏更容易.毫无疑问,shader(着色器)编码,仍有很长的路要走.shader是一个专门运行在GPU的程序,经常被神秘包 ...

  3. cocos2dx 编写shader 遇到 溢出问题

    在 编程语言中,不论什么 数据类型 都有 各种 的 局限,无法 表示 现实世界中的 不论什么 情况. 比如 int ,char 会 溢出,float 会 有 溢出 以及 精度 不准确的 情况. 所以 ...

  4. 【Unity Shaders】Shader学习资源和Surface Shader概述

    写在前面 写这篇文章的时候,我断断续续学习Unity Shader半年了,其实还是个门外汉.我也能体会很多童鞋那种想要学好Shader却无从下手的感觉.在这个期间,我找到一些学习Shader的教程以及 ...

  5. 对Unity一个Shader编译Bug的分析(Unrecognized sampler 'samplerunity_lightmap)

    写在前面 Unity的用户量越来越大,越来越有钱,这几年摊子也铺的越来越大,所以各个版本总是有很多Bug.对于一些Bug官方在ReleaseNote里的说明是很不详细的,而对于一些渲染相关的Bug,有 ...

  6. cocos2d-js Shader系列2:在cc.Sprite上使用Shader(黑白、灰度、造旧效果)

    在Sprite中使用Shader做特殊的颜色处理比较简单,只需要把Shader程序绑定到Sprite上即可: sprite.shaderProgram = alphaTestShader; Cocos ...

  7. OpenGL10-骨骼动画原理篇(3)-Shader版本代码已经上传

    视频教程请关注 http://edu.csdn.net/lecturer/lecturer_detail?lecturer_id=440 接上一个例程OpenGL10-骨骼动画原理篇(2),对骨骼动画 ...

  8. 【OpenGL】Shader实例分析(六)- 卡牌特效

    转发请保持地址:http://blog.csdn.net/stalendp/article/details/30989295 本文将介绍怎么通过alpha通道来隐藏信息.并实现卡牌特效. 执行效果例如 ...

  9. 用 Shader 写个完美的波浪

    前言 皮皮最近接到了一个小需求: 美术小姐姐:皮皮皮皮,你能不能做奶茶? 我:??? 美术小姐姐:就是那种,奶茶的轮廓加上动态水波纹~

随机推荐

  1. Yii安装使用教程(转)

    Yii 是一个基于组件的高性能 PHP 框架,用于快速开发大型 Web 应用.它使Web开发中的 可复用度最大化,可以显著提高你的Web应用开发速度.Yii 这个名字(读作易(Yee) 或 [ji:] ...

  2. Nginx如何配置静态文件直接访问

    其实前面在这篇文章Nginx之动静分离中已经提到过如何配置静态文件直接访问,今天突然再写是因为之前写的不够完善,所以这一篇文章你可以理解为是在前一个基础上的扩展. 之所以下午临时想到这个,是因为之前搭 ...

  3. [转]地图投影的N种姿势

    此处直接给出原文链接: 1.地图投影的N种姿势 2.GIS理论(墨卡托投影.地理坐标系.地面分辨率.地图比例尺.Bing Maps Tile System)

  4. IntelliJ IDEA使用技巧整理

    1 .写代码时用 Alt-Insert ( Code|Generate… )可以创建类里面任何字段的 getter 与 setter 方法. 2 .右键点击断点标记(在文本的左边栏里)激活速查菜单,你 ...

  5. atom / vscode (配置c++环境流程)

    最初主要是被这个炫酷的插件吸引了,这么打代码太特么有激情了 还有跳舞的初音姐姐哦!! 现附上一篇文章,这篇文章步骤讲得很详细了 http://blog.csdn.net/qq_36731677/art ...

  6. Ural 1183 Brackets Sequence(区间DP+记忆化搜索)

    题目地址:Ural 1183 最终把这题给A了.. .拖拉了好长时间,.. 自己想还是想不出来,正好紫书上有这题. d[i][j]为输入序列从下标i到下标j最少须要加多少括号才干成为合法序列.0< ...

  7. 易语言中锐浪报表绿色发布指南(免COM组件DLL注册)

    第一步 打开易语言开发环境(注要求易语言版本 v5.5及以上版本,如果版本太低,请更新到新版本),点击[工具]菜单,进入系统配置界面: 第二步 切换选择夹到[存根]项目,选中"使用用户自定义 ...

  8. C语言学习记录_2019.02.09

    打印字符串:%s--------printf("%s","abcd"); 打印字符串数组中某一位:%c--------printf("%c" ...

  9. 20145209刘一阳《JAVA程序设计》第十五周补充测试

    第十五周补充测试 1.实验楼Linux中可以通过(ABC)查看用户登录情况. A .who B .who am i C .who mom likes D .who are you 2.在 Linux ...

  10. 微信小程序:text元素中加入空格

    在text标签中加入 decode = "{{true}}" ,然后字啊需要加入空格的地方使用   即可加入一个空格,可以连续用多个例如: <text decode = &q ...