百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

UI系统之UGUI框架 u3d ui框架

yuyutoo 2024-10-21 12:07 1 浏览 0 评论

RectTransform组件(UI对象位置描点控制组件):

  • RectTransform是继承至Transform;
  • PosX:UI控件的x方向的位置;PosY:UI控件的y方向的位置;PosZ:UI控件的z方向的位置;Width:UI 控件的宽度;Height:UI控件的高度;Left/Top/Right/Bottom:矩形边缘相对于锚点的位置;当前锚点分离时会出现这些内容;
  • Anchors(相对父矩形锚点):Min是矩形锚点范围X和Y的最小值;Max是矩形锚点范围X和Y的最大值;取值在0~1;
  • Pivot:轴心(中心)点,取值范围0~1;
  • Pos(x,y,z):轴心点(中心点)相对锚点的位置;
  • Rotation:围绕轴心点旋转的角度;

Canvas组件(画布组件,主要用于渲染Canvas的子对象UI控件):


Render Mode(UI渲染模式)三种不同方式的UI渲染模式,控制画布中UI控件的不同适配方式。

(1).Screen Space-Overlay(屏幕空间,覆盖模式,UI始终会显示在3D物体之前):

  • Pixel Perfect(像素精度):是否开启无锯齿精度渲染,一般不会使用(性能换效果);
  • Sort Order(渲染顺序队列):排序层编号,用于控制多个Canvas对象的UI渲染顺序;
  • Target Display(目标设备):和摄像机配合使用,一般使用一个设备就可以,根据需求决定;
  • Additional Shader Channels:着色器通道是附加的信息层,决定着色器可以读取那些数据;

(1).Screen Space-Camera(屏幕空间,摄像机模式,3D物体可以渲染在UI之前):

  • Render Camera:用于渲染UI的摄像机(如果不设置将类似于覆盖模式)
  • Plane Distance:UI平面在摄像机前方的距离,相当于整体z轴的感觉;
  • Sorting Layer:所有排序层,通过层级决定渲染顺序;
  • Order in Layer:同一排序层,根据序号决定渲染顺序;

(1).World Space(世界空间,3D模式):

  • Event Camera:用于处理UI事件的摄像机,如果不设置,不能正常处理UI事件,一般用于VR/AR开发,可以跟随玩家移动,空间中UI方式;

Canvas Scaler组件(画布分辨率自适应组件):

UI Scale Mode(UI适配模式):主要负责在不同分辨率下的UI控件大小的自适应,Canvas中的RectTransforms( 宽高*缩放系数=屏幕分辨率 )。

(1).Constant Pixel Size(恒定像素模式):无论屏幕大小如何,UI始终保持相同像素大小

  • Scale Facor: 缩放系数,按此系数缩放画布中的所有UI元素,宽高*缩放系数=屏幕分辨率
  • Reference Pixels Per Unit: 单位参考像素,多少像素对应Unity中的一个单位(默认一个单位为100像素)图片设置中的Pixels Per Unit,会和该参数一起参与计算;
  • UI原始尺寸=图片大小(像素)/(Pixels Per Unit / Reference Pixels Per Unit)
  • Pixels Per Unit:精灵图像素大小;

(2).Scale With Screen Size(缩放模式)常用根据屏幕尺寸进行缩放,随着屏幕尺寸放大缩小

  • Reference Resolution:参考分辨率(屏幕宽高),在该缩放模式下的所有匹配模式都会基于参考分辨率进行自适应计算;
  • Screen Match Mode:屏幕匹配模式,当前屏幕分辨率宽高比不适应参考分辨率时,用于分辨率大小自适应的匹配模式
  • Match Width Or Height:以宽高或者二者的平均值作为参考来缩放画布区域;
  • Expand:水平或者垂直拓展画布区域,会根据宽高比来放大缩小画布,可能会有黑边,最大程度的缩小UI元素,保留UI控件所有细节;
  • Shrink:水平或者垂直裁剪画布区域,会根据宽高比的变化来放大缩小画布,可能会裁剪掉部分,最大程度放大UI元素,填充屏幕;
  • 缩放系数=Mathf.Min(屏幕宽/参考分辨率宽,屏幕高/参考分辨率高)
  • 画布尺寸=屏幕尺寸/缩放系数
  • Match:确定用于计算的宽高匹配值,横屏游戏Match=1;竖屏游戏Match=0

(2).Constant Physical Size(恒定物理模式):无论屏幕大小和分辨率如何,UI元素始终保持相同物理大小

  • DPI(Dots Per Inch,每英寸点数):图像每英寸长度的像素点数;
  • Physical Unit:物理单位,使用的物理单位种类;
  • Fallback Screen DPI:备用DPI,当找不到设备DPI时,使用此值;
  • Default Sprite DPI:默认图片DPI;

