unity shader ---水箱水位线效果

2023-11-21 03:50

本文主要是介绍unity shader ---水箱水位线效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

应功能需求,要做一个透明水箱效果,并包含一个水位线,表示水位高度,找了一些资源整改了一下,接下来,上代码

效果:

 

shader:

Shader "Unlit/SpecialFX/Liquid"
{Properties//属性{_Tint("Tint", Color) = (1,1,1,1)_FillAmount("Fill Amount", Range(0,1)) = 0.0_WobbleX("WobbleX", Range(-1,1)) = 0.0_WobbleZ("WobbleZ", Range(-1,1)) = 0.0_TopColor("Top Color", Color) = (1,1,1,1)_FoamColor("Foam Line Color", Color) = (1,1,1,1)_Rim("Foam Line Width", Range(0,0.1)) = 0.0_RimColor("Rim Color", Color) = (1,1,1,1)_RimPower("Rim Power", Range(0,10)) = 0.0_CubeColor("CubeColor", color) = (1,1,1,1)_Width("Width", range(0,0.5)) = 0.1_Length("Length", range(0.5,1)) = 0.1_ScaleColor("ScaleColor", color) = (1,1,1,1)_ScaleWidth("ScaleLine Width", Range(0,0.1)) = 0.0_ScaleHight("ScaleLine Hight", range(0,1)) = 0.1}SubShader//着色器{Tags {"Queue" = "Transparent"  "DisableBatching" = "True" }Pass {Zwrite On//将像素的深度写入深度缓存中  Cull Off // 关闭阴影剔除AlphaToMask On // transparencyblend srcalpha oneminussrcalpha//渲染代码在CGPROGRAM和ENDCG之间CGPROGRAM#pragma vertex vert#pragma fragment frag			#pragma multi_compile_fog// make fog work#include "UnityCG.cginc"//引入Unity内置定义fixed4 _Tint;fixed4 _CubeColor;fixed4 _LineColor;fixed _Width;fixed _Length;float _FillAmount, _WobbleX, _WobbleZ;float4 _TopColor, _RimColor, _FoamColor, _ScaleColor;float _Rim, _RimPower, _ScaleWidth, _ScaleHight;struct v2f {float4 pos : SV_POSITION;float2 uv : TEXCOORD0;UNITY_FOG_COORDS(1)float3 viewDir : COLOR;float3 normal : COLOR2;float fillEdge : TEXCOORD2;float warningLine : TEXCOORD1;};struct appdata {float4 vertex : POSITION;float2 uv : TEXCOORD0;float3 normal : NORMAL;};float4 RotateAroundYInDegrees(float4 vertex, float degrees) {float alpha = degrees * UNITY_PI / 180;float sina, cosa;sincos(alpha, sina, cosa);float2x2 m = float2x2(cosa, sina, -sina, cosa);return float4(vertex.yz , mul(m, vertex.xz)).xzyw;}v2f vert(appdata v){v2f o;o.pos = UnityObjectToClipPos(v.vertex);o.uv = v.uv;UNITY_TRANSFER_FOG(o,o.pos);//获取世界坐标float3 worldPos = mul(unity_ObjectToWorld, v.vertex.xyz);// XY轴晃动float3 worldPosX = RotateAroundYInDegrees(float4(worldPos,0),360);// XZ轴晃动 float3 worldPosZ = float3 (worldPosX.y, worldPosX.z, worldPosX.x);// 结合旋转与worldPos,基于正弦波,脚本控制float3 worldPosAdjusted = worldPos + (worldPosX  * _WobbleX) + (worldPosZ* _WobbleZ);// 控制液体高度o.fillEdge = worldPosAdjusted.y + _FillAmount;o.warningLine = worldPos.y + _ScaleHight;o.viewDir = normalize(ObjSpaceViewDir(v.vertex));o.normal = v.normal;return o;}fixed4 frag(v2f i, fixed facing : VFACE) : SV_Target{fixed4 col = _Tint;//边框线  有待优化 理应不应使用if块if (((i.uv.x < _Width || i.uv.x > 1 - _Width) && (i.uv.y < 1 - _Length || i.uv.y > _Length)) || ((i.uv.y < _Width || i.uv.y > 1 - _Width) && (i.uv.x < 1 - _Length || i.uv.x > _Length))){col += _CubeColor;}//液位线float4 lineHight = step(i.warningLine,0.5) - step(i.warningLine, (0.5 -_ScaleWidth));float4 lineColored = lineHight * (_ScaleColor*0.9 );//烟雾效果UNITY_APPLY_FOG(i.fogCoord, col);//边缘高光float dotProduct = 1 - pow(dot(i.normal, i.viewDir), _RimPower);float4 RimResult = smoothstep(0.5, 1.0, dotProduct);RimResult *= _RimColor;// 液体表面float4 foam = step(i.fillEdge, 0.5) - step(i.fillEdge, (0.5 - _Rim));float4 foamColored = foam * (_FoamColor * 0.9);// 液体内部float4 result = step(i.fillEdge, 0.5) - foam;float4 resultColored = result * col;// 液体融合float4 finalResult =  foamColored + col+ lineColored;finalResult.rgb += RimResult;// color of backfaces/ topfloat4 topColor = _TopColor * (foam + result);//VFACE returns positive for front facing, negative for backfacingreturn facing > 0 ? finalResult : topColor;}ENDCG}}
}

