当前位置: 首页 > article >正文

Unity3D仿星露谷物语开发52之菜单页面

1、目标

创建菜单页面,可通过Esc键开启或关闭。

当把鼠标悬停在上面时它会高亮,然后当点击按钮时标签页会被选择。

2、 创建PauseMenuCanvas

(1)创建Canvas

在Hierarchy -> PersistentScene -> UI下创建新的Cavans命名为PauseMenuCanvas(右击 -> UI -> Canvas)。

配置组件的参数如下:

(2)创建BlackBackground

接下来创建黑色背景:

在PauseMenuCanvas下创建Image对象,重命名为BlackBackground:

Anchor Presets设置为:按住Shift + Alt,选择如下:

其他设置如下:

(3)创建PauseMenuPanel

接下来创建菜单的面板。

在PauseMenuCanvas下创建Image命名为PauseMenuPanel,其组件设置如下:

其中Anchor Presents还是Shift + Alt选择stretch + stretch。

(4)创建功能标签对象

接下来创建功能标签对象,这些对象当我们在不同类型之间切换时它们会被激活,我们会创建7种功能标签。

在PauseMenuPanel下创建新物体命名为Tab0InventoryManagement,仅设置Anchor Presents为Shift + Alt的Stretch + stretch。

复制Tab0InventoryManagement,分别创建Tab1 ~ Tab6。

然后再设置Tab1 ~ Tab6为非激活状态。

(5)创建SelectionTabImagesPanel

接下来创建标签选项按钮。

在PauseMenuPanel下创建新的Panel命名为SelectionTabImagesPanel,删除已有的组件(只保留Transform组件),其他配置如下:

在SelectionTabImagesPanel下创建Image命名为SelectionTabImage,组件配置如下:

然后复制6份如下:

(6)创建SelectionTabButtonsPanel

在PauseMenuPanel下创建新的Panel命名为SelectionTabButtonsPanel,删除已有的组件(只保留Transform组件),其他配置如下:

在SelectionTabButtonsPanel下创建Image命名为SelectionButton,组件配置如下:

给SelectionButton添加UI -> Text(Text Mesh Pro),其组件设置如下:

SelectionButton复制6份如下:

除了保留第一个的文本内容,删除其他button的文本内容:

3、创建UIManager.cs脚本 

在Assets/Scripts/UI下创建新脚本命名为UIManager.cs。

