【Unity之FGUI】Fairy GUI面板的创建相关

news2024/11/16 10:17:21

在这里插入图片描述


👨‍💻个人主页:@元宇宙-秩沅

👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅!

👨‍💻 本文由 秩沅 原创
👨‍💻 收录于专栏:就业宝典

🅰️推荐专栏

⭐-软件设计师高频考点大全



文章目录

    • 前言
    • 🪶(==1==)加载UIPanel
      • 😶‍🌫️1.手动创建UIPanel
      • 😶‍🌫️2.代码自动创建UIPanel
    • 🪶(==2==)认识UIPanel
      • 😶‍🌫️1.UIPanel脚本的属性
      • 😶‍🌫️2.认识StageCamera
    • 🪶(==3==)代码动态加载UI资源
      • 😶‍🌫️1. GRoot
      • 😶‍🌫️2.主要步骤
      • 😶‍🌫️3.GComponent(组件)常用API
      • 😶‍🌫️4.选择动态创建UI还是手动创建UIPanel?
    • 🪶(==4==)脚本组件
      • 😶‍🌫️1.UIContentScaler脚本组件
      • 😶‍🌫️2.认识UIConfig
    • 🅰️


前言


🪶(1加载UIPanel


😶‍🌫️1.手动创建UIPanel


  • 在Unity中创建UIPanel

Hierarchy窗口右键一>FairyGUI——>UIPanel
选中创建出的uIPanel 在Inspector窗口中点击PackageName或ComponentName在弹出窗口中选择对应的包和组件点击OK即可
UIPanel只能自动载入放置在Resources目录或其子目录下的UT包

在这里插入图片描述

在这里插入图片描述


😶‍🌫️2.代码自动创建UIPanel


  //首先加载对应的UI包
  UIPackage.AddPackage("UI/Teach");
  //为一个对象想 添加UIPanel组件 设置相关参数即可
  GameObject obj = new GameObject("UIPanel2");
   //将层级改为UI层
  obj.layer = LayerMask.NameToLayer("UI");
  UIPanel panel = obj.AddComponent<UIPanel>();
  //设置关键属性
  panel.packageName = "Teach";
  panel.componentName = "TeachPanel";

  //想要改变别的参数属性
  panel.container.renderMode = RenderMode.ScreenSpaceOverlay;
  panel.container.fairyBatching = true;

  panel.SetSortingOrder(1, true);

  panel.SetHitTestMode(HitTestMode.Default);

  //创建UI
  panel.CreateUI();

🪶(2认识UIPanel


创建UIPanel之后,会生成Stage Camera 和UIPanel

在这里插入图片描述


😶‍🌫️1.UIPanel脚本的属性


  • 获取UIPanel,而后即可获取组件
    GComponent view = uiPanel.ui;
    在这里插入图片描述

  • PackageName——包名

  • Componetn Name——组件名

  • Package Path——引用的组件路径

  • Render Mode ——渲染模式

Screen Space Overlay:UI始终显示在最前面
Screen Space Camera:可以自定义正交摄像机渲染UI
World Space:在世界控件使用UI,用透视相机渲染,默认是主相机
当渲染模式是后两种时,可以自己设置渲染UI的摄像机,默认为场景的主摄像机。
如果是World Space模式,需要设置相机,否则无法点击UI

  • Fairy Batching——FairyGUI的动态批处理开关。
    切换这个值,可以在编辑模式下实时看到DrawCall的变化。开启它后会开启深度调整,即使我们的UI层级没有刻意设置,底层也能帮助我们进行优化

  • Hit Test Mode:——点击测试模式

Default:使用内置机制判断点击和触摸,不使用射线,效率较高
Raycast:使用射线判断,UIPanel会自动创建碰撞体,适用于UIPanel需要和其它3D物体交互时时使用

  • Touch Disabled——将关闭点击检测
    如果UI没有可以交互的内容,可以勾选它提升性能

  • Set Native Children Order——在UIPanel下挂其它3D对象,比如粒子模型

  • UI Transform:——UI位置
    渲染模式为Screen Space时设置UI Transform
    渲染模式为World Space时设置Transform

  • FIt Screen:——UIPanel屏幕适配模式

Fit Size:UI铺满屏幕
Fit Width And Set Middle:UI横向铺满屏幕,上下居中
Fit Height And Set Center:UI纵向铺满屏幕,左右居中

  • SortingOrder:——进行排序

1.当渲染模式为ScreenSpace屏幕空间渲染时

SortingOrder为1000这个值是个特殊值
1000以上UIPanel会显示在2D UI的上面
1000以下都显示在2D UI的下面

2.当渲染模式为WorldSpace世界空间渲染时用世界坐标的Z轴来对UI进行排序

如果想要通过z轴来进行排序 需要将需要通过z轴排序的UIPanel的sortingOrder设置为相同值
然后调用API_ Stage.inst.SortWorldSpacePanelsByZOrder(100);

一般进行UI面板的排序,通过 ScreenSpace进行渲染 然后通过 坐标系转换 来不停的更新UI坐标(降低性能消耗),不用方法二世界坐标的Z轴来对UI进行排序


😶‍🌫️2.认识StageCamera


本质:UI摄像机
在这里插入图片描述

  • Constant Size: 是否使用固定的相机大小,默认true

    为ture时。屏幕放大或缩小,粒子效果也会随着放大和缩小,适用于手机平台

    为false时。屏幕放大或缩小,粒子效果不会随着放大和缩小,使用与PC平台,根据自己游戏面向的平台决定是否勾选


🪶(3代码动态加载UI资源



😶‍🌫️1. GRoot


  • 是动态创建UI时会自动创建的跟对象, 它主要负责适配等工作

1.设置适配(分辨率自适应)API
GRoot.inst.SetContentScaleFactor(1365, 768, UIContentScaler.ScreenMatchMode.MatchHeight);

2.创建好的UI对象添加为它的子对象
GRoot.inst.AddChild()


😶‍🌫️2.主要步骤


  • 1.设置适配相关内容
//设置分辨率(设置一次即可)
 GRoot.inst.SetContentScaleFactor(1365, 768, UIContentScaler.ScreenMatchMode.MatchHeight);
  • 2.加载包
 //创建UI之前 必须加载包
 UIPackage package = UIPackage.AddPackage("UI/package");

  • 3.加载依赖包
 //加载依赖包
 foreach(var item in package.dependencies)
 {
     UIPackage.AddPackage("UI/" + item["name"]);
 }
  • 4.动态创建UI资源

1.同步加载

 //GObject obj = UIPackage.CreateObject("Teach", "TeachPanel");
 //GComponent view = obj.asCom;
 GComponent view = UIPackage.CreateObject("Teach", "TeachPanel").asCom;

//组件加载在GRoot对象下
 GRoot.inst.AddChild(view);

 //销毁UI
 //view.Dispose();

2.异步加载

 UIPackage.CreateObjectAsync("Teach", "TeachPanel", (obj) =>
 {
     GComponent v = obj.asCom;
     GRoot.inst.AddChild(v);
 });

😶‍🌫️3.GComponent(组件)常用API


  • 1.位置
    view.x = 10;
    view.y = 10;
    view.SetPosition(0, 0, 0);
  • 2.宽高
    view.width = 1000;
    view.height = 500;
    view.SetSize(1365, 768);
  • 3.轴心点
    view.pivotX = 0;
    view.pivotY = 0;
    view.SetPivot(0, 0, true);
    view.pivotAsAnchor = false;
  • 4.角度
    view.rotation = 0;
  • 5.可见与否
    view.visible = true;
    6.置灰
    view.grayed = true;
  • 7.缩放
    view.scaleX = 1;
    view.scaleY = 1;
  • 8.排序层
    view.sortingOrder = 1;
  • 9.点击不穿透
    view.opaque = true;
  • 10.子对象数量
    print(view.numChildren);
  • 11.子对象相关
    添加子对象 ——view.AddChild()
    根据名字获取子对象—— view.GetChild(“n1”);
    根据索引获取子对象——view.GetChildAt(0);
    设置对象排序位置——view.SetChildIndex(null, 5);
    设置子对象排序规则

默认,升序,从小到大依次渲染,序号大的显示在前面
view.childrenRenderOrder = ChildrenRenderOrder.Ascent;
降序反之
view.childrenRenderOrder = ChildrenRenderOrder.Descent;
拱形 设置一个顶峰值显示在最前面,两侧的依次渲染
view.childrenRenderOrder = ChildrenRenderOrder.Arch;
view.apexIndex = 5;


😶‍🌫️4.选择动态创建UI还是手动创建UIPanel?


  • 大多数都是选择动态创建,使用代码创建UI,可以应用到传统的设计模式上
    注意:动态创建的UI不要和其它GameObject相关联

  • 小项目可以使用_UIPanel一般用来做3DUI,它可以更加方便的挂载到任意GameObject上
    优点是可以像物体一样直接摆放在场景中,因为随着UI的增多,项目的变大
    管理起来常的麻烦


🪶(4脚本组件



😶‍🌫️1.UIContentScaler脚本组件


  • 不需要每个场景都挂,随便一个对象挂载即可

  • 该组件是用来分辨率自适应的

    也可以不使用UIContentScaler
    通过使用 GRoot.inst.setContentScaleFactor 代码设置 效果完全一致
    在这里插入图片描述

  • Scale Mode:缩放模式

Constant Pixel Size:不进行缩放。UI按1:1呈现
Scale With Screen Size:根据屏幕大小缩放
Constant Physical Size:暂不支持

  • Scale With Screen Size:根据屏幕大小缩放
    在这里插入图片描述

Design Resolution X/Y:设计分辨率的宽高
Ignore Orientation:忽略方向,FairyGUI会保证屏幕在旋转时缩放系数保持不变,勾选则该功能失效
PC游戏不需要这个特性

  • Screen Match Mode:屏幕匹配模式
    在这里插入图片描述

Match Width Or Height:宽高匹配(横竖屏切换游戏)
Match Width:根据宽匹配(适合竖屏游戏)
Match Height:根据高匹配(适合横屏游戏)


😶‍🌫️2.认识UIConfig


在这里插入图片描述

UIConfig是FGUI提供设置一些全局参数的组件
(默认字体,按钮音效,按钮音量、预加载的包等等)

  • Config Items:全局设置

在这里插入图片描述

  • Preload Packages:预先加载包放在Resources下的包

🅰️


⭐【Unityc#专题篇】之c#进阶篇】

⭐【Unityc#专题篇】之c#核心篇】

⭐【Unityc#专题篇】之c#基础篇】

⭐【Unity-c#专题篇】之c#入门篇】

【Unityc#专题篇】—进阶章题单实践练习

⭐【Unityc#专题篇】—基础章题单实践练习

【Unityc#专题篇】—核心章题单实践练习


你们的点赞👍 收藏⭐ 留言📝 关注✅是我持续创作,输出优质内容的最大动力!


在这里插入图片描述


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

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

相关文章

【Linux安全】Firewalld防火墙基础

目录 一、Firewalld概述 二、Firewalld和iptables的关系 三、Firewalld网络区域 1、firewalld防火墙预定义了9个区域: 2、firewalld 数据包处理原则 3、firewalld数据处理流程 4、firewalld检查数据包的源地址的规则 四、Firewalld防火墙的配置方法 1、firewalld 命令…

安全存储网关怎么实现多个存储统一管理和访问?

安全存储网关是一种网络安全产品&#xff0c;用于保护存储系统和数据。它的主要功能包括数据加密、访问控制、数据审计和监控等。安全存储网关可以用于防止未经授权的访问、数据泄露和数据篡改等安全威胁。它们通常与存储设备集成&#xff0c;提供对数据的端到端保护&#xff0…

【QT环境配置】节约msvc2017灰色不可用问题

1. 问题 msvc2017不可用&#xff0c;2019、2022都同理解决。 2. 解决 打开控制面板->程序->程序和功能->找到自己安装的vs程序->鼠标右键后出现卸载更改->点击更改 找到下面组件即可。&#xff08;msvc2019就找msvcv142&#xff09;

05.爬虫---urllib与requests请求实战(GET)

05.urllib与Requests请求实战GET 1.Urllib模块2.Requests模块3.对比4.实战 GET请求 Python中的GET请求也是HTTP协议中的一种请求方法&#xff0c;用于向服务器请求数据。与POST请求不同&#xff0c;GET请求将数据以查询字符串的形式附加在URL后面&#xff0c;而不是封装在请求体…

[Linux]第一个小程序-进度条

回车,换行概念 \n&#xff1a;回车&#xff0c;换行 回车&#xff1a;回到最开始 换行&#xff1a;回到最新的一行 缓冲区概念 #include <stdio.h> int main() {printf("hello Makefile!\n");sleep(3);return 0; } #include <stdio.h> int main() {pr…

邦之信短信分析:验证码短信、营销短信与通知短信的差异化解析

在数字通讯时代&#xff0c;短信已成为我们日常生活中不可或缺的一部分。其中&#xff0c;验证码短信、营销短信和通知短信各自扮演着不同的角色。今天&#xff0c;飞鸽将带您深入了解这三种短信类型之间的核心差异。 1. 验证码短信 验证码短信广泛应用于各类电商网站和…

使用Prometheus组件node_exporter采集linux系统的指标数据(包括cpu/内存/磁盘/网络)

一、背景 Linux系统的基本指标包括cpu、内存、磁盘、网络等&#xff0c;其中网络可以细分为带宽进出口流量、连接数和tcp监控等。 本文使用Prometheus组件node_exporter采集&#xff0c;存储在promethues&#xff0c;展示在grafana面板。 二、安装node_exporter 1、下载至本…

【C++】CentOS环境搭建-升级 OpenSSL

【C】CentOS环境搭建-升级 OpenSSL 下载 OpenSSL 源代码解压源代码进入源代码目录配置编译选项报错Cant locate IPC/Cmd.pm in INC (INC contains: /usr/local/openssl-3.3.0/util/perl /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/shar…

Python编程-后端开发之Django5应用请求处理与模板基础

Python编程-后端开发之Django5应用请求处理与模板基础 最近写项目&#xff0c;刚好用到了Django&#xff0c;现在差不多闲下来&#xff0c;个人觉得单体项目来讲django确实舒服&#xff0c;故写此总结 模板语法了解即可&#xff0c;用到了再看&#xff0c;毕竟分离已经是主流操…

幼儿园管理系统-收退费管理原型模版

幼儿园管理系统是专为幼儿园打造&#xff0c;涵盖学校儿童、职工人事、收费财务、后勤管理、办公教务、膳食分析、体检保健、文档管理等各方面内部管理的幼儿园专家系统。 本次分享给大家的是雅居乐教育集团幼儿园园务管理系统中“收退费管理”模块的设计文档。收退费管理是幼儿…

报错:c2665 ”loadimage“没有重载函数可以转换所有参数类型

解决方法: 右键项目选择属性-》高级-》字符集-》使用多字节字符集-》确定

IO多路复用模型原理

在linux没有实现epoll事件驱动机制之前,常规的手段是选择select和poll等IO多路复用的方法来实现并发服务程序。但是在大数据、高并发、集群情况下,select和poll的性能瓶颈就出现了,于是epoll就诞生了 Select select函数监视的文件描述符分三类:writefds、readfds和exceptf…

国内首个智能体生态大会!2024百度万象大会定档5月30日

最近&#xff0c;百度悄悄「上新」了几个AI神器。 百度搜索上线「互动」功能&#xff0c;可以实时问答&#xff0c;查询信息就像聊天一样简单&#xff0c;还可以艾特相关智能体&#xff0c;更细致精确地满足个性化需求&#xff0c;比如去新加坡旅游&#xff0c;可以让新加坡旅…

【源码】2024心悦搜剧源码百万级网盘资源

1、一键转存他人链接&#xff1a;就是将别人的分享链接转为你自己的 2、转存心悦搜剧资源&#xff1a;就是将心悦搜剧平台上的所有资源都转成你自己的 3、每日自动更新&#xff1a;自动转存每天的资源并入库 前端uin-app&#xff0c;后端PHP&#xff0c;兼容微信小程序

必看!企业数字化转型的组织架构与人员配置方案!

数字化浪潮汹涌而来&#xff0c;企业如何在这波大潮中破浪前行&#xff1f;关键在于构建合理的组织架构和配备合适的人员&#xff01;今天&#xff0c;我们就为大家带来蚓链实践经验总结的方案&#xff0c;让你的企业数字化转型之路更加顺畅&#xff01; 组织架构&#xff1a; …

【数学建模】碎纸片的拼接复原

2013高教社杯全国大学生数学建模竞赛B题 问题一模型一模型二条件设立思路 问题求解 问题一 已知 d i d_i di​为第 i i i张图片图片的像素矩阵 已知 d i d_i di​都是 n ∗ m n*m n∗m二维矩阵 假设有 N N N张图片 模型一 我们认为对应位置像素匹配为 d i [ j ] [ 1 ] d k…

引入安全生产培训云平台,实现“人人讲安全、个个会应急”

引入安全生产培训云平台&#xff0c;旨在全面提升企业及员工的安全意识与应急处理能力&#xff0c;通过数字化手段实现“人人讲安全、个个会应急”的目标。这一平台的构建和应用&#xff0c;不仅促进了安全知识的普及&#xff0c;还极大提高了培训的效率与效果。以下是该平台几…

【赠书第24期】Java项目开发实战(微视频版)

文章目录 前言 1 项目选择与需求分析 1.1 项目选择 1.2 需求分析 2 系统设计 2.1 系统架构设计 2.2 数据库设计 2.3 接口设计 3 编码实现 3.1 环境搭建 3.2 编码规范 3.3 编码实现 4 测试与部署 4.1 单元测试 4.2 系统测试 4.3 部署与上线 5 总结与展望 6 推…

挖矿宝藏之系统日志

什么是日志&#xff1f; 日志是指系统或应用程序在运行过程中产生的记录文件&#xff0c;这些文件记录了系统或应用程序的运行情况、错误信息、用户操作等。 日志的主要作用 记录信息&#xff1a;日志可以记录系统或应用程序的启动、运行、停止等状态信息&#xff0c;以及用户的…