c#:

using UnityEngine;namespace DataVisualization
{public class Wobble : MonoBehaviour{Renderer rend;Vector3 lastPos;Vector3 velocity;Vector3 lastRot;Vector3 angularVelocity;public float MaxWobble = 0.03f;public float WobbleSpeed = 1f;public float Recovery = 1f;float wobbleAmountY;float wobbleAmountZ;float wobbleAmountToAddY;float wobbleAmountToAddZ;float pulse;float time = 0.5f;// Use this for initializationvoid Start(){rend = GetComponent<Renderer>();}private void Update(){time += Time.deltaTime;// decrease wobble over timewobbleAmountToAddY = Mathf.Lerp(wobbleAmountToAddY, 0, Time.deltaTime * (Recovery));wobbleAmountToAddZ = Mathf.Lerp(wobbleAmountToAddZ, 0, Time.deltaTime * (Recovery));// make a sine wave of the decreasing wobblepulse = 2 * Mathf.PI * WobbleSpeed;wobbleAmountY = wobbleAmountToAddY * Mathf.Sin(pulse * time);wobbleAmountZ = wobbleAmountToAddZ * Mathf.Sin(pulse * time) * 0.1f;// send it to the shaderrend.material.SetFloat("_WobbleX", wobbleAmountY);rend.material.SetFloat("_WobbleZ", wobbleAmountZ);// velocityangularVelocity = transform.rotation.eulerAngles - lastRot;if (Input.GetMouseButton(1)){// add clamped velocity to wobblewobbleAmountToAddY += Mathf.Clamp((Input.GetAxis("Mouse X") + (angularVelocity.z * 0.2f)) * MaxWobble, -MaxWobble, MaxWobble);wobbleAmountToAddZ += Mathf.Clamp((Input.GetAxis("Mouse Y") + (angularVelocity.x * 0.2f)) * MaxWobble, -MaxWobble, MaxWobble);}// keep last positionlastRot = transform.rotation.eulerAngles;}}
}

这篇关于unity shader ---水箱水位线效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/399606

相关文章

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

使用Python实现生命之轮Wheel of life效果

《使用Python实现生命之轮Wheeloflife效果》生命之轮Wheeloflife这一概念最初由SuccessMotivation®Institute,Inc.的创始人PaulJ.Meyer... 最近看一个生命之轮的视频,让我们珍惜时间,因为一生是有限的。使用python创建生命倒计时图表,珍惜时间

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

防近视护眼台灯什么牌子好?五款防近视效果好的护眼台灯推荐

在家里,灯具是属于离不开的家具,每个大大小小的地方都需要的照亮,所以一盏好灯是必不可少的,每个发挥着作用。而护眼台灯就起了一个保护眼睛,预防近视的作用。可以保护我们在学习,阅读的时候提供一个合适的光线环境,保护我们的眼睛。防近视护眼台灯什么牌子好?那我们怎么选择一个优秀的护眼台灯也是很重要,才能起到最大的护眼效果。下面五款防近视效果好的护眼台灯推荐: 一:六个推荐防近视效果好的护眼台灯的

Unity Post Process Unity后处理学习日志

Unity Post Process Unity后处理学习日志 在现代游戏开发中,后处理(Post Processing)技术已经成为提升游戏画面质量的关键工具。Unity的后处理栈(Post Processing Stack)是一个强大的插件,它允许开发者为游戏场景添加各种视觉效果,如景深、色彩校正、辉光、模糊等。这些效果不仅能够增强游戏的视觉吸引力,还能帮助传达特定的情感和氛围。 文档

【Godot4.3】多边形的斜线填充效果基础实现

概述 图案(Pattern)填充是一个非常常见的效果。其中又以斜线填充最为简单。本篇就探讨在Godot4.3中如何使用Geometry2D和CanvasItem的绘图函数实现斜线填充效果。 基础思路 Geometry2D类提供了多边形和多边形以及多边形与折线的布尔运算。按照自然的思路,多边形的斜线填充应该属于“多边形与折线的布尔运算”范畴。 第一个问题是如何获得斜线,这条斜线应该满足什么样