Unity UGUI - 六大基础组件

        目录

一、Canvas上

1. Canvas:复制渲染子UI控件

2. ✨Canvas Scaler✨:画布分辨率自适应

3. Graphics Raycaster:射线事件响应

4. ✨Rect Transform✨:UI位置锚点对齐

二、Event System上

5. Event System

6. Standalone Input Module


一、Canvas上

1. Canvas:复制渲染子UI控件

        
(1)当场景中有多个画布时,可以设置Sort Order来控制图层,越大越上层       

(2)3种渲染方式:
          ① Screen Space - Overlay覆盖模式,UI始终显示在最上层 [default]
          ② Screen Space - Camera摄像机模式,物体可以显示在UI之前。
        该模式关联的摄像机最好不要用主摄像机,因为当游戏物体和UI物体用同一个摄像机渲染时,它们的前后关系不好单独控制。
        所以建议是专门创建一个摄像机来渲染UI,将其Culling Mask改为只渲染UI,且主摄像机就不要渲染UI层了;此时因为它们都会渲染到背景or天空盒,所以无论怎么修改sort order都会一个画面挡住另一个画面,所以还需要将相机的Clear Flag改为Depth only,只渲染自己层相关的东西。
        但是在实际使用中,需要在UI前显示的游戏物体还是少数,所以可以进行单独处理,将需要的物体直接创建在Canvas下,然后将其层级改为UI,通过控制z值来控制其显示在UI的前面还是后面。
          ③ World Space3D模式,可以把UI当作3d物体一样处理,一般VR这类项目会使用

       

2. ✨Canvas Scaler✨:画布分辨率自适应

        
        只负责UI大小自适应,而位置自适应是由Rect Transform做的。
        核心公式:Canvas的宽高 * 缩放系数Scale = 屏幕分辨率

        3种缩放模式:
         (1) Constant Pixel Size (恒定像素模式):无论如何,UI保持相同像素大小
               有些UI组件有 Set Native Size 的按钮,用来恢复其原始尺寸
               原始尺寸 = 图片原像素 / (Pixels Per Unit / Reference Pixels Per Unit)

               一般不会使用这个模式,除非通过代码 修改缩放系数 来做自适应。

          (2) Scale With Screen Size [最常用](缩放模式):UI随屏幕尺寸缩放,有参考分辨率
               3种匹配方式:
               ① Match Width Or Height:以宽高的某种比例作为参考来缩放。
                                    一般,竖屏游戏match=0(width);横屏游戏match=1(height)
               Expand:拓展画布Canvas的方式,可能有黑边
               Shrink:裁剪画布Canvas的方式,可能会裁剪

          (3) Constant Physical Size (恒定物理模式):无论如何,UI保持相同物理大小
 

3. Graphics Raycaster:射线事件响应

        
        通过射线检测来判断玩家是否点击到了UI元素。

        这里下面两个属性能设置在摄像机/3D模式下,UI的点击是否会被游戏物体阻挡的。在默认状态下,blocking objects设为none,也就是说游戏物体碰撞器的存在是不会影响射线检测的。所以可以通过这个属性值的设置来修改游戏物体的2D/3D碰撞器是否影响射线检测。
 

4. ✨Rect Transform✨:UI位置锚点对齐

        继承于Transform组件 [位置、角度、缩放] ,在其基础上添加了pivot 中(轴)心点、anchors 锚点 [基于父组件] 等属性。

  • 中心点的作用:
    a. 作为旋转的中心;
    b.物体宽高变化时影响延伸方向;
    c.用其与锚点的距离来记录物体的位置。当锚点为一个点时【位置自适应】(更常见),控件的位置属性是posXYZ,此时是以锚点为原点计算中心点位置;当锚点为一个面时【大小自适应】,位置属性会变为上下左右,记录的是物体边缘与锚点的距离。

  • 快捷键:
    左键单点的话可以快速设置锚点,而如果一起按着shift和alt点击的话能直接将物体移动到吸附位置。


