Unity利用UGUI RawImage组件制作转场动画

news2025/1/16 0:54:47

Unity利用UGUI RawImage组件制作转场动画

最近接到了一个unity全景图的小项目,由于在不同的场景之间转场时直接转会太过生硬,因此要求有个Alpha转场的动画。于是想到两种可行的方案:

一、UGUI方案

用UGUI显示当前屏幕纹理,然后进行场景切换,切换好之后,在把UGUI隐掉。这种方案适合任何场景的切换。
先看效果:

Unity 利用UGUI制作转场动画的演示

直接上代码:

// 调用这个方法,就可以直接把全景图纹理更换为newTex
public ChangeScene( Texture newTex )
{
	// 暂时关闭玩家控制
	_controller.enable = false;

	// 启动切换协程
	StartCoroutine(StartSceneChange(newTex));
}

// 更换纹理的协程
private IEnumerator StartSceneChange(SceneNode node)
{
    // 这里要等到当前帧渲染完成,否则截屏结果将不正确。
    yield return new WaitForEndOfFrame();

	// 开始截屏,保存当前的屏幕画面到一张纹理中。
    var oldtex = new Texture2D(Screen.Width, Screen.Height, TextureFormat.RGB24, false );
    oldtex.ReadPixels(rectScr, 0, 0);
    oldtex.Apply();

	// 等待UGUI完成渐隐
    yield return Switch(oldtex, newTex);

	// 销毁截屏
    Destroy(oldtex);
}

public IEnumerator Switch(Texture oldTex, Texture newTex)
{
	// 激活UGUI并将截屏显示到RawImage
    rawImage.gameObject.SetActive(true);
    yield return null;
    _rawImage.texture = oldTex;
    rawImageCanvasGroup.alpha = 1;
    yield return null;

	// 更换球体纹理为新的全景图
    _material.SetTexture(GameLogic.mainTex, newTex);
    
    // 渐隐UGUI
    while (_group.alpha > 0.01f)
    {
        _group.alpha -= speed * Time.deltaTime;
        yield return null;
    }

	// 隐藏UGUI
    _rawImage.texture = null;
    rawImageCanvasGroup.alpha = 0;
    rawImage.gameObject.SetActive(false);
}

代码非常容易理解。值得一提的是,Unity截屏的API,其实是有现成的:

ScreenCapture.CaptureScreenshotAsTexture();

但是,这个截屏出来的格式是RGBA格式的,直接贴到RawImage上,会只有UI显示,场景里的东西是透明的。这个解决方案有三:

  1. 格式转换为RGB,但我没有找到Texture有对应的转换API;
  2. 写个shader替换默认的Rawimage材质,不使用A通道。
  3. 我用的方法,不用自带的截屏API,二是自己用ReadPixels来获取。

二、Shader方案

由于全景图的纹理,我是贴到一个球体上的,所以,最直接的方法,就是写Shader,在两种全景纹理下进行切换。这种方案非常适合全景图切换(只是替换两个纹理),但不太适合3d场景转场。
效果:

Unity转场shader效果演示

Shader是用ASE做的,比较简单,连线如下图:
在这里插入图片描述
其实,这里只是描述基本的原理,如果想要做到更多的转场效果,玩法非常的多,第一种方法,用UGUI的,也可以写Shader来实现更多炫酷的效果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/474473.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python处理图像的各种技术镜像、旋转、遮挡、叠加、条带化

2.6 图像镜面对称 1、将图像水平镜面转换。 2、将图像垂直镜面转换。 import random #导入模块 import numpy as np import matplotlib.pyplot as plt a plt.imread("1.jpg") # 将图像沿着水平方向重复三次。 ba.copy() da.copy() # 将图像水平镜面转换。&…

【笔记】cuda大师班1-4

一.基本概念 进程(process)一个正在被执行的计算机程序的实例 上下文(context):待处理数据的集合,允许处理器暂停,保持处理的执行和恢复处理 并发:上下文切换,主要应用于…

AIGC - 生产力新工具 Copilot

文章目录 介绍能干啥IDEA 安装 介绍 https://github.com/features/copilot 能干啥 Copilot的主要功能包括: 代码补全和提示:Copilot会根据上下文,智能提示您可能需要的变量,函数,参数等。快速生成代码:Copilot可以快速生成if语句,for循环,类定义,函数定义等代码模板。代码优…

Unity之OpenXR+XR Interaction Toolkit实现 传送

前言 VR中由于走动比较容易头晕,所以基本上玩家移动都是靠传送,这样用户更加直观,传送过去也不会感觉头晕。 好了,那么我们一起来说实现一下OpenXR的传送功能。 准备 我们新建一个3D(URL)项目&#xff0…

git 撤销add/commit,以及更换源命令

前言:主要是为了自己方便记录,省的每次都查找一下这些命令 1、当我们只是想撤回commit,保留add .的时候,可以用下方代码 git reset --soft HEAD^ 2、当我们想撤回commit以及add .的时候,可以用下方代码 git reset…

Mesh形变算法

