先看效果:

看一下网格模型:

这就是个面片模型,越靠近边缘的地方,alpha值越低。所以烟有变淡的感觉。

如图:

注意箭头指的地方,面片这里故意做了个折角,这样让烟看起来更有在某个位置受风改变方向的感觉。

看shader参数:

两张贴图,一张做base,一张做2nd。

分别控制:

上面12个参数,控制的是两张贴图的使用方式,

修改的都是uv,speed是x,y方向的滚动速度,amplitude是x,y方向上sin的偏移幅度。freq是x,y方向上uv的频率。

最后两个:

color控制整体颜色变化,Multiplier控制的是颜色再提升的次数。

整体shader的注释:

Shader "MADFINGER/Environment/Scroll 2 Layers Sine AlphaBlended" {
Properties {
    _MainTex ("Base layer (RGB)", 2D) = "white" {}
    _DetailTex ("2nd layer (RGB)", 2D) = "white" {}
    _ScrollX ("Base layer Scroll speed X", Float) = 1.0
    _ScrollY ("Base layer Scroll speed Y", Float) = 0.0
    _Scroll2X ("2nd layer Scroll speed X", Float) = 1.0
    _Scroll2Y ("2nd layer Scroll speed Y", Float) = 0.0
    _SineAmplX ("Base layer sine amplitude X",Float) = 0.5 
    _SineAmplY ("Base layer sine amplitude Y",Float) = 0.5
    _SineFreqX ("Base layer sine freq X",Float) = 10 
    _SineFreqY ("Base layer sine freq Y",Float) = 10
    _SineAmplX2 ("2nd layer sine amplitude X",Float) = 0.5 
    _SineAmplY2 ("2nd layer sine amplitude Y",Float) = 0.5
    _SineFreqX2 ("2nd layer sine freq X",Float) = 10 
    _SineFreqY2 ("2nd layer sine freq Y",Float) = 10
    _Color("Color", Color) = (1,1,1,1)
    
    _MMultiplier ("Layer Multiplier", Float) = 2.0
}

SubShader {
    Tags { "Queue"="Transparent" "IgnoreProjector"="True" "RenderType"="Transparent" }
    
    Blend SrcAlpha OneMinusSrcAlpha
    Cull Off Lighting Off 
    ZWrite On Fog { Color (0,0,0,0) }
    
    LOD 100
    
    
    
    CGINCLUDE
    #pragma multi_compile LIGHTMAP_OFF LIGHTMAP_ON
    #pragma exclude_renderers molehill    
    #include "UnityCG.cginc"
    sampler2D _MainTex;
    sampler2D _DetailTex;

float4 _MainTex_ST;
    float4 _DetailTex_ST;
    
    float _ScrollX;
    float _ScrollY;
    float _Scroll2X;
    float _Scroll2Y;
    float _MMultiplier;
    
    float _SineAmplX;
    float _SineAmplY;
    float _SineFreqX;
    float _SineFreqY;

float _SineAmplX2;
    float _SineAmplY2;
    float _SineFreqX2;
    float _SineFreqY2;
    float4 _Color;

struct v2f {
        float4 pos : SV_POSITION;
        float4 uv : TEXCOORD0;
        fixed4 color : TEXCOORD1;
    };

v2f vert (appdata_full v)
    {
        v2f o;
        o.pos = mul(UNITY_MATRIX_MVP, v.vertex);
        o.uv.xy = TRANSFORM_TEX(v.texcoord.xy,_MainTex) + frac(float2(_ScrollX, _ScrollY) * _Time);   //先给底图根据时间做uv滚动
        o.uv.zw = TRANSFORM_TEX(v.texcoord.xy,_DetailTex) + frac(float2(_Scroll2X, _Scroll2Y) * _Time); //uv 滚动
        
        o.uv.x += sin(_Time * _SineFreqX) * _SineAmplX;    //给底图x方向上做sin周期扰动
        o.uv.y += sin(_Time * _SineFreqY) * _SineAmplY; //底图y方向上做sin周期扰动
        
        o.uv.z += sin(_Time * _SineFreqX2) * _SineAmplX2;//2nd图的uv存在texcoord的zw中
        o.uv.w += sin(_Time * _SineFreqY2) * _SineAmplY2;
        
        o.color = _MMultiplier * _Color * v.color; //给最终的颜色乘以外面赋进来的color和Multiplier。
        return o;
    }
    ENDCG

Pass {
        CGPROGRAM
        #pragma vertex vert
        #pragma fragment frag
//        #pragma fragmentoption ARB_precision_hint_fastest        
        fixed4 frag (v2f i) : COLOR
        {
            fixed4 o;
            fixed4 tex = tex2D (_MainTex, i.uv.xy); //底图取xy
            fixed4 tex2 = tex2D (_DetailTex, i.uv.zw);//2nd图取zw
            
            //o = tex * tex2 * i.color;
            o=tex2*tex*i.color;
                        
            return o;
        }
        ENDCG 
    }    
}
}

效果图中箭头指的地方,有点泛红,这个也是在面片里控制的。

面片中,越靠近火源的点,color的值越偏红。如图:

3D优化之ShadowGun系列二:浓烟,使用面片模拟粒子效果相关推荐

  1. 【UE Sequencer系列】07-创建慢镜头、粒子效果、淡入淡出效果、添加音乐

    目录 一.创建慢镜头 二.创建粒子效果 三.创建淡入淡出效果 四.添加音乐 一.创建慢镜头 1. 添加时间膨胀轨迹 2. 设置一开始的播放速率为1 通过减少时间膨胀系数来制作慢镜头 二.创建粒子效果 ...

  2. linux cpu监控方案,Linux性能优化和监控系列(二)分析CPU性能

    分析CPU性能 top命令提供了监控CPU性能的基本功能, 如果需要更加深入的挖掘CPU的性能问题, top所提供的信息不足以做到. 由于大多数人认为CPU性能是体现服务器性能的主要因素, 所以在遇到 ...

  3. android 原生开发 3d地图 下载_arcgis api 3.x for js 入门开发系列二不同地图服务展示(附源码下载)...

    前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...

  4. 图机器学习(GML)图神经网络(GNN)原理和代码实现(前置学习系列二)

    图机器学习(GML)&图神经网络(GNN)原理和代码实现(PGL)[前置学习系列二] 上一个项目对图相关基础知识进行了详细讲述,下面进图GML networkx :NetworkX 是一个 P ...

  5. 从《Doom》到《Dunia》 回顾3D游戏引擎发展历程二

    Quake III / id Tech 3 就像AMD与Intel,Nvidia与ATI,10年前,游戏引擎的战争主要集中在Quake III(现在被称为id Tech 3)与Unreal之间. 顾名 ...

  6. A.图机器学习(GML)图神经网络(GNN)原理和代码实现(前置学习系列二)

    图学习图神经网络算法专栏简介:主要实现图游走模型(DeepWalk.node2vec):图神经网络算法(GCN.GAT.GraphSage),部分进阶 GNN 模型(UniMP标签传播.ERNIESa ...

  7. SEO系列二:何为用户体验?如何做好用户体验?

    昨天写了一篇<SEO系列一:SEO是什么?SEO有什么意义?>的文章,受到了汇道童鞋们的支持和鼓舞,周珍在这里和大家说声谢谢.甚至还有童鞋说期待我写到SEO系列2000,是否能写到2000 ...

  8. 微服务架构系列二:密码强度评测的实现与实验

    本文是继<微服务架构系列一:关键技术与原理研究>的后续,系列一中论述了微服务研究的背景和意义,主要调研了传统架构的发展以及存在的问题和微服务架构的由来,然后针对微服务架构的设计原则.容器技 ...

  9. Tomcat源码解析系列二:Tomcat总体架构

    Tomcat即是一个HTTP服务器,也是一个servlet容器,主要目的就是包装servlet,并对请求响应相应的servlet,纯servlet的web应用似乎很好理解Tomcat是如何装载serv ...

  10. PyOpenGL之3D界面详解(二)

    本文转自:http://eyehere.net/2011/learn-opengl-3d-by-pyopengl-2/ 每个人都有做3D的潜质 看看这张图片(选自"一秒钟看穿统计陷阱&quo ...

最新文章

  1. 针对当前项目SLED存在短缺XX天
  2. windows to go 命令行模式建立
  3. JPA JoinColumn vs mappedBy
  4. 2011年1月MVP申请将于10月13日截止
  5. StyleGAN-基于样式的生成对抗网络(论文阅读总结)(精)
  6. 通过telnet来实践HTTP协议。
  7. Linux RabbitMQ+Erlang /sbin/service rabbitmq-server start 启动报错
  8. mysql中创建表并添加约束_创建表并添加约束
  9. 【人才引进】博士补贴75万,硕士补贴20万,这个南方城市,高待遇引才150人!...
  10. mysql definer super_技术分享 | 改写 mysqldump 解决 DEFINER 问题
  11. Nginx-详解其原理
  12. 使用unity制作游戏——打砖块
  13. flea-jersey使用之文件上传接入
  14. RecyclerView在GridLayoutManager情况下实现四周都有分割线的ItemDecoration
  15. SV绿皮书笔记(九)暂时完结
  16. php生成推广二维码海报、合成图片demo
  17. 解决:Notepad++搜索不到(无法安装)Finger Text插件
  18. 如何设置Parallels Desktop,让Windows更加好用
  19. 射频中IM3、IIP3、OIP3、G、P1dB指标计算
  20. ORACLE ORA-01950 对表空间无权限

热门文章

  1. iOS逆向工程开发技巧
  2. JavaScript基础知识总结(必看篇)
  3. 论文翻译:2020_Demucs:Real Time Speech Enhancement in the Waveform Domain
  4. Spring AOP中的责任链设计模式
  5. 数字图像处理(三):函数fspecial
  6. 亲测码支付第三方支付源码、完美对接日主题系列网站
  7. XRD 数据处理:使用 Origin 进行多谱图对比
  8. 2022珠三角深圳锂电池技术展览会暨论坛|2022华南广东深圳锂电池技术展览会
  9. HTML当前标签鼠标停留下划线和变色效果
  10. 2022-2028年中国高尔夫GPS手表行业竞争现状及投资策略研究报告