溶解与重现
来源:互联网 发布:seo怎么提高自然排名 编辑:程序博客网 时间:2024/04/28 18:49
<div id="article_content" class="article_content"><p>参考链接:http://www.cnblogs.com/Esfog/p/DissolveShader.html</p><p><br></p><p>效果图:</p><p><img src="http://img.blog.csdn.net/20150610131745834" alt=""><br></p><p><br></p><p>从颜色变化来说,有三种,一种是纹理颜色,一种是纹理与黑边的混合颜色,一种是透明(用discard处理,不绘制像素)。还需要一张纹理(任意),根据它的任意一个通道来控制哪部分先消失。例如上面的效果图用的就是这张纹理的r通道:</p><p><img src="http://img.blog.csdn.net/20150610132712297" alt=""><br></p><p>如果用的是这张纹理(也就是模型自身的纹理)的r通道,会更加酷:</p><p><img src="http://img.blog.csdn.net/20150610132733020" alt=""><br></p><p><br></p><p><img src="http://img.blog.csdn.net/20150610133211838" alt=""><br></p><p><br></p><p>溶解效果代码如下:</p><p></p><div class="dp-highlighter bg_csharp"><div class="bar"><div class="tools"><b>[csharp]</b> <a href="#" class="ViewSource" title="view plain" onclick="dp.sh.Toolbar.Command('ViewSource',this);return false;">view plain</a><span data-mod="popu_168"> <a href="#" class="CopyToClipboard" title="copy" onclick="dp.sh.Toolbar.Command('CopyToClipboard',this);return false;">copy</a><div style="position: absolute; left: 734px; top: 2601px; width: 18px; height: 18px; z-index: 99;"><embed id="ZeroClipboardMovie_1" src="http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf" loop="false" menu="false" quality="best" bgcolor="#ffffff" width="18" height="18" name="ZeroClipboardMovie_1" align="middle" allowscriptaccess="always" allowfullscreen="false" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" flashvars="id=1&width=18&height=18" wmode="transparent"></div></span><span data-mod="popu_169"> <a href="#" class="PrintSource" title="print" onclick="dp.sh.Toolbar.Command('PrintSource',this);return false;">print</a></span><a href="#" class="About" title="?" onclick="dp.sh.Toolbar.Command('About',this);return false;">?</a><span class="tracking-ad" data-mod="popu_167"><a href="https://code.csdn.net/snippets/1693878" target="_blank" title="在CODE上查看代码片" style="text-indent:0;"><img src="https://code.csdn.net/assets/CODE_ico.png" width="12" height="12" alt="在CODE上查看代码片" style="position:relative;top:1px;left:2px;"></a></span><span class="tracking-ad" data-mod="popu_170"><a href="https://code.csdn.net/snippets/1693878/fork" target="_blank" title="派生到我的代码片" style="text-indent:0;"><img src="https://code.csdn.net/assets/ico_fork.svg" width="12" height="12" alt="派生到我的代码片" style="position:relative;top:2px;left:2px;"></a></span></div></div><ol start="1" class="dp-c"><li class="alt"><span><span>Shader </span><span class="string">"Esfog/Dissolve"</span><span> </span></span></li><li class=""><span>{ </span></li><li class="alt"><span> Properties </span></li><li class=""><span> { </span></li><li class="alt"><span> _MainTex (<span class="string">"Base (RGB)"</span><span>, 2D) = </span><span class="string">"white"</span><span> {} </span></span></li><li class=""><span> _NoiseTex (<span class="string">"NoiseTex (R)"</span><span>,2D) = </span><span class="string">"white"</span><span>{} </span></span></li><li class="alt"><span> _DissolveSpeed (<span class="string">"DissolveSpeed (Second)"</span><span>,Float) = 1 </span></span></li><li class=""><span> _EdgeWidth(<span class="string">"EdgeWidth"</span><span>,Range(0,0.5)) = 0.1 </span></span></li><li class="alt"><span> _EdgeColor(<span class="string">"EdgeColor"</span><span>,Color) = (1,1,1,1) </span></span></li><li class=""><span> _StartTime(<span class="string">"StartTime"</span><span>,Float) = 0 </span></span></li><li class="alt"><span> } </span></li><li class=""><span> SubShader </span></li><li class="alt"><span> { </span></li><li class=""><span> Tags { <span class="string">"RenderType"</span><span>=</span><span class="string">"Opaque"</span><span> } </span></span></li><li class="alt"><span> </span></li><li class=""><span> Pass </span></li><li class="alt"><span> { </span></li><li class=""><span> CGPROGRAM </span></li><li class="alt"><span><span class="preprocessor"> #pragma vertex vert_img</span><span> </span></span></li><li class=""><span><span class="preprocessor"> #pragma fragment frag</span><span> </span></span></li><li class="alt"><span><span class="preprocessor"> #include "UnityCG.cginc"</span><span> </span></span></li><li class=""><span> </span></li><li class="alt"><span> uniform sampler2D _MainTex; </span></li><li class=""><span> uniform sampler2D _NoiseTex; </span></li><li class="alt"><span> uniform <span class="keyword">float</span><span> _DissolveSpeed; </span></span></li><li class=""><span> uniform <span class="keyword">float</span><span> _EdgeWidth; </span></span></li><li class="alt"><span> uniform float4 _EdgeColor; </span></li><li class=""><span> uniform <span class="keyword">float</span><span> _StartTime; </span></span></li><li class="alt"><span> </span></li><li class=""><span> float4 frag(v2f_img i):COLOR </span></li><li class="alt"><span> { </span></li><li class=""><span> <span class="keyword">float</span><span> DissolveFactor = saturate((_Time.y - _StartTime) / _DissolveSpeed); </span></span></li><li class="alt"><span> <span class="keyword">float</span><span> noiseValue = tex2D(_NoiseTex,i.uv).r; </span></span></li><li class=""><span> <span class="keyword">if</span><span>(noiseValue <= DissolveFactor) </span></span></li><li class="alt"><span> { </span></li><li class=""><span> discard; </span></li><li class="alt"><span> } </span></li><li class=""><span> </span></li><li class="alt"><span> float4 texColor = tex2D(_MainTex,i.uv); </span></li><li class=""><span> <span class="keyword">float</span><span> EdgeFactor = saturate((noiseValue - DissolveFactor)/(_EdgeWidth*DissolveFactor)); </span></span></li><li class="alt"><span> float4 BlendColor = texColor * _EdgeColor; </span></li><li class=""><span> </span></li><li class="alt"><span> <span class="keyword">return</span><span> lerp(texColor,BlendColor,1 - EdgeFactor); </span></span></li><li class=""><span> } </span></li><li class="alt"><span> </span></li><li class=""><span> ENDCG </span></li><li class="alt"><span> } </span></li><li class=""><span> } </span></li><li class="alt"><span> </span></li><li class=""><span> FallBack Off </span></li><li class="alt"><span>} </span></li></ol></div><pre code_snippet_id="1693878" snippet_file_name="blog_20160523_1_7335827" name="code" class="csharp" style="display: none;">Shader "Esfog/Dissolve" { Properties { _MainTex ("Base (RGB)", 2D) = "white" {} _NoiseTex ("NoiseTex (R)",2D) = "white"{} _DissolveSpeed ("DissolveSpeed (Second)",Float) = 1 _EdgeWidth("EdgeWidth",Range(0,0.5)) = 0.1 _EdgeColor("EdgeColor",Color) = (1,1,1,1) _StartTime("StartTime",Float) = 0 } SubShader { Tags { "RenderType"="Opaque" } Pass { CGPROGRAM #pragma vertex vert_img #pragma fragment frag #include "UnityCG.cginc" uniform sampler2D _MainTex; uniform sampler2D _NoiseTex; uniform float _DissolveSpeed; uniform float _EdgeWidth; uniform float4 _EdgeColor; uniform float _StartTime; float4 frag(v2f_img i):COLOR { float DissolveFactor = saturate((_Time.y - _StartTime) / _DissolveSpeed); float noiseValue = tex2D(_NoiseTex,i.uv).r; if(noiseValue <= DissolveFactor) { discard; } float4 texColor = tex2D(_MainTex,i.uv); float EdgeFactor = saturate((noiseValue - DissolveFactor)/(_EdgeWidth*DissolveFactor)); float4 BlendColor = texColor * _EdgeColor; return lerp(texColor,BlendColor,1 - EdgeFactor); } ENDCG } } FallBack Off}</pre><br>重现效果代码如下:<br><p></p><p></p><div class="dp-highlighter bg_csharp"><div class="bar"><div class="tools"><b>[csharp]</b> <a href="#" class="ViewSource" title="view plain" onclick="dp.sh.Toolbar.Command('ViewSource',this);return false;">view plain</a><span data-mod="popu_168"> <a href="#" class="CopyToClipboard" title="copy" onclick="dp.sh.Toolbar.Command('CopyToClipboard',this);return false;">copy</a><div style="position: absolute; left: 734px; top: 3640px; width: 18px; height: 18px; z-index: 99;"><embed id="ZeroClipboardMovie_2" src="http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf" loop="false" menu="false" quality="best" bgcolor="#ffffff" width="18" height="18" name="ZeroClipboardMovie_2" align="middle" allowscriptaccess="always" allowfullscreen="false" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" flashvars="id=2&width=18&height=18" wmode="transparent"></div></span><span data-mod="popu_169"> <a href="#" class="PrintSource" title="print" onclick="dp.sh.Toolbar.Command('PrintSource',this);return false;">print</a></span><a href="#" class="About" title="?" onclick="dp.sh.Toolbar.Command('About',this);return false;">?</a><span class="tracking-ad" data-mod="popu_167"><a href="https://code.csdn.net/snippets/1693878" target="_blank" title="在CODE上查看代码片" style="text-indent:0;"><img src="https://code.csdn.net/assets/CODE_ico.png" width="12" height="12" alt="在CODE上查看代码片" style="position:relative;top:1px;left:2px;"></a></span><span class="tracking-ad" data-mod="popu_170"><a href="https://code.csdn.net/snippets/1693878/fork" target="_blank" title="派生到我的代码片" style="text-indent:0;"><img src="https://code.csdn.net/assets/ico_fork.svg" width="12" height="12" alt="派生到我的代码片" style="position:relative;top:2px;left:2px;"></a></span></div></div><ol start="1" class="dp-c"><li class="alt"><span><span>Shader </span><span class="string">"lyh/Show"</span><span> </span></span></li><li class=""><span>{ </span></li><li class="alt"><span> Properties </span></li><li class=""><span> { </span></li><li class="alt"><span> _MainTex (<span class="string">"Base (RGB)"</span><span>, 2D) = </span><span class="string">"white"</span><span> {} </span></span></li><li class=""><span> _NoiseTex (<span class="string">"NoiseTex (R)"</span><span>,2D) = </span><span class="string">"white"</span><span>{} </span></span></li><li class="alt"><span> _DissolveSpeed (<span class="string">"DissolveSpeed (Second)"</span><span>,Float) = 1 </span></span></li><li class=""><span> _EdgeWidth(<span class="string">"EdgeWidth"</span><span>,Range(0,0.5)) = 0.1 </span></span></li><li class="alt"><span> _EdgeColor(<span class="string">"EdgeColor"</span><span>,Color) = (1,1,1,1) </span></span></li><li class=""><span> _StartTime(<span class="string">"StartTime"</span><span>,Float) = 0 </span></span></li><li class="alt"><span> } </span></li><li class=""><span> SubShader </span></li><li class="alt"><span> { </span></li><li class=""><span> Tags { <span class="string">"RenderType"</span><span>=</span><span class="string">"Opaque"</span><span> } </span></span></li><li class="alt"><span> </span></li><li class=""><span> Pass </span></li><li class="alt"><span> { </span></li><li class=""><span> CGPROGRAM </span></li><li class="alt"><span><span class="preprocessor"> #pragma vertex vert_img</span><span> </span></span></li><li class=""><span><span class="preprocessor"> #pragma fragment frag</span><span> </span></span></li><li class="alt"><span><span class="preprocessor"> #include "UnityCG.cginc"</span><span> </span></span></li><li class=""><span> </span></li><li class="alt"><span> uniform sampler2D _MainTex; </span></li><li class=""><span> uniform sampler2D _NoiseTex; </span></li><li class="alt"><span> uniform <span class="keyword">float</span><span> _DissolveSpeed; </span></span></li><li class=""><span> uniform <span class="keyword">float</span><span> _EdgeWidth; </span></span></li><li class="alt"><span> uniform float4 _EdgeColor; </span></li><li class=""><span> uniform <span class="keyword">float</span><span> _StartTime; </span></span></li><li class="alt"><span> </span></li><li class=""><span> float4 frag(v2f_img i):COLOR </span></li><li class="alt"><span> { </span></li><li class=""><span> <span class="keyword">float</span><span> DissolveFactor = saturate((_Time.y - _StartTime) / _DissolveSpeed); </span></span></li><li class="alt"><span> <span class="keyword">float</span><span> noiseValue = tex2D(_NoiseTex,i.uv).r; </span></span></li><li class=""><span> </span></li><li class="alt"><span> float4 texColor = tex2D(_MainTex,i.uv); </span></li><li class=""><span> <span class="keyword">float</span><span> EdgeFactor = saturate((noiseValue - DissolveFactor)/(_EdgeWidth*DissolveFactor)); </span></span></li><li class="alt"><span> float4 BlendColor = texColor * _EdgeColor; </span></li><li class=""><span> </span></li><li class="alt"><span> clip(1 - EdgeFactor - 0.01); </span></li><li class=""><span> <span class="keyword">return</span><span> lerp(BlendColor,texColor,1 - EdgeFactor); </span></span></li><li class="alt"><span> } </span></li><li class=""><span> </span></li><li class="alt"><span> ENDCG </span></li><li class=""><span> } </span></li><li class="alt"><span> } </span></li><li class=""><span> </span></li><li class="alt"><span> FallBack Off </span></li><li class=""><span>} </span></li></ol></div><pre code_snippet_id="1693878" snippet_file_name="blog_20160523_2_8350366" name="code" class="csharp" style="display: none;">Shader "lyh/Show" { Properties { _MainTex ("Base (RGB)", 2D) = "white" {} _NoiseTex ("NoiseTex (R)",2D) = "white"{} _DissolveSpeed ("DissolveSpeed (Second)",Float) = 1 _EdgeWidth("EdgeWidth",Range(0,0.5)) = 0.1 _EdgeColor("EdgeColor",Color) = (1,1,1,1) _StartTime("StartTime",Float) = 0 } SubShader { Tags { "RenderType"="Opaque" } Pass { CGPROGRAM #pragma vertex vert_img #pragma fragment frag #include "UnityCG.cginc" uniform sampler2D _MainTex; uniform sampler2D _NoiseTex; uniform float _DissolveSpeed; uniform float _EdgeWidth; uniform float4 _EdgeColor; uniform float _StartTime; float4 frag(v2f_img i):COLOR { float DissolveFactor = saturate((_Time.y - _StartTime) / _DissolveSpeed); float noiseValue = tex2D(_NoiseTex,i.uv).r; float4 texColor = tex2D(_MainTex,i.uv); float EdgeFactor = saturate((noiseValue - DissolveFactor)/(_EdgeWidth*DissolveFactor)); float4 BlendColor = texColor * _EdgeColor; clip(1 - EdgeFactor - 0.01); return lerp(BlendColor,texColor,1 - EdgeFactor); } ENDCG } } FallBack Off}</pre><br>在给出的参考链接中,可以很好地了解到原理,这里就不解释了,而重现效果不过就是溶解效果的反转了。这里需要控制一下时间:<p></p><p></p><div class="dp-highlighter bg_csharp"><div class="bar"><div class="tools"><b>[csharp]</b> <a href="#" class="ViewSource" title="view plain" onclick="dp.sh.Toolbar.Command('ViewSource',this);return false;">view plain</a><span data-mod="popu_168"> <a href="#" class="CopyToClipboard" title="copy" onclick="dp.sh.Toolbar.Command('CopyToClipboard',this);return false;">copy</a><div style="position: absolute; left: 734px; top: 4625px; width: 18px; height: 18px; z-index: 99;"><embed id="ZeroClipboardMovie_3" src="http://static.blog.csdn.net/scripts/ZeroClipboard/ZeroClipboard.swf" loop="false" menu="false" quality="best" bgcolor="#ffffff" width="18" height="18" name="ZeroClipboardMovie_3" align="middle" allowscriptaccess="always" allowfullscreen="false" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer" flashvars="id=3&width=18&height=18" wmode="transparent"></div></span><span data-mod="popu_169"> <a href="#" class="PrintSource" title="print" onclick="dp.sh.Toolbar.Command('PrintSource',this);return false;">print</a></span><a href="#" class="About" title="?" onclick="dp.sh.Toolbar.Command('About',this);return false;">?</a><span class="tracking-ad" data-mod="popu_167"><a href="https://code.csdn.net/snippets/1693878" target="_blank" title="在CODE上查看代码片" style="text-indent:0;"><img src="https://code.csdn.net/assets/CODE_ico.png" width="12" height="12" alt="在CODE上查看代码片" style="position:relative;top:1px;left:2px;"></a></span><span class="tracking-ad" data-mod="popu_170"><a href="https://code.csdn.net/snippets/1693878/fork" target="_blank" title="派生到我的代码片" style="text-indent:0;"><img src="https://code.csdn.net/assets/ico_fork.svg" width="12" height="12" alt="派生到我的代码片" style="position:relative;top:2px;left:2px;"></a></span></div></div><ol start="1" class="dp-c"><li class="alt"><span><span>material.SetFloat(</span><span class="string">"_StartTime"</span><span>, Time.realtimeSinceStartup); </span></span></li></ol></div><pre code_snippet_id="1693878" snippet_file_name="blog_20160523_3_2636528" name="code" class="csharp" style="display: none;">material.SetFloat("_StartTime", Time.realtimeSinceStartup);</pre><br><p></p> </div>
0 0
- 溶解与重现
- [UnityShader3]溶解与重现效果
- struts2漏洞重现与编译
- 重现
- 溶解效果
- 溶解效果
- 溶解效果
- 汉服重现与中国的文艺复兴
- GPS参数提取与轨迹重现实验
- ORA-01460的重现与解决
- WebView与JS交互问题重现
- 重现Redis--数据结构与对象(一)
- 重现Redis--数据结构与对象(二)
- 重现Redis--数据结构与对象(三)
- 图片溶解渐显效果
- 溶解(Dissolve)效果
- shader溶解特效
- unity 溶解贴花编辑器
- 深拷贝和浅拷贝和copy和mutableCopy总结
- Hibernate注解映射的使用
- 跟我一起写 Makefile
- 工作邮件的若干注意事项
- 小白进阶之矩阵乘法
- 溶解与重现
- Android NDK 交叉编译
- 【p2p金融平台开发】Log4j.properties配置详解
- JNI学习之:C/C++基础知识学习
- java 数据结构容器之HashSet
- github项目解析(一)-->上传android项目至github
- placeholer字体颜色修改
- 15-CSS样式设置技巧
- Thread sleep方法