前言: 作者正好因为动画、模拟仿真等等的重大需求需要预先研发离散形的模型Mesh的形变算法,并且要验证、研究适用的范围、特别是性能等等,摸着石头过河别喷,毕竟我主要是渲染、动画、引擎的对于计算几何、三维重建不是很熟悉&…

Python小姿势 - Python使用Jupyter Notebook

Python使用Jupyter Notebook Jupyter Notebook是一个开源的Web应用程序,可以用来创建和共享包含 live code,公式,可视化和解释性文本的文档。 安装Jupyter Notebook 首先,确保你安装了正确的Python版本和包管理器(pip&…

(6)elasticsearch的分词器

1 文档规范化(normalization) 是为了提高召回率。 停用词 、时态转换、大小写、同义词、语气词。 以下的doc1\doc2,经过normalization之后,在搜索的时候是可以匹配到这两个doc。 我们可以看到,normalization就是把一…

带你认识什么是BMS(电池管理系统)

文章目录 概述BMS的硬件拓扑BMS的电气架构BMS的功能BMS的总压采集(主板功能)BMS的电流采集(主板功能)BMS的电芯电压和温度采集(从板功能)BMS的SOC、SOP和SOH(ASW计算)BSM的绝缘检测B…

ES6新特性(1)

目录 一、字符串扩展 (1)字符串遍历器接口(for...of...) (2)模板字符串 二、字符串新增方法 (1)包含方法 (2)重复方法 (3)补全方…

MySQL数据库,JDBC连接数据库操作流程详细介绍

前言: 在学完 MySQL 和 Java 后,我们通常会尝试使用 Java编译器 连接 MySQL数据库,从而达到使用编译器来操作数据库的效果。连接的这个过程会用 JDBC 相关知识,因此我把 JDBC 包的下载及导入流程,以及 JDBC 的使用流程…

Arduino驱动L298N控制直流电机的正反转和调速

Arduino驱动L298N控制直流电机的正反转和调速 一、前言二、产品参数三、驱动直流电机三、接线图四、程序五、实验结果总结 一、前言 本模块使用ST公司的L298N作为主驱动芯片,具有驱动能力强,发热量低,抗干扰能力强的特点。LN2&am…

Windows系统自带工具介绍

文章目录 1 Windows系统工具1.1 系统增强工具PowerToys1.1.1 简介1.1.2 使用 1.2 增强版任务管理器 Process Explorer1.2.1 简介1.2.2 使用 1.3 进程监视器 Process Monitor1.3.1 简介1.3.2 使用 1.4 数据恢复神器 Windows File Recovery1.4.1 简介1.4.2 使用 1.5 微软AI识图1.…

Acwing- 835. Trie字符串统计

什么是Trie?Trie是一种高效地存储和查找字符串集合的数据结构。 我想,看下图就明白了 hh~ 在本题中,我们将a-z映射为0-25,然后将其作为数组下标,便于处理。 idx为已使用的节点数量(使用一个节点则idx&…

Go语言——【高质量编程 | 代码规范】

作者:非妃是公主 专栏:《Golang》 博客主页:https://blog.csdn.net/myf_666 个性签:顺境不惰,逆境不馁,以心制境,万事可成。——曾国藩 文章目录 一、高质量编程定义 二、代码规范1. 代码格式…

Scratch资料

Scratch软件是免费的、免费的、免费的。任何需要花钱才能下载Scratch软件的全是骗子。 1、什么是Scratch Scratch是麻省理工学院的“终身幼儿园团队”开发的一种图形化编程工具。是面向青少年的一款模块化,积木化、可视化的编程语言。 什么是模块化、积木化&…

箭牌家居首次亮相AWE展会,大秀智慧生活新提案

作者 | 曾响铃 文 | 响铃说 2023年作为全面贯彻党的二十大精神开局之年,同时也是后疫情时代的第一年,以科技创新驱动社会发展成为当下首要任务。 特别是科技强国战略的实施落地,对推动经济社会高质量发展有着不可或缺的作用。所谓需求产生…

线性表之单链表(详解)

🍕博客主页:️自信不孤单 🍬文章专栏:数据结构与算法 🍚代码仓库:破浪晓梦 🍭欢迎关注:欢迎大家点赞收藏关注 文章目录 🍥前言🍉链表1. 链表的概念及结构2. 链…

肝一肝设计模式【二】-- 工厂模式

系列文章目录 肝一肝设计模式【一】-- 单例模式 传送门 肝一肝设计模式【二】-- 工厂模式 传送门 文章目录 系列文章目录前言一、简单工厂模式二、工厂方法模式三、抽象工厂模式写在最后 前言 在实际开发过程中,构建对象往往使用new的方式来构建,但随着…

Nginx搭建以及使用(linux)

1.概念 Nginx是一个高性能的HTTP和反向代理服务器,它可以用来处理静态文件,负载均衡,反向代理等功能。 Nginx的来历是这样的:它是由俄罗斯人伊戈尔赛索耶夫为Rambler.ru站点开发的,第一个公开版本发布于2004年…