Graphic Raycaster(射线事件交互组件,控制UI控件射线相应):

  • Ignore Revered Graphics:是否忽略反转,UI元素发生旋转时,是否还需要进行射线检测;
  • Blocking Objects:射线被那些类型的碰撞器阻挡(在覆盖渲染模式没效果);
  • Blocking Mask:射线被那些层级的碰撞器阻挡(在覆盖渲染模式没效果);

EventSystem组件(玩家输入事件响应系统):

  • First Selected:首先选择的游戏对象,可以设置游戏一开始的默认选择;
  • Send Navigation Events:是否允许UI导航事件(移动/按下/取消);
  • Drag Threshold:拖拽操作的阈值(移动多少像素算拖拽);

Standalone Input Module组件(玩家独立输入模块组件,监听玩家操作):

  • 独立输入模块,处理鼠标、键盘、控制器、触屏的输入事件通过EventSystem进行分发;
  • Horizontal Axis:水平轴按钮对应的热键名(Input管理器);
  • Vertical Axis:垂直轴按钮对应的热键名;
  • Submit Button:提交(确定)按钮对应的热键名;
  • Cancel Button:取消按钮对应的热键名;
  • Input Actions Per Second:每秒允许键盘/控制器输入的数量;
  • Repeat Delay:每秒输入操作重复率生效前的延迟时间;
  • ForceModule Active:是否强制模块处于激活状态;

相关推荐

mysql数据库如何快速获得库中无主键的表

概述总结一下MySQL数据库查看无主键表的一些sql,一起来看看吧~1、查看表主键信息--查看表主键信息SELECTt.TABLE_NAME,t.CONSTRAINT_TYPE,c.C...

一文读懂MySQL的架构设计

MySQL是一种流行的开源关系型数据库管理系统,它由四个主要组件构成:协议接入层...

MySQL中的存储过程和函数

原文地址:https://dwz.cn/6Ysx1KXs作者:best.lei存储过程和函数简单的说,存储过程就是一条或者多条SQL语句的集合。可以视为批文件,但是其作用不仅仅局限于批处理。本文主要介...

创建数据表:MySQL 中的 CREATE 命令深入探讨

数据库是企业日常运营和业务发展的不可缺少的基石。MySQL是一款优秀的关系型数据库管理系统,它支持数据的插入、修改、查询和删除操作。在数据库中,表是一个关系数据库中用于保存数据的容器,它由表定义、表...

SQL优化——IN和EXISTS谁的效率更高

IN和EXISTS被频繁使用在SQL中,虽然作用是一样的,但是在使用效率谁更高这点上众说纷纭。下面我们就通过一组测试来看,在不同场景下,使用哪个效率更高。...

在MySQL中创建新的数据库,可以使用命令,也可以通过MySQL工作台

摘要:在本教程中,你将学习如何使用MySQLCREATEDATABASE语句在MySQL数据库服务器上创建新数据库。MySQLCREATEDATABASE语句简介...

SQL查找是否"存在",别再用count了

根据某一条件从数据库表中查询『有』与『没有』,只有两种状态,那为什么在写SQL的时候,还要SELECTCOUNT(*)呢?无论是刚入道的程序员新星,还是精湛沙场多年的程序员老白,都是一如既往...

解决Mysql数据库提示innodb表不存在的问题

发现mysql的error.log里面有报错:>InnoDB:Error:Table"mysql"."innodb_table_stats"notfo...

Mysql实战总结&面试20问

1、MySQL索引使用注意事项1.1、索引哪些情况会失效查询条件包含or,可能导致索引失效如果字段类型是字符串,where时一定用引号括起来,否则索引失效...

MySQL创建数据表

数据库有了后,就可以在库里面建各种数据表了。创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性(包括实体完整性、引用完整性和域完整性)约束的过程。后面也是通过SQL语句和Navicat...

MySQL数据库之死锁与解决方案

一、表的死锁产生原因:...

MySQL创建数据库

我的重点还是放在数据表的操作,但第一篇还是先介绍一下数据表的容器数据库的一些操作。主要涉及数据库的创建、修改、删除和查看,下面演示一下用SQL语句创建和用图形工具创建。后面主要使用的工具是Navica...

MySQL中创建触发器需要执行哪些操作?

什么是触发器触发器,就是一种特殊的存储过程。触发器和存储过程一样是一个能够完成特定功能、存储在数据库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段...

《MySQL 入门教程》第 17 篇 MySQL 变量

原文地址:https://blog.csdn.net/horses/article/details/107736801原文作者:不剪发的Tony老师来源平台:CSDN变量是一个拥有名字的对象,可以用于...

关于如何在MySQL中创建表,看这篇文章就差不多了

数据库技术是现代科技领域中至关重要的一部分,而MySQL作为最流行的关系型数据库管理系统之一,在数据存储和管理方面扮演着重要角色。本文将深入探讨MySQL中CREATETABLE语句的应用,以及如何...

取消回复欢迎 发表评论: