『功能项目』销毁怪物蛋的Shaders消融特效【17】

2024-09-04 00:52

本文主要是介绍『功能项目』销毁怪物蛋的Shaders消融特效【17】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本章项目成果展示

我们打开上一篇16主角的信息显示的项目,

本章要做的事情是在怪物消亡时生成一个销毁特效

首先创建一个Unlit Shader

重命名为Dissolve

双击进入脚本后编写脚本:

Shader "Unlit/Dissolve"{Properties{//物体基础材质纹理[Header(Base Texture)][Space(10)][NoScaleOffset]_Albedo("Albedo",2D) = "bump"{}//高光[NoScaleOffset]_Specular("Specular_Smoothness",2D) = "black"{}//法向//"bump"{}表示默认 (0.5,0.5,1)紫色纹理[NoScaleOffset]_Normal("Normal",2D) = "bump"{}//环境光遮蔽[NoScaleOffset]_AO("AO",2D) = "white"{}//消融属性[Header(Dissolve Properties)][Space(10)]//控制消融形状的噪声图_Noise("Dissolve Noise",2D) = "white"{}//控制消融进度_Dissolve("Dissolve",Range(0,1))=0//控制边缘的颜色[NoScaleOffset]_Gradient("Edge Gradient",2D) = "black"{}//控制边缘的范围_Range("Edge Range",Range(2,100))=6//控制边缘的亮度_Brightness("Brightness",Range(0,10))=1}SubShader{Tags{//开启透明测试 丢弃给定数值的像素 下面两个声明一般是一起的//用于透明剪裁的效果"RenderType"="TransparentCutout""Queue"="AlphaTest"}CGPROGRAM//表示使用表面着色器 光照模型为StandardSpecular//addshadow表示不透明的部分也能产生正确的投影//fullforwardshadows表示物体支持所有类型灯光的阴影,默认状态下支支持平行光#pragma surface surf StandardSpecular addshadow fullforwardshadows//Input结构体//'uv_'+'纹理的名称' 用于获取对应纹理的第一套纹理坐标//如果是uv2则时获取第二套 以此类推struct Input {float2 uv_Albedo;float2 uv_Noise;};//上面的Properties中声明的知识为了在编辑器中显示,可有可无sampler2D _Albedo;sampler2D _Specular;sampler2D _Normal;sampler2D _AO;sampler2D _Noise;fixed _Dissolve;sampler2D _Gradient;float _Range;float _Brightness;//Input时上面声明的Input结构体 //SurfaceOutputStandardSpecular表示自带的高光工作流结构体void surf(Input IN, inout SurfaceOutputStandardSpecular o) {//根据噪声图剪辑//tex2D(纹理,纹理坐标)用于获取纹理的颜色信息//.r表示颜色rgba中的r值(用xyzw也是一样的道理)fixed noise = tex2D(_Noise, IN.uv_Noise).r;fixed dissolve = _Dissolve * 2 - 1;//saturate(x)表示将x的范围截取到(0,1)之间fixed mask = saturate(noise - dissolve);//clip(x)如果x小于0 则在最终输出中剔除这个像素clip(mask - 0.5);//边缘燃烧fixed texcoord = saturate(mask * _Range - 0.5 * _Range);o.Emission = tex2D(_Gradient, fixed2(texcoord, 0.5)) * _Brightness;//正常的纹理fixed4 c = tex2D(_Albedo, IN.uv_Albedo);o.Albedo = c.rgb;//高光fixed4 specular = tex2D(_Specular, IN.uv_Albedo);o.Specular = specular.rgb;o.Smoothness = specular.a;//发现与环境光遮蔽o.Normal = UnpackNormal(tex2D(_Normal, IN.uv_Albedo));o.Occlusion = tex2D(_AO, IN.uv_Albedo);}ENDCG}
}

在新建的Shader脚本右键创建一个该Shader的材质Material

将一下资源图片添加至如下

新建脚本:DissolveController

编写脚本:

using UnityEngine;
public class DissolveController : MonoBehaviour{//网格渲染组件MeshRenderer m_MeshRenderer;//测试状态bool isTest = false;//消融参数float dissolve = 0f;//消融速度float dissolveSpeed = 0.3f;void Start(){m_MeshRenderer = GetComponent<MeshRenderer>();isTest = true;}void Update(){//按下空格执行消融测试if (Input.GetKeyDown(KeyCode.Space) && !isTest) {isTest = true;}//通过事件控制材质的消融参数if (isTest) {dissolve += Time.deltaTime * dissolveSpeed;//用SetFloat方法设置材质相应的属性m_MeshRenderer.material.SetFloat("_Dissolve", dissolve);if (dissolve > 1f) {isTest = false;dissolve = 0f;}}}public void DissolveValue(float value){dissolve = value;m_MeshRenderer.material.SetFloat("_Dissolve", dissolve);}
}

(这里有冗余代码,是为了测试以及让其外部类调用溶解效果,也可以在Start()函数里将isTest改为false,运行项目后按空格Space键即可消融)

新建一个球体调至缩放倍数,重命名为MonsterKingDieEffect,并且挂载新建材质以及控制脚本

放进Prefabs的预制体文件夹中

修改脚本:MonsterKing.cs(当怪物King消亡时调用生成一个消融效果)

运行项目 - 怪物消亡时

本篇做了主角的UI信息显示升级的功能,接下来还需做以下内容:

1.怪物死亡掉落物品

2.掉落物品拾取

3.背包道具的转移与穿戴

4.异步传送转换场景

5.目标点巡航功能

6.坐骑模型的召唤与取消

7.乘坐坐骑

以及开放回合制、坐骑系统、宠物系统、背包系统、神炼系统、商城系统、Boss的目标跟随任务导航系统以及UI播放3D动画效果等等。

具体项目运行效果请关注water1024的b站视频项目演示《破碎纪元》

【Unity回合2.5D】破碎纪元_单机游戏热门视频 (bilibili.com)icon-default.png?t=N7T8https://www.bilibili.com/video/BV1rZY4e9Ebs/?spm_id_from=333.999.0.0&vd_source=547091a95b03acfa8e8a9e46ef499cd6

这篇关于『功能项目』销毁怪物蛋的Shaders消融特效【17】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免