【Unity Shader实例】 水体WaterEffect(二) 用贴图和uv动画模拟水效
Unity Shader实现简单水体效果
效果展示
原理
用贴图和uv动画模拟水效实现”假”水。
设计
找一张水波的贴图,处理它的uv值,让贴图流动起来。这样就用静态纹理和uv动画模拟出了动态水流动的效果。
实现要点
- 贴图流动
贴图流动的实质就是uv偏移,图片各个部分的偏移程度有区别(可以借助噪声图让uv偏移程度具有随机性的区别)就实现了扭曲效果。让偏移程度与时间相关,就会有种贴图随着时间发生流动的感觉。 更多关于贴图流动的实现和原理看这里:贴图流动。
具体实现
完整的shader代码
Shader "Water/Liudong"
{Properties{_MainTex ("MainTex", 2D) = "white" {}_NoiseTex("NoiseTex", 2D) = "white" {}_Intensity("intensity", float) = 0.1_XSpeed("Flow Speed", float) = -0.2}SubShader{Tags { "RenderType"="Opaque" }LOD 100Pass{CGPROGRAM#pragma vertex vert#pragma fragment frag// make fog work#pragma multi_compile_fog#include "UnityCG.cginc"struct appdata{float4 vertex : POSITION;float2 uv : TEXCOORD0;};struct v2f{float2 uv : TEXCOORD0;UNITY_FOG_COORDS(1)float4 vertex : SV_POSITION;};sampler2D _MainTex;float4 _MainTex_ST;sampler2D _NoiseTex;float _Intensity;float _XSpeed;v2f vert (appdata v){v2f o;o.vertex = UnityObjectToClipPos(v.vertex);o.uv = TRANSFORM_TEX(v.uv, _MainTex);UNITY_TRANSFER_FOG(o,o.vertex);return o;}fixed4 frag (v2f i) : SV_Target{// sample the texturefixed4 noise_col = tex2D(_NoiseTex, i.uv + fixed2(_Time.y*_XSpeed, 0));fixed uOffset = noise_col.r;fixed vOffset = noise_col.r;fixed4 col = tex2D(_MainTex, i.uv +_Intensity*fixed2(uOffset, vOffset));// apply fogUNITY_APPLY_FOG(i.fogCoord, col);return col;}ENDCG}}
}
效果
总结
我们已经实现了一个最简单的水体效果,但是这样做出来的水特别假,它既没有对周围环境的反射也没有对水下物体的折射,也没有真实水面的起伏波浪,当水中有物体时也不会在水与物体交界处产生浪花等等。这些效果,我们会来后续的文章中继续讨论。
附:配套Unity3d工程下载地址
【Unity Shader实例】 水体WaterEffect(二) 用贴图和uv动画模拟水效相关推荐
- 【Unity Shader实例】 水体WaterEffect(一) 设计
Unity Shader 水体效果实现的设计 在设计水体效果的实现方案之前,我们先参考一下大神们写好的精彩的例子,比如DCG Water Shader的效果,这也是我们努力的目标. 好!~ 现在开始实 ...
- unity shader学习---光照模型(二)
更复杂的光照 效果图 理论 unity的光源类型 unity的渲染路径 在这里插入图片描述 实验 多光源 阴影 不透明物体的阴影 让物体接收阴影 统-管理光照衰减和阴影 透明度物体的阴影 代码 多光源 ...
- 【Unity】Unity Shader学习笔记(二)渲染管线
文章目录 渲染管线(Randering Pipeline) 渲染流程 可编程渲染管线 应用阶段 把数据加载到显存中 设置渲染状态 调用DrawCall 几何阶段.光栅化阶段 渲染管线(Randerin ...
- Unity Shader(一) Lowpoly动态低多边形 (QQ登录界面低边动画)
前言 在逛论坛的时候偶然发现有人在问动态低多边形(Lowpoly)是如何实现的,因为经常编写UGUI拓展对顶点操作较为熟悉的我立马就想到利用继承UnityEngine.Graphic,重写OnPopu ...
- Unity shader入门精要学习笔记-代码篇6(序列帧动画/滚动背景/流动河流/广告牌/顶点动画的阴影)
一.序列帧动画 建立一个四边形对着摄像机. 我们需要一张序列帧图像,这里用到8x8的爆炸图. 给四边形上材质和shader,代码如下: Shader "Custom/NewSurfaceSh ...
- 【Unity Shader】Special Effects(一)UI特效的动画播放器
更新日期:2021年8月16日. Github源码:[点我获取源码] 索引 [系列简介] [SpecialEffects 模块简介] [UI特效的动画播放器] 下载SpecialEffects模块 使 ...
- Unity Shader入门笔记
学习资料:https://onevcat.com/2013/07/shader-tutorial-1/猫都能学会的Unity3D Shader入门指南(一)(二) 学习资料:http://98jy.n ...
- Shader实例:卡通水 Unity toon water shader
准备1: 加入以下脚本到摄像机让depth texture 有效,水面整体颜色变化基于深度. using UnityEngine;public class CameraDepthTextureMode ...
- Unity Shader入门精要学习笔记 - 第7章 基础纹理
转自 冯乐乐的 <Unity Shader 入门精要> 纹理最初的目的就是使用一张图片来控制模型的外观.使用纹理映射技术,我们可以把一张图"黏"在模型表面,逐纹素地控制 ...
最新文章
- iOS 关于第三方键盘
- 2021高考成绩查询是几点,2021高考查分是从几点到几点
- 人脸识别之insightface开源代码使用:训练、验证、测试(4)
- 查看mysql主从配置的状态及修正 slave不启动问题
- CodeForces - 1553E Permutation Shift(暴力+置换群求环)
- 高仿带感魔性病毒源码+成品(最近很火的)
- chrome91 后 SameSite by default cookies 不对外开放 解决方案
- cad怎么选择一个对象打散vba_CAD制图的二十四字秘诀!
- 蚂蚁课堂-第四期-基于springcloud构建微服务电商项目_阿里巴巴29个屌炸天的开源项目,你用过几个?附编程资料!!!...
- java keytool 导出证书,keytool 导出证书
- linux 怎么格式化u盘写保护,u盘写保护如何解除?去掉保护模式的具体方法
- 计算机组成原理/计算机硬件基础第五章:存储器
- 疯狂java笔记(七) - Java集合之Map
- 【2018十大VR眼镜排行榜】VR眼镜有哪些品牌。哪个牌子的VR眼镜比较好,性价比高,适合玩VR游戏的
- 内网用户通过域名或公网IP访问内部服务器的解决办法
- python微信朋友圈刷图_用python中的itchat可视化微信朋友圈
- 日本市场智能电视的主要功能
- 内发光html,如何使用css3实现字体内发光效果(详解)
- 如何快速绘制XRD标准图
- Python技法之简单递归下降Parser的实现方法