二、Event System上

5. Event System

6. Standalone Input Module

两者都是用来 监听玩家输入事件并分发给各UI控件的,一般不会对它们作修改,但是不能删掉,如果发现UI点击全都无法响应了可以检查是否被误删了。
运行时可以利用下方的小窗口帮助调式

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

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

相关文章

基于Springboot的网上订餐系统 【源码】+【PPT】+【开题报告】+【论文】

网上订餐系统是一个基于Java语言和Spring Boot框架开发的Web应用,旨在为用户和管理员提供一个便捷的订餐平台。该系统通过简化餐饮订购和管理流程,为用户提供快速、高效的在线订餐体验,同时也为管理员提供完善的后台管理功能,帮助…

css 实现闪烁光标

要实现闪烁光标&#xff08;比如文本输入框内常见的闪烁效果&#xff09;&#xff0c;可以使用 CSS 动画。下面是一个简单的方法&#xff1a; 代码示例 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta n…

从JVM底层揭开Java方法重载与重写的面纱:原理、区别与高频面试题突破

&#x1f31f;引言&#xff1a;一场由方法调用引发的"血案" 2018年&#xff0c;某电商平台在"双十一"大促期间遭遇严重系统故障。 技术团队排查发现&#xff0c;问题根源竟是一个继承体系中的方法重写未被正确处理&#xff0c;导致订单金额计算出现指数级…

详解Spark executor

在 Apache Spark 中&#xff0c;Executor&#xff08;执行器&#xff09; 是运行在集群工作节点&#xff08;Worker Node&#xff09;上的进程&#xff0c;负责执行具体的计算任务并管理数据。它是 Spark 分布式计算的核心组件之一&#xff0c;直接决定了任务的并行度和资源利用…

适配器模式及其典型应用

引言 适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许不兼容的接口协同工作。适配器模式通过创建一个适配器类来转换一个类的接口&#xff0c;使其能够与另一个类的接口兼容。这种模式在实际开发中非常有用&#xff0c;特别是在需要…

如何在 Vue 项目中使用v - for指令进行列表渲染,如何优化其性能?

大白话如何在 Vue 项目中使用v - for指令进行列表渲染&#xff0c;如何优化其性能&#xff1f; 在Vue项目里&#xff0c;咱们常常会碰到要把一组数据渲染成列表的状况。这时候&#xff0c;v-for指令就派上大用场啦&#xff01;它能让咱们轻松地把数据数组里的每个元素渲染成对…

qt QQuaternion详解

1. 概述 QQuaternion 是 Qt 中用于表示三维空间中旋转的四元数类。它包含一个标量部分和一个三维向量部分&#xff0c;可以用来表示旋转操作。四元数在计算机图形学中广泛用于平滑的旋转和插值。 2. 重要方法 默认构造函数 QQuaternion::QQuaternion(); // 构造单位四元数 (1…

如何将爬取的评论数据存储到数据库?

在使用Python爬虫获取1688商品评论后&#xff0c;将这些数据存储到数据库中是一个常见的需求。这样可以方便后续的数据分析、查询和管理。本文将详细介绍如何将爬取的评论数据存储到数据库中&#xff0c;包括MySQL和SQLite两种常见的数据库。 一、准备工作 1. 安装必要的Pytho…

Maven中为什么有些依赖不用引入版本号

先给出一个例子&#xff1a; <parent><artifactId>sky-take-out</artifactId><groupId>com.sky</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>sky-s…

Nginx相关漏洞解析

一、CRLF注入漏洞 原理&#xff1a;Nginx将传入的url进行解码&#xff0c;对其中的%0a%0d替换成换行符&#xff0c;导致后面的数据注入至头部&#xff0c;造成CRLF 注入漏洞 1、开环境 2、访问网站&#xff0c;并抓包 3、构造请求头 %0ASet-cookie:JSPSESSID%3D1 这样就可以…

RUBY报告系统