using System.Collections;
using System.Collections.Generic;
using Unity.VisualScripting;
using UnityEngine;
using UnityEngine.UI;public class UIManager : SingletonMonobehaviour<UIManager>
{private bool _pauseMenuOn = false;[SerializeField] private GameObject pauseMenu = null;[SerializeField] private GameObject[] menuTabs = null;[SerializeField] private Button[] menuButtons = null;public bool PauseMenuOn { get => _pauseMenuOn; set => _pauseMenuOn = value; }private void Awake(){base.Awake();pauseMenu.SetActive(false);}// Update is called once per frameprivate void Update(){PauseMenu();}private void PauseMenu(){// Toggle pause menu if escape is pressedif(Input.GetKeyDown(KeyCode.Escape)){if (PauseMenuOn){DisablePauseMenu();}else{EnablePauseMenu();}}}private void EnablePauseMenu(){PauseMenuOn = true;Player.Instance.PlayerInputIsDisabled = true;Time.timeScale = 0;pauseMenu.SetActive(true);// Trigger garbage collector// 当暂停游戏时,抓住机会触发系统垃圾收集System.GC.Collect();// Highlight selected buttonHighlightButtonForSelectedTab();}private void DisablePauseMenu(){PauseMenuOn = false;Player.Instance.PlayerInputIsDisabled = false;Time.timeScale = 1;pauseMenu.SetActive(false);}private void HighlightButtonForSelectedTab(){for(int i = 0; i < menuTabs.Length; i++){if (menuTabs[i].activeSelf){SetButtonColorToActive(menuButtons[i]);}else{SetButtonColorToInactive(menuButtons[i]);}}}private void SetButtonColorToActive(Button button){ColorBlock colors = button.colors;colors.normalColor = colors.pressedColor;button.colors = colors;}private void SetButtonColorToInactive(Button button){ColorBlock colors = button.colors;colors.normalColor = colors.disabledColor;button.colors = colors;}// 该函数放在SelectionButton的onClick事件中private void SwitchPauseMenuTab(int tabNum){for(int i = 0; i < menuTabs.Length; i++){if(i != tabNum){menuTabs[i].SetActive(false);}else{menuTabs[i].SetActive(true);}}HighlightButtonForSelectedTab();}}

4、配置UI对象

给UI对象添加UIManger组件,其他配置如下:

配置SelectionButton对象:

第1个SelectionButton的入参刚好是0,对于第2个SelectionButton(1),其配置如下:

依次配置其他SelectionButton

5、运行游戏

游戏过程中,按Esc键可以进入菜单界面。

相关文章:

Unity3D仿星露谷物语开发52之菜单页面

1、目标 创建菜单页面&#xff0c;可通过Esc键开启或关闭。 当把鼠标悬停在上面时它会高亮&#xff0c;然后当点击按钮时标签页会被选择。 2、 创建PauseMenuCanvas &#xff08;1&#xff09;创建Canvas 在Hierarchy -> PersistentScene -> UI下创建新的Cavans命名为…...

待定事项之存储数据

#### 部署云服务器 ![alt text](./img/屏幕截图%202025-05-18%20132353.png) ### 部署云服务器完整步骤 1. **连接到云服务器** bash ssh root<服务器IP> 2. **创建项目目录结构** bash mkdir -p /var/www/three/study/待办事项 3. **克隆项目仓库** bash cd /var/www…...

电脑装的数据越多,会不会越重

在这个数字化飞速发展的时代&#xff0c;有一个看似荒诞却又引人深思的问题&#xff1a;电脑装的数据越多&#xff0c;会不会越重&#xff1f; 先来说说大家的普遍认知&#xff0c;我们通常认为数据只是一些虚拟的代码和信息&#xff0c;存放在电脑的硬盘或其他存储设备中&…...

君正Ingenic webRTC P2P库libyangpeerconnection7编程指南

概述 libyangpeerconnection7是一个实现P2P媒体传输/数据通道的一个轻量级的webRTC库&#xff0c;基于metaRTC7.0的传输模块构建&#xff0c;支持H264/H265视频编码&#xff0c;通过 P2P 连接为用户提供高效、低延迟的音视频和数据通信。 君正版libyangpeerconnection7可适用…...

MySQL——复合查询表的内外连

目录 复合查询 回顾基本查询 多表查询 自连接 子查询 where 字句中使用子查询 单行子查询 多行子查询 多列子查询 from 字句中使用子查询 合并查询 实战OJ 查找所有员工入职时候的薪水情况 获取所有非manager的员工emp_no 获取所有员工当前的manager 表的内外…...

小米玄戒O1架构深度解析(一):十核异构设计与缓存层次详解

前言 这两天&#xff0c;小米的全新SOC玄戒O1横空出世&#xff0c;引发了科技数码圈的一次小地震&#xff0c;那么小米的这颗所谓的自研SOC&#xff0c;内部究竟有着什么不为人知的秘密呢&#xff1f;我们一起一探究竟。 目录 前言1 架构总览1.1 基本构成1.2 SLC缺席的原因探…...

Numba模块的用法(高性能计算)

文章目录 介绍核心装饰器与基础用法@jit(nopython=True):最常用的编译装饰器@njit的简写编译时指定类型签名并行加速(parallel=True)@cuda.jit: GPU 编程(CUDA)向量化函数(@vectorize)性能优化技巧调试与常见问题调试模式常见错误适用场景与局限性实例:加速蒙特卡洛模拟…...

Kafka自定义分区策略实战避坑指南

文章目录 概要代码示例小结 概要 kafka生产者发送消息默认根据总分区数和设置的key计算哈希取余数&#xff0c;key不变就默认存放在一个分区&#xff0c;没有key则随机数分区&#xff0c;明显默认的是最不好用的&#xff0c;那kafka也提供了一个轮询分区策略&#xff0c;我自己…...

PyTorch中cdist和sum函数使用示例详解

以下是PyTorch中cdist与sum函数的联合使用详解: 1. cdist函数解析 功能:计算两个张量间的成对距离矩阵 输入格式: X1:形状为(B, P, M)的张量X2:形状为(B, R, M)的张量p:距离类型(默认2表示欧式距离)输出:形状为(B, P, R)的距离矩阵,其中元素 d i j d_{ij} dij​表示…...

[免费]微信小程序宠物医院管理系统(uni-app+SpringBoot后端+Vue管理端)【论文+源码+SQL脚本】

大家好&#xff0c;我是java1234_小锋老师&#xff0c;看到一个不错的微信小程序宠物医院管理系统(uni-appSpringBoot后端Vue管理端)&#xff0c;分享下哈。 项目视频演示 【免费】微信小程序宠物医院管理系统(uni-appSpringBoot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibi…...

centos7.9使用docker-compose安装kafka

docker-compose配置文件 services:zookeeper:image: confluentinc/cp-zookeeper:7.0.1hostname: zookeepercontainer_name: zookeeperports:- "2181:2181"environment:ZOOKEEPER_CLIENT_PORT: 2181ZOOKEEPER_TICK_TIME: 2000kafka:image: confluentinc/cp-kafka:7.0…...

ETL 工具与数据中台的关系与区别

ETL 工具和数据中台作为数据处理领域的关键概念&#xff0c;虽然存在一定的关联&#xff0c;但二者有着明显的区别。本文将深入剖析 ETL 工具与数据中台之不同。 一、ETL 工具概述 ETL 是数据仓库技术中的核心技术之一&#xff0c;其全称为 Extract&#xff08;抽取&#xff…...

SQLMesh Typed Macros:让SQL宏更强大、更安全、更易维护

在SQL开发中&#xff0c;宏&#xff08;Macros&#xff09;是一种强大的工具&#xff0c;可以封装重复逻辑&#xff0c;提高代码复用性。然而&#xff0c;传统的SQL宏往往缺乏类型安全&#xff0c;容易导致运行时错误&#xff0c;且难以维护。SQLMesh 引入了 Typed Macros&…...

DeepSpeed-Ulysses:支持极长序列 Transformer 模型训练的系统优化方法

DeepSpeed-Ulysses&#xff1a;支持极长序列 Transformer 模型训练的系统优化方法 flyfish 名字 Ulysses “Ulysses” 和 “奥德修斯&#xff08;Odysseus&#xff09;” 指的是同一人物&#xff0c;“Ulysses” 是 “Odysseus” 的拉丁化版本 《尤利西斯》&#xff08;詹姆…...

Docker 使用镜像[SpringBoot之Docker实战系列] - 第537篇

历史文章&#xff08;文章累计530&#xff09; 《国内最全的Spring Boot系列之一》 《国内最全的Spring Boot系列之二》 《国内最全的Spring Boot系列之三》 《国内最全的Spring Boot系列之四》 《国内最全的Spring Boot系列之五》 《国内最全的Spring Boot系列之六》 《…...

解锁MCP:AI大模型的万能工具箱

摘要&#xff1a;MCP&#xff08;Model Context Protocol&#xff0c;模型上下文协议&#xff09;是由Anthropic开源发布的一项技术&#xff0c;旨在作为AI大模型与外部数据和工具之间沟通的“通用语言”。它通过标准化协议&#xff0c;让大模型能够自动调用外部工具完成任务&a…...

Error in beforeDestroy hook: “Error: [ElementForm]unpected width “

使用 element 的 form 时候报错&#xff1a; vue.runtime.esm.js:3065 Error: [ElementForm]unpected width at VueComponent.getLabelWidthIndex (element-ui.common.js:23268:1) at VueComponent.deregisterLabelWidth (element-ui.common.js:23281:1) at Vue…...

vscode包含工程文件路径

在 VSCode 中配置 includePath 以自动识别并包含上层目录及其所有子文件夹&#xff0c;需结合通配符和相对/绝对路径实现。以下是具体操作步骤及原理说明&#xff1a; 1. 使用通配符 ** 递归包含所有子目录 在 c_cpp_properties.json 的 includePath 中&#xff0c;${workspac…...

私有知识库 Coco AI 实战(七):摄入本地 PDF 文件

是否有些本地文件要检索&#xff1f;没问题。我们先对 PDF 类的文件进行处理&#xff0c;其他的文件往后稍。 Coco Server Token 创建一个 token 备用。 PDF_Reader 直接写个 python 程序解析 PDF 内容&#xff0c;上传到 Coco Server 就行了。还记得以前都是直接写入 Coco …...

GitLab 18.0 正式发布,15.0 将不再受技术支持,须升级【二】

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料&#xff1a; 极狐GitLab 官网极狐…...

NtfsLookupAttributeByName函数分析之和Scb->AttributeName的关系

第一部分&#xff1a; VOID FindFirstIndexEntry ( IN PIRP_CONTEXT IrpContext, IN PSCB Scb, IN PVOID Value, IN OUT PINDEX_CONTEXT IndexContext ) { 。。。。。。 // // Lookup the attribute record from the Scb. // if (!NtfsLookupAt…...

STM32H7系列USART驱动区别解析 stm32h7xx_hal_usart.c与stm32h7xx_ll_usart.c的区别?

在STM32H7系列中&#xff0c;stm32h7xx_hal_usart.c和stm32h7xx_ll_usart.c是ST提供的两种不同层次的USART驱动程序&#xff0c;主要区别在于设计理念、抽象层次和使用场景&#xff1a; 1. HAL库&#xff08;Hardware Abstraction Layer&#xff09; 文件&#xff1a;stm32h7x…...

网络原理 | TCP与UDP协议的区别以及回显服务器的实现

目录 TCP与UDP协议的区别 基于 UDP 协议实现回显服务器 UDP Socket 编程常用 Api UDP 服务器 UDP 客户端 基于 TCP 协议实现回显服务器 TCP Socket 编程常用 Api TCP 服务器 TCP 客户端 TCP 服务端常见的 bug 客户端发送数据后&#xff0c;没有响应 服务器仅支持…...

IP动态伪装开关

IP动态伪装开关 在OpenWrt系统中&#xff0c;IP动态伪装&#xff08;IP Masquerading&#xff09;是一种网络地址转换&#xff08;NAT&#xff09;技术&#xff0c;用于在私有网络和公共网络之间转换IP地址。它通常用于允许多个设备共享单个公共IP地址访问互联网。以下是关于O…...

【Unity3D】将自动生成的脚本包含到C#工程文件中

我们知道&#xff0c;在用C#开发中&#xff0c;通过vs编辑器新建的脚本&#xff0c;会自动包含到vs工程中&#xff0c;而通过外部创建&#xff0c;比如复制别的工程或代码创建的C#脚本不会包含到vs工程。 在我们的日常开发中&#xff0c;通常会自动创建C#脚本&#xff0c;特别…...

解决leetcode第3509题.最大化交错和为K的子序列乘积

3509.最大化交错和为K的子序列乘积 难度&#xff1a;困难 问题描述&#xff1a; 给你一个整数数组nums和两个整数k与limit&#xff0c;你的任务是找到一个非空的子序列&#xff0c;满足以下条件&#xff1a; 它的交错和等于k。 在乘积不超过limit的前提下&#xff0c;最大…...

【Python 深度学习】1D~3D iou计算

一维iou 二维 import numpy as npdef iou_1d(set_a, set_b):# 获得集合A和B的边界 x1, x2 set_ay1, y2 set_b# 计算交集的上下界low max(x1,y1)high - min(x2, y2)# 计算交集if high - low < 0:inter 0else:inter high - low# 计算并集union (x2 -x1) (y2 - y1) - in…...

java23

1.美化界面 添加背景图片 所以我们添加背景图片要放在后面添加 添加图片边框 绝对路径&#xff1a; 相对(模块)路径&#xff1a; 第一个是绝对路径&#xff0c;第二个是相对路径&#xff0c;但是斜杠的方向不对 总结&#xff1a; 2.图片移动 先实现KeyListener接口&#xf…...

嵌入式工程师常用软件

1、 Git Git 是公司常用的版本管理工具&#xff0c;人人都要会。在线的 git 教程可以参考菜鸟教程&#xff1a; https://www.runoob.com/git/git-tutorial.html 电子书教程请在搜索栏搜索&#xff1a; git Git 教程很多&#xff0c;常用的命令如下&#xff0c;这些命令可…...

LitCTF2025 WEB

星愿信箱 使用的是python&#xff0c;那么大概率是ssti注入 测试{{5*5}} 发现需要包含文字&#xff0c;那么添加文字 可以看到被waf过滤了&#xff0c;直接抓包查看参数上fenjing 可以看到这里是json格式&#xff0c;其实fenjing也是支持json格式的 https://github.com/Marv…...