UI系统之UGUI框架 u3d ui框架
yuyutoo 2024-10-21 12:07 2 浏览 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:是否强制模块处于激活状态;
相关推荐
- 如何在HTML中使用JavaScript:从基础到高级的全面指南!
-
“这里是云端源想IT,帮你...
- 推荐9个Github上热门的CSS开源框架
-
大家好,我是Echa。...
- 硬核!知网首篇被引过万的论文讲了啥?作者什么来头?
-
整理|袁小华近日,知网首篇被引量破万的中文论文及其作者备受关注。知网中心网站数据显示,截至2021年7月23日,由华南师范大学教授温忠麟等人发表在《心理学报》2004年05期上的学术论文“中介效应检验...
- 为什么我推荐使用JSX开发Vue3_为什么用vue不用jquery
-
在很长的一段时间中,Vue官方都以简单上手作为其推广的重点。这确实给Vue带来了非常大的用户量,尤其是最追求需求开发效率,往往不那么在意工程代码质量的国内中小企业中,Vue占据的份额极速增长...
-
- 【干货】一文详解html和css,前端开发需要哪些技术?
-
网站开发简介...
-
2025-02-20 18:34 yuyutoo
- 分享几个css实用技巧_cssli
-
本篇将介绍几个css小技巧,目录如下:自定义引用标签的符号重置所有标签样式...
- 如何在浏览器中运行 .NET_怎么用浏览器运行代码
-
概述:...
- 前端-干货分享:更牛逼的CSS管理方法-层(CSS Layers)
-
使用CSS最困难的部分之一是处理CSS的权重值,它可以决定到底哪条规则会最终被应用,尤其是如果你想在Bootstrap这样的框架中覆盖其已有样式,更加显得麻烦。不过随着CSS层的引入,这一...
-
- HTML 基础标签库_html标签基本结构
-
HTML标题HTML标题(Heading)是通过-...
-
2025-02-20 18:34 yuyutoo
- 前端css面试20道常见考题_高级前端css面试题
-
1.请解释一下CSS3的flexbox(弹性盒布局模型),以及适用场景?display:flex;在父元素设置,子元素受弹性盒影响,默认排成一行,如果超出一行,按比例压缩flex:1;子元素设置...
- vue引入外部js文件并使用_vue3 引入外部js
-
要在Vue中引入外部的JavaScript文件,可以使用以下几种方法:1.使用``标签引入外部的JavaScript文件。在Vue的HTML模板中,可以直接使用``标签来引入外部的JavaScrip...
- 网页设计得懂css的规范_html+css网页设计
-
在初级的前端工作人员,刚入职的时候,可能在学习前端技术,写代码不是否那么的规范,而在工作中,命名的规范的尤为重要,它直接与你的代码质量挂钩。网上也受很多,但比较杂乱,在加上每年的命名都会发生一变化。...
- Google在Chrome中引入HTML 5.1标记
-
虽然负责制定Web标准的WorldWideWebConsortium(W3C)尚未宣布HTML5正式推荐规格,而Google已经迁移到了HTML5.1。即将发布的Chrome38将引入H...
- HTML DOM 引用( ) 对象_html中如何引用js
-
引用对象引用对象定义了一个同内联元素的HTML引用。标签定义短的引用。元素经常在引用的内容周围添加引号。HTML文档中的每一个标签,都会创建一个引用对象。...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)