我们常用GFP及其变体如RFP、YFP、mCherry等作为基因表达的报告蛋白——需要荧光显微镜制片观察&#xff1b;此外还有GUS或荧光素酶作为报告酶——需要添加底物。 RUBY报告系统则与众不同&#xff0c;其作用原理是&#xff1a;将酪氨酸转化为鲜艳的红色甜菜碱&#xff0c;无需使…

[力扣每日一练]关于MySQL和pandas的正则表达式应用

一&#xff1a;题目要求 表&#xff1a;Users-------------------------- | Column Name | Type | -------------------------- | user_id | int | | email | varchar | -------------------------- (user_id) 是这张表的唯一主键。 每一行包含用…

office_word中使用宏以及DeepSeek

前言 Word中可以利用DeepSeek来生成各种宏&#xff0c;从而生成我们需要各种数据和图表&#xff0c;这样可以大大减少我们手工的操作。 1、Office的版本 采用的是微软的office2016&#xff0c;如下图&#xff1a; 2、新建一个Word文档 3、开启开发工具 这样菜单中的“开发工具…

深度学习框架PyTorch——从入门到精通(10)PyTorch张量简介

这部分是 PyTorch介绍——YouTube系列的内容&#xff0c;每一节都对应一个youtube视频。&#xff08;可能跟之前的有一定的重复&#xff09; 创建张量随机张量和种子张量形状张量数据类型 使用PyTorch张量进行数学与逻辑运算简单介绍——张量广播关于张量更多的数学操作原地修改…

Oracle 10G DG 修复从库-磁盘空间爆满导致从库无法工作

一、背景 由于近期在做应用升级和系统改造&#xff0c;导致几天没怎么观察DG库的状态。这几天归档日志暴涨导致磁盘空间用尽&#xff0c;从库无法接收主库的归档日志&#xff0c;且从库无法工作。经过检查&#xff0c;发现从库所需要的日志在主库均存在。所以当前文档使用归档…

【踩坑系列】使用httpclient调用第三方接口返回javax.net.ssl.SSLHandshakeException异常

1. 踩坑经历 最近做了个需求&#xff0c;需要调用第三方接口获取数据&#xff0c;在联调时一直失败&#xff0c;代码抛出javax.net.ssl.SSLHandshakeException异常&#xff0c; 具体错误信息如下所示&#xff1a; javax.net.ssl.SSLHandshakeException: sun.security.validat…

算法基础——模拟

目录 1 多项式输出 2.蛇形方阵 3.字符串的展开 模拟&#xff0c;顾名思义&#xff0c;就是题⽬让你做什么你就做什么&#xff0c;考察的是将思路转化成代码的代码能⼒。这类题⼀般较为简单&#xff0c;属于竞赛⾥⾯的签到题&#xff08;但是&#xff0c;万事⽆绝对&#xff…

PrimeTime生成.lib竟暗藏PG添加Bug

在primeTime里生成lib&#xff0c;如何能带上相关的pg信息&#xff1f; 这是一位群友的发问&#xff0c;就这个问题总结了下可能的原因和解决步骤&#xff1a; 概念 PrimeTime是Synopsys的静态时序分析工具&#xff0c;通常用于在设计的各个阶段进行时序验证。 1&#xff09…

yolo系列算法最新进展

YOLO&#xff08;You Only Look Once&#xff09;系列算法作为目标检测领域的代表性模型&#xff0c;自2016年推出以来不断迭代&#xff0c;在速度与精度之间寻求平衡。截至2024年&#xff0c;其最新进展主要集中在以下几个方面&#xff1a; ‌1. YOLOv8 的优化与扩展‌ ‌官方…

动态规划:路径类dp

路径类dp 1.矩阵的最小路径和_牛客题霸_牛客网 #include<iostream> #include<cstring> using namespace std;const int N 510; int f[N][N]; int n, m;int main() {cin >> n >> m;memset(f, 0x3f3f3f, sizeof(f));f[0][1] 0;for (int i 1; i < …