Unity 引擎做残影效果——1、BakeMesh

2023-10-28 07:40

本文主要是介绍Unity 引擎做残影效果——1、BakeMesh,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Unity实现残影效果

  大家好,我是阿赵。
  这次来分享一下在Unity里面做残影的效果。
  所谓的残影,就是在角色移动的过程中,留下一串残留的影子。
在这里插入图片描述
在这里插入图片描述

  这种效果比较常出现在格斗游戏和动作游戏。
  在Unity里面做残影,方法很多。我这里将会介绍三种方法:
1、BakeMesh
2、屏幕后处理
3、顶点偏移。
  这一篇先介绍最常见的BakeMesh方法。

一、原理

  用BakeMesh来实现残影,实际上是通过SkinnedMeshRenderer.BakeMesh方法实现的。
  这个方法的作用,是在调用的时候,把蒙皮的网格当前帧的网格情况复制出来,变成一个新的网格模型。
在这里插入图片描述
在这里插入图片描述

  实际上,这种方法做残影,是真的在场景里面生成了很多个物体,每个物体代表了某一帧的角色的网格模型。
  至于想复制出来的模型是什么效果,就自己选择一种材质球附上去就行了。比如你想要红色半透明的,或者边缘光半透明之类,都可以。

二、优缺点

1、优点

  这种方法的优点是效果还不错,通过控制复制网格的频率,就可以做出很细腻的残影效果。
  然后这种方法的实现难度非常低,你知道了SkinnedMeshRenderer.BakeMesh方法,在适当的时候调用,获得一个Mesh,并且塞到一个MeshFilter上面,加一个材质球,就可以显示出来。基本上不涉及到什么难的计算。

2、缺点

  缺点是显而易见的,首先是复制很多个Mesh出来,增加了内存的使用和GC回收的频率。然后是一个模型的网格渲染了很多次,渲染性能不是很好。
  如果同屏幕多个角色使用这种方式做残影,那么渲染压力是极端的增大。
  所以这种方法如果要使用,也要多考虑一下,比如只能主角使用,并且生成残影的数量可能要做一下控制。

三、代码

  这种方式,只需要写C#代码就行。然后生成的残影需要定时删除自己,或者自己建立一个对象池都可以。由于要做透明度渐变,所以附加在复制出来的MeshRender上的材质球,要么每个Render一个材质球,要么用SetPropertyBlock去设置每个材质球不同的透明度。
  我这里只是一个demo,所以写得不是很严谨,只是表达一下过程了:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;public class MoveBakeMesh : MonoBehaviour
{public bool isMove = false;public SkinnedMeshRenderer[] skinList;public int spaceTime = 5;public int countTime = 0;public Material bakeMat;private Vector3 oldPos;// Start is called before the first frame updatevoid Start(){skinList = this.gameObject.GetComponentsInChildren<SkinnedMeshRenderer>();}// Update is called once per framevoid Update(){countTime++;if(countTime%spaceTime == 0){BakeFun();}}private void BakeFun(){if(Vector3.Distance(this.gameObject.transform.position,oldPos)>0){oldPos = this.gameObject.transform.position;for (int i = 0; i < skinList.Length; i++){Mesh mesh = new Mesh();skinList[i].BakeMesh(mesh);GameObject go = new GameObject();MeshFilter mf = go.AddComponent<MeshFilter>();mf.mesh = mesh;MeshRenderer mr = go.AddComponent<MeshRenderer>();mr.material = new Material(bakeMat.shader);go.transform.position = this.transform.position;go.transform.rotation = Quaternion.Euler(-90, 0, 0);DelayDetele dd = go.AddComponent<DelayDetele>();dd.mat = mr.material;}}}
}
using System.Collections;
using System.Collections.Generic;
using UnityEngine;public class DelayDetele : MonoBehaviour
{public float delTime = 0.8f;public float delSpeed = 1;public Material mat;// Start is called before the first frame updatevoid Start(){}// Update is called once per framevoid Update(){delTime -= Time.deltaTime * delSpeed;if(mat){mat.SetColor("_Color", new Color(1f, 0.2f, 0, delTime / 4));}if(delTime <=0){GameObject.Destroy(this.gameObject);}}
}

这篇关于Unity 引擎做残影效果——1、BakeMesh的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

MySQL 存储引擎 MyISAM详解(最新推荐)

《MySQL存储引擎MyISAM详解(最新推荐)》使用MyISAM存储引擎的表占用空间很小,但是由于使用表级锁定,所以限制了读/写操作的性能,通常用于中小型的Web应用和数据仓库配置中的只读或主要... 目录mysql 5.5 之前默认的存储引擎️‍一、MyISAM 存储引擎的特性️‍二、MyISAM 的主

Kotlin Compose Button 实现长按监听并实现动画效果(完整代码)

《KotlinComposeButton实现长按监听并实现动画效果(完整代码)》想要实现长按按钮开始录音,松开发送的功能,因此为了实现这些功能就需要自己写一个Button来解决问题,下面小编给大... 目录Button 实现原理1. Surface 的作用(关键)2. InteractionSource3.

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动

Java实现图片淡入淡出效果

《Java实现图片淡入淡出效果》在现代图形用户界面和游戏开发中,**图片淡入淡出(FadeIn/Out)**是一种常见且实用的视觉过渡效果,它可以用于启动画面、场景切换、轮播图、提示框弹出等场景,通过... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U