Unity3D手游开发日记(4) - 适合移动平台的热浪扭曲
热浪扭曲效果的实现,分两部分,一是抓图,二是扭曲扰动.其中难点在于抓图的处理,网上的解决方案有两种,在移动平台都有很多问题,只好自己实现了一种新的方案,效果还不错.
网上方案1. 用GrabPass抓图
GrabPass在有的手机上是不支持的...效率也是问题,所以...
代码可以看看:
- Shader "Luoyinan/Distortion/HeatDistortion"
- {
- Properties
- {
- _NoiseTex ("Noise Texture (RG)", 2D) = "white" {}
- _MainTex ("Alpha (A)", 2D) = "white" {}
- _HeatTime ("Heat Time", range (0,1.5)) = 1
- _HeatForce ("Heat Force", range (0,0.1)) = 0.1
- }
- Category
- {
- Tags { "Queue"="Transparent+1" "RenderType"="Transparent" }
- Blend SrcAlpha OneMinusSrcAlpha
- AlphaTest Greater .01
- Cull Off
- Lighting Off
- ZWrite Off
- SubShader
- {
- GrabPass
- {
- Name "BASE"
- Tags { "LightMode" = "Always" }
- }
- Pass
- {
- Name "BASE"
- Tags { "LightMode" = "Always" }
- CGPROGRAM
- #pragma vertex vert
- #pragma fragment frag
- #pragma fragmentoption ARB_precision_hint_fastest
- #include "UnityCG.cginc"
- struct appdata_t
- {
- float4 vertex : POSITION;
- fixed4 color : COLOR;
- float2 texcoord: TEXCOORD0;
- };
- struct v2f
- {
- float4 vertex : POSITION;
- float4 uvgrab : TEXCOORD0;
- float2 uvmain : TEXCOORD1;
- };
- float _HeatForce;
- float _HeatTime;
- float4 _MainTex_ST;
- float4 _NoiseTex_ST;
- sampler2D _NoiseTex;
- sampler2D _MainTex;
- v2f vert (appdata_t v)
- {
- v2f o;
- o.vertex = mul(UNITY_MATRIX_MVP, v.vertex);
- o.uvgrab = ComputeGrabScreenPos(o.vertex);
- o.uvmain = TRANSFORM_TEX( v.texcoord, _MainTex );
- return o;
- }
- sampler2D _GrabTexture;
- half4 frag( v2f i ) : COLOR
- {
- // noise effect
- half4 offsetColor1 = tex2D(_NoiseTex, i.uvmain + _Time.xz*_HeatTime);
- half4 offsetColor2 = tex2D(_NoiseTex, i.uvmain - _Time.yx*_HeatTime);
- i.uvgrab.x += ((offsetColor1.r + offsetColor2.r) - 1) * _HeatForce;
- i.uvgrab.y += ((offsetColor1.g + offsetColor2.g) - 1) * _HeatForce;
- half4 col = tex2Dproj(_GrabTexture, UNITY_PROJ_COORD(i.uvgrab));
- // Skybox's alpha is zero, don't know why.
- col.a = 1.0f;
- half4 tint = tex2D( _MainTex, i.uvmain);
- return col*tint;
- }
- ENDCG
- }
- }
- // ------------------------------------------------------------------
- // Fallback for older cards and Unity non-Pro
- SubShader
- {
- Blend DstColor Zero
- Pass
- {
- Name "BASE"
- SetTexture [_MainTex] { combine texture }
- }
- }
- }
- }
网上方案2:用RenderTexture来代替抓图
这种方法很坑爹,把场景再渲染一次?想想就很恐怖
我的方案: 后处理
换种思路,后处理其实就已经有了我们需要抓取的图,我们只需要渲染一个掩码图,就能实现局部的扭曲了,以前做次世代引擎的开发,很多特效都是后处理的实现的,比如人在水里面走水面泛起的涟漪,其实热浪扭曲也可以用类似的方法.
原理:
1.先用后处理实现全屏的扰动
2.用RenderTexture做实时的掩码图.
这样的话,效率开销只在两部分,一是后处理,二是把扭曲面片渲染到掩码图,
优化:
1.掩码图RenderTexture尽可能简单,关掉深度,抗锯齿等,用最简单的格式RenderTextureFormat.RGB565,黑白掩码图,不要alpha通道,掩码面片的shader可以用粒子的add shader
2.不需要扭曲的时候应该关闭掉扭曲用的后处理.不要一直开着.这个实现起来需要对掩码面片的存在有一个计数统计,才知道什么时候能关掉.
3.掩码图的比例一定要和屏幕保持一致,大小可设置为屏幕宽高的1/2或者1/4,
后处理的脚本:
后处理shader:
- Shader "Luoyinan/ImageEffect/HeatDistortion"
- {
- Properties
- {
- _MainTex ("Base (RGB)", 2D) = "white" {}
- _NoiseTex ("Noise Texture (RG)", 2D) = "white" {}
- _MaskTex ("Mask Texture", 2D) = "white" {}
- _HeatTime ("Heat Time", range (0,1.5)) = 1
- _HeatForce ("Heat Force", range (0,0.1)) = 0.1
- }
- SubShader
- {
- Pass
- {
- CGPROGRAM
- #pragma vertex vert_img
- #pragma fragment frag
- #pragma fragmentoption ARB_precision_hint_fastest
- #include "UnityCG.cginc"
- float _HeatForce;
- float _HeatTime;
- uniform sampler2D _MainTex;
- uniform sampler2D _NoiseTex;
- uniform sampler2D _MaskTex;
- fixed4 frag(v2f_img i) : COLOR
- {
- // 为了效率,掩码图是黑白的,so...
- fixed mask = tex2D(_MaskTex, i.uv).r;
- // 扭曲效果
- half4 offsetColor1 = tex2D(_NoiseTex, i.uv + _Time.xz*_HeatTime);
- half4 offsetColor2 = tex2D(_NoiseTex, i.uv - _Time.yx*_HeatTime);
- i.uv.x += ((offsetColor1.r + offsetColor2.r) - 1) * _HeatForce * mask;
- i.uv.y += ((offsetColor1.g + offsetColor2.g) - 1) * _HeatForce * mask;
- fixed4 renderTex = tex2D(_MainTex, i.uv);
- return renderTex;
- }
- ENDCG
- }
- }
- FallBack off
- }
Unity3D手游开发日记(4) - 适合移动平台的热浪扭曲的更多相关文章
- Unity3D手游开发日记(6) - 适合移动平台的水深处理
市面上大部分的手机游戏,水面都比较粗糙,也基本没发现谁做过水深的处理. 水深的处理在PC平台比较容易,因为很容易获得每个像素的深度,比如G-Buffer,有了像素的深度,就能计算出每个像素到水面的距离 ...
- Unity3D手游开发日记(5) - 适合移动平台的植被随风摆动
一直在思考怎么让场景更有生机,我觉得植被的随风摆动是必不可少的.CE3引擎的植被bending就做得特别棒.我也准备在手机上做一套. 先分析一下植被摆动常见的几种做法.其实不管哪种做法,核心就是让植被 ...
- Unity3D手游开发日记(7) - 适合移动平台的天气效果
腾讯的天涯明月刀的天气很棒,以前我也在CE3的基础上做了一个效果差不多的,但是在手机上,还是斜下固定视角的游戏,是否还需要一个天气系统? 而且没有G-Buffer的支持,很多牛逼效果实现不了,比如角色 ...
- Unity3D手游开发日记(9) - 互动草的效果
所谓互动草,就是角色跑动或者释放技能,能影响草的摆动方向和幅度. 前面的文章早已经实现了风吹草动的效果,迟迟没有在Unity上面做互动草,是因为以前我在端游项目做过一套太过于牛逼的方案.在CE3的互动 ...
- Unity3D手游开发日记(8) - 运动残影效果
2D游戏的残影很简单,美术做序列帧图片就行了,那么3D游戏的残影美术做不了,得靠程序员动态创建模型来处理. 实现原理也很简单: 1.间隔一定时间创建一个残影模型 GameObject go = Gam ...
- Unity3D手游开发日记(2) - 技能系统架构设计
我想把技能做的比较牛逼,所以项目一开始我就在思考,是否需要一个灵活自由的技能系统架构设计,传统的技能设计,做法都是填excel表,技能需要什么,都填表里,很死板,比如有的技能只需要1个特效,有的要10 ...
- Unity3D手游开发日记(3) - 场景加载进度条的完美方案
我以为做个进度条很简单,分分钟解决,结果折腾了一天才搞定,Unity有很多坑,要做完美需要逐一解决. 问题1:最简单的方法不能实现100%的进度 用最简单的方法来实现,不能实现100%的进度,原因是U ...
- Unity3D手游开发日记(1) - 移动平台实时阴影方案
阴影这个东西,说来就话长了,很多年前人们就开始研究出各种阴影技术,但都存在各种瑕疵和问题,直到近几年出现了PSSM,也就是CE3的CSM,阴影技术才算有个比较完美的解决方案.Unity自带的实时阴影, ...
- Unity3D手游开发实践
<腾讯桌球:客户端总结> 本次分享总结,起源于腾讯桌球项目,但是不仅仅限于项目本身.虽然基于Unity3D,很多东西同样适用于Cocos.本文从以下10大点进行阐述: 架构设计 原生插件/ ...
随机推荐
- JS_正则表达式_验证中文字符
正则表达式:"^[\u4e00-\u9fa5]{0,}$" . "/^[\u4E00-\u9FA5]{1,5}$/" 的含义: 在JS里,\uXXXX 是转义字 ...
- Keil出错解决方法
1.安装KEIL5后创建工程后出现这个报错 解决方法:打开下图目录的文件. Keil.STM32F1xx_DFP.pdsc文件是只读文件,必须将只读属性取消. 如下图所示,注释掉红色圆圈的哪一行,保存 ...
- Selenium2+python自动化-CSS定位语法
前言 一些人在使用selenium定位元素时,用的是xpath定位,因为xpath基本能解决定位的需求.css定位往往被忽略掉了,其实css定位也有它的价值,css定位更快,语法更简洁.这一篇css的 ...
- 概念这种东西--node.js
概念是一个既简单又复杂.既招人爱又招人恨的东西.概念是对一事务或现象的抽象.抽象好了,那就太方便问题的解决了,抽象坏了,那就驴唇不对马嘴,反而会让逻辑一塌糊涂.现实中经常有这样的概念:东北人怎么怎么样 ...
- TW实习日记:前三天
今天是2018年7月20号,周五.从周一开始实习到现在,终于想起来要写日记这种东西了,可以记录一下自己这一天所学所做所知也是蛮不错的.先简单总结一下自己的大学生活吧,算是多姿多彩,体验了很多东西.在大 ...
- 大O算法
大O计法:根据执行次数计算#sum = (1+n)*n/2://执行了一次,即为O(1)#for(i=0;i<n;i++);//执行了n次,即为O(n)#算法的时间复杂度:T(n) = O(f( ...
- Ryu学习总结(持续更新)
Ryu学习总结 该篇学习笔记,与其他分析Ryu控制器代码的笔记不同,主要按照程序的构成来进行分块总结,由于本人为新手入门,不能保证没有错误,如果发现错误,欢迎指教. 以下的内容主要来源: 源码 官方文 ...
- 袋鼠云旗下新公司云掣科技启航,深耕云MSP业务助推企业数字化转型
1983年3月15日,国际消费者联盟组织将3月15日确立为国际消费者权益日. 2019年3月15日,袋鼠云举办三周年年会. 一生二,二生三,三生万物.植树节后,万物生长. 年会现场,袋鼠云宣布成立新公 ...
- 如何通俗理解贝叶斯推断与beta分布?
有一枚硬币(不知道它是否公平),假如抛了三次,三次都是“花”: 能够说明它两面都是“花”吗? 1 贝叶斯推断 按照传统的算法,抛了三次得到三次“花”,那么“花”的概率应该是: 但是抛三次实在太少了,完 ...
- 20130501-Twitter向全美用户开放广告平台Twitter Ads
腾讯科技讯(晁晖)北京时间5月1日消息,据国外媒体报道,Twitter今天向所有美国用户开放了广告平台Twitter Ads.自2012年3月发布以来,Twitter Ads只向受邀请用户开放.Twi ...