Unity3D学习之UI系统——NGUI

文章目录

  • 1. 前言
  • 2 NGUI下载和导入
  • 3. NGUI三大组件
    • 3.1 Root组件
      • 3.1.1 分辨率概念
      • 3.1.2 Root的作用
      • 3.1.3 root脚本各组件
      • 3.1.4 总结
    • 3.2 Panel 组件
      • 3.2.1 Panel的作用
      • 3.2.2 Panel的控件
      • 3.2.3 总结
    • 3.3 EventSystem组件
      • 3.3.1 作用
      • 3.3.2 组件
      • 3.3.3 总结
  • 4 图集制作
    • 4.1 图集的作用
    • 4.2 打开图集制作工具
    • 4.3 新建图集
  • 5 三大基础控件
    • 5.1 Sprite 精灵图片
      • 5.1.1 创建Sprite
      • 5.1.2 Sprite 控件
      • 5.1.3 在代码中的Sprite
    • 5.2 Label文本控件
      • 5.2.1 创建Label
      • 5.2.2 Label控件
      • 5.2.3 代码控制
    • 5.3 Texture 大图控件
  • 6 组合控件
    • 6.1 Button组件
      • 6.1.1 添加Sprite组件
      • 6.1.2 添加Button脚本
      • 6.1.3 添加碰撞器
      • 6.1.4 组合
      • 6.1.5 button组件参数
      • 6.1.6 监听点击事件
      • 6.1.7 总结
    • 6.2 Toggle单选多选框
      • 6.2.1 创建toggle
      • 6.2.2 toggle控件
      • 6.2.3 监听事件
    • 6.3 Input文本输入
      • 6.3.1 Input文本创建
      • 6.3.2 Input组件
      • 6.3.3 监听事件的两种方式
    • 6.4 PopupList 下拉列表组件
      • 6.4.1 制作PopupList
      • 6.4.2 组件相关
      • 6.4.3 选择相关
      • 6.4.4 监听事件
    • 6.5 Slider滑动条控件
      • 6.5.1 创建
      • 6.5.2 参数
      • 6.5.3 监听函数
    • 6.6 ScrollBar 滚动条 和 ProgressBar进度条
      • 6.6.1 制作ScrollBar 滚动条
      • 6.6.2 制作 ProgressBar进度条
    • 6.7 ScrollView 滚动视图
      • 6.7.1 制作ScrollView
      • 6.7.2 ScrollView组件
      • 6.7.3 自动对齐脚本Grid
    • 6.8 Anchor 锚点组件
      • 6.8.1 老版本中(了解)
      • 6.8.2 新版本基础控件自带锚点信息
  • 7 NGUI进阶
    • 7.1 EventListener
    • 7.2 EventTrigger
    • 7.3 DrawCall
      • 7.3.1 如何降低DrawCall
    • 7.4 NGUI字体
      • 7.4.1 制作NGUI字体
      • 7.4.2 通过bmfont64 制作
      • 7.4.3 选择Unity字体和NGUI字体
    • 7.5 NGUI 缓动
      • 7.5.2 缓动参数
      • 7.5.3 输入事件和缓动关联PlayTween
    • 7.6 NGUI中显示3D模型和粒子特效
      • 7.6.1 用UI摄像机渲染
      • 7.6.2 用Render Texture渲染
      • 7.6.3 显示粒子特效
    • 7.7 NGUI 音效
    • 7.8 按键绑定
    • 7.9 PC端 tab键快速切换选中
    • 7.10 本地化


1. 前言

在这里插入图片描述

2 NGUI下载和导入

资源商店搜索
在这里插入图片描述
学习版自行搜索
在这里插入图片描述
在这里插入图片描述
导入即可
创建UI
在这里插入图片描述

3. NGUI三大组件

在这里插入图片描述
创建NGUI后,挂载在UI Root 和其 子Camera的脚本
在这里插入图片描述
在这里插入图片描述

3.1 Root组件

分辨率自适应模式的基础

3.1.1 分辨率概念

在这里插入图片描述
在这里插入图片描述

3.1.2 Root的作用

在这里插入图片描述

3.1.3 root脚本各组件

在这里插入图片描述
Minimun Height 和 Maximum Height
用于拖动窗口时,如果窗口变得很小了,UI不缩放的话,会挡住游戏,使用Flexible模式用于解决该问题,会在小于或着大于这两个值的时候,进行等比缩放

Shrink Portrait UI 竖屏时按宽度来适配

Adjust by DPI 勾选就是

在这里插入图片描述
Content Width 和 Content Height 是自适应屏幕时默认的分辨率
不勾选Fit 时 会裁剪,不会有黑边,始终会有UI填充屏幕
勾选Height 画布总是跟着屏幕高度缩放 (横屏游戏
勾选Width 画布总是跟着屏幕宽度缩放 (竖屏游戏
在这里插入图片描述

3.1.4 总结

在这里插入图片描述

3.2 Panel 组件

3.2.1 Panel的作用

管理渲染相关内容
在这里插入图片描述

3.2.2 Panel的控件

在这里插入图片描述
Depth 控制层级,层级越高的遮挡层级低的。要注意不同Panel最好不要在一个层级
Clipping 通过参数裁剪
在这里插入图片描述

在这里插入图片描述
排序层之后再讲
在这里插入图片描述

3.2.3 总结

在这里插入图片描述

3.3 EventSystem组件

3.3.1 作用

在这里插入图片描述

3.3.2 组件

在这里插入图片描述

UI模式是根据组件深度处理事件
World模式 根据距离著摄像机的远近来响应排序(这两个的主要区别在 眼睛看到在前面的,进行交互时UI模式点击看起来在被前面的窗口压在后面的,但被压在的那一层层级更高,会先相应被压在下面的UI)

EventMask 决定哪个层级接受事件
在这里插入图片描述
Debug就是测试时,你点击这个UI,会打印出来交互的时什么对象

在这里插入图片描述

3.3.3 总结

在这里插入图片描述

4 图集制作

4.1 图集的作用

在这里插入图片描述

4.2 打开图集制作工具

在这里插入图片描述
在这里插入图片描述

4.3 新建图集

点击New 新建

在这里插入图片描述
选择 加入图集的文件
在这里插入图片描述
创建图集,一般存放在Resources文件夹内,方便读取
在这里插入图片描述
有三个文件
1.图集文件
2.图集材质
3.图集图片

在这里插入图片描述

5 三大基础控件

在这里插入图片描述
公共内容
在这里插入图片描述

5.1 Sprite 精灵图片

在这里插入图片描述

5.1.1 创建Sprite

方式1
在这里插入图片描述
方式2
在这里插入图片描述

5.1.2 Sprite 控件

在这里插入图片描述
Atlas 选择图集
Sprite选择图集中的图片
Fiexed Aspect保持宽高比

sliced模式
点击Edit
在这里插入图片描述
拉伸Border,会根据九宫格进行拉伸。保证四个角不变化,只会拉伸中间的十字区域
在这里插入图片描述
Tiled 平铺模式
图片会重复绘制
在这里插入图片描述

Filled 填充模式
填充模式用于制作进度条、血条
在这里插入图片描述

在这里插入图片描述

5.1.3 在代码中的Sprite

在这里插入图片描述

在这里插入图片描述

5.2 Label文本控件

在这里插入图片描述

5.2.1 创建Label

NGUI - create - Lable

5.2.2 Label控件

在这里插入图片描述
在这里插入图片描述
shrink Content
在这里插入图片描述

Calmp Content
在这里插入图片描述
Resize freely
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
给Lable增加碰撞器,然后点击超链接可以转到超链接的网之
在这里插入图片描述
在这里插入图片描述

5.2.3 代码控制

在这里插入图片描述

在这里插入图片描述

5.3 Texture 大图控件

在这里插入图片描述

6 组合控件

在这里插入图片描述

6.1 Button组件

6.1.1 添加Sprite组件

在这里插入图片描述

6.1.2 添加Button脚本

在这里插入图片描述

6.1.3 添加碰撞器

在这里插入图片描述
在这里插入图片描述

6.1.4 组合

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

6.1.5 button组件参数

在这里插入图片描述
Transition 过渡时间 从某一个颜色编导另外一个颜色所需要的时间
Sprite 可以设置各个状态时的效果

6.1.6 监听点击事件

在这里插入图片描述
把Panel(挂载脚本的组件)拖入到button 的on click中
在这里插入图片描述

然后在Method选择 需要使用的函数
在这里插入图片描述
在这里插入图片描述
点击后
在这里插入图片描述
如果方法是私有,会找不到
同时可以添加多个监听函数
在这里插入图片描述
使用代码获得按钮对象监听

在这里插入图片描述
拖入
在这里插入图片描述
在这里插入图片描述
使用拉姆达表达式
在这里插入图片描述

在这里插入图片描述

6.1.7 总结

在这里插入图片描述

6.2 Toggle单选多选框

6.2.1 创建toggle

在这里插入图片描述
在这里插入图片描述
增加脚本和碰撞器
在这里插入图片描述

6.2.2 toggle控件

在这里插入图片描述
关联选中时的图片
在这里插入图片描述
加入Sprite后
未选中
在这里插入图片描述
选中
在这里插入图片描述

Starting state 一开始的选中状态
Invert State 反转状态

Group 多选框分组
在这里插入图片描述
如果只能选择一个
可以设置为同一个Group
在这里插入图片描述
State of None是这个Group必须要选中一个
在这里插入图片描述

6.2.3 监听事件

创建一个Panel用于挂载脚本
然后再Toggle上拖入函数
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
如何知道哪一个Toggle选中,可以在Panel的脚本中设声明三个Sprite变量关联
在这里插入图片描述

在这里插入图片描述
然后给所有的Toggle关联Panel

分别选中
在这里插入图片描述
代码监听

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.3 Input文本输入

6.3.1 Input文本创建

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.3.2 Input组件

在这里插入图片描述

拖入Label
在这里插入图片描述
Input type
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

6.3.3 监听事件的两种方式

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Panel装载脚本,关联Input的Sprite
在这里插入图片描述
input脚本里关联Panel的函数

在这里插入图片描述

测试的时候把回车改成提交

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.4 PopupList 下拉列表组件

如此类似的
在这里插入图片描述

6.4.1 制作PopupList

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.4.2 组件相关

在这里插入图片描述
在这里插入图片描述
选项 空一行一个组件
在这里插入图片描述
如果设置了之后没有反应,首先设置一下字体

在这里插入图片描述
出现了三个,很奇怪后面的参数可以设置
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

6.4.3 选择相关

选择这个脚本
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.4.4 监听事件

在这里插入图片描述
在这里插入图片描述
和之前一样的套路Panel挂载脚本,popupList关联事件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
新加选项
在这里插入图片描述
在这里插入图片描述

6.5 Slider滑动条控件

在这里插入图片描述

6.5.1 创建

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
NGUI的Slider是添加到背景的这个Sprite上
但是碰撞器 添加到 背景的Sprite上,用户按和拖动滑块都能进行移动,如果碰撞器 添加到 滑块的Sprite 上,用户只能通过拖动滑块进行移动

6.5.2 参数

在这里插入图片描述
steps 会等分成十份

6.5.3 监听函数

和其他控件一样,就一笔带过了
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.6 ScrollBar 滚动条 和 ProgressBar进度条

在这里插入图片描述在这里插入图片描述

6.6.1 制作ScrollBar 滚动条

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

6.6.2 制作 ProgressBar进度条

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6.7 ScrollView 滚动视图

在这里插入图片描述

6.7.1 制作ScrollView

在这里插入图片描述
在这里插入图片描述
子对象添加Drag Scorll View和碰撞器
在这里插入图片描述

6.7.2 ScrollView组件

在这里插入图片描述
Panel主要用于设置范围

在这里插入图片描述
改变可视范围
在这里插入图片描述
MoveMent 水平移动或者竖直移动
设置只能水平或者垂直 或者自由(左右都行
拖动
在这里插入图片描述
Drag Effect 类似于惯性 和 弹性 的效果

ScrollWheel Factor 滚动因子 滚动速度和方向
在这里插入图片描述
Momentum Amount动量 设置惯性大小
Sppring Strength 弹力大小
Dampen Strength 阻尼强度
Cancel Drag if fits 如果 内容没有超过 可视范围,决定此时能不能拖动

滚动条相关
在这里插入图片描述

自行设置,只要关联了,就会自动设置拖动条,运行前会自己计算在这里插入图片描述

6.7.3 自动对齐脚本Grid

为 ScrollView添加Grid脚本 自动对齐
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

手动排序
在这里插入图片描述
通过代码移除物品 更新滚动条
在这里插入图片描述

6.8 Anchor 锚点组件

在这里插入图片描述

6.8.1 老版本中(了解)

create 一个Anchor
在这里插入图片描述
在这里插入图片描述

6.8.2 新版本基础控件自带锚点信息

在这里插入图片描述
各大小是屏幕的
在这里插入图片描述
如果希望始终处于屏幕左上角
在这里插入图片描述
右上角
在这里插入图片描述
右中
在这里插入图片描述

7 NGUI进阶

NGUI提供了一些自带的函数,在挂载脚本时,NGUI会自动寻找这些方法。
在这里插入图片描述
在这里插入图片描述
创建一个只有碰撞器的Sprite
在这里插入图片描述
拖入这个脚本
按下时
在这里插入图片描述
其他函数同理
在这里插入图片描述

7.1 EventListener

在这里插入图片描述
首先挂载两个Sprite对象
在这里插入图片描述
为Sprite添加EventListenner 以及为委托添加函数
在这里插入图片描述

也可以自己添加函数
在这里插入图片描述

在这里插入图片描述

7.2 EventTrigger

添加
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

7.3 DrawCall

在这里插入图片描述

7.3.1 如何降低DrawCall

Dra'w

在这里插入图片描述
同一个图集 如果在这两个同图集的图 中间的层级加入了其他图集,也会产生DrawCall,打断了合并渲染
要效率 还是要内存 可以自己决定

7.4 NGUI字体

在这里插入图片描述

7.4.1 制作NGUI字体

降低DrawCall
在这里插入图片描述
把文字导成图集
在这里插入图片描述
图集中多了
在这里插入图片描述
可以在Lebel中选择该图集

在这里插入图片描述
然后选择MyFont
优点在于减少DrawCall缺点在于不能动态改变文字

7.4.2 通过bmfont64 制作

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
可以导入TXT,记得改成带有BOM 的UTF-8

在这里插入图片描述
然后导入 + 生成
在NGUI中导入

在这里插入图片描述
在外部 可以 自定义美术字体
通过字体编号
这里48 是 0,然后替换这个字体

在这里插入图片描述
在这里插入图片描述

7.4.3 选择Unity字体和NGUI字体

在这里插入图片描述

7.5 NGUI 缓动

在这里插入图片描述### 7.5.1 使用缓动

在这里插入图片描述
在这里插入图片描述

7.5.2 缓动参数

在这里插入图片描述
有点像手游里一直膨胀缩小的图标

TweenGroup用于多个动画分组

Ignore TimeScale 用于在游戏暂停时依然播放特效

7.5.3 输入事件和缓动关联PlayTween

添加Play Tween参数
在这里插入图片描述
在这里插入图片描述
勾选 start State时value默认为0,意思是一开始的时候不会自动播放特效
PlayTween 和Tweener上的Group如果不相同,则不会管理这个Tweener
在这里插入图片描述
Trigger 触发的方式
在这里插入图片描述
记得加触发器
在这里插入图片描述

添加两个PlayTween

在这里插入图片描述

一各按压时管理缩放小,一个松开时管理放大
把两个PlayTween改为taggle

7.6 NGUI中显示3D模型和粒子特效

7.6.1 用UI摄像机渲染

在这里插入图片描述
更改为UI层
在这里插入图片描述
拖入3D模型
调整缩放和UI控件Z轴的距离
在这里插入图片描述

7.6.2 用Render Texture渲染

在这里插入图片描述
设置主摄像机不渲染我们要展示的模型
在这里插入图片描述

设置要渲染模型的摄像机渲染
在这里插入图片描述
设置UI 摄像机渲染UI层
在这里插入图片描述

在Panel中创建一张大图,拖入摄像机
在这里插入图片描述
tank托上去
在这里插入图片描述

7.6.3 显示粒子特效

在这里插入图片描述

在粒子特效中找到设置层级
在这里插入图片描述
在这里插入图片描述

7.7 NGUI 音效

在这里插入图片描述

在这里插入图片描述
选择触发什么音效时播放

7.8 按键绑定

添加KeyBinding脚本

在这里插入图片描述

7.9 PC端 tab键快速切换选中

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
如果要打到tab切换,要所有的Sprite都添加这个脚本
然后记得添加碰撞器

7.10 本地化

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
挂载LanguageSelection后

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

如何使用手机安装JuiceSSH远程连接本地Linux服务器

⛳️ 推荐 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 文章目录 ⛳️ 推荐1. Linux安装cpolar2. 创建公网SSH连接地址3. JuiceSSH公网远程连接4. 固定连接SSH公网地址5. SSH固定地址…

vue-computed 计算属性

一、computed 计算属性 在Vue应用中&#xff0c;在模板中双向绑定一些数据或者表达式&#xff0c;但是表达式如果过长&#xff0c;或者逻辑更为复杂 时&#xff0c;就会变得臃肿甚至难以维护和阅读&#xff0c;例如&#xff1a; <div>写在双括号中的表达式太长了,不利于阅…

关于如何将Win幻兽帕鲁服务端存档转化为单人本地存档的一种方法(无损转移)

本文转自博主的个人博客&#xff1a;https://blog.zhumengmeng.work,欢迎大家前往查看。 原文链接&#xff1a;点我访问 **起因&#xff1a;**最近大火的开放世界缝合体游戏幻兽帕鲁的大火也是引起了博主的注意&#xff0c;然后博主和周边小伙伴纷纷入手&#xff0c;博主也是利…

Maya------创建多边形工具

配合导入图像使用 Tab键可以删除一个点&#xff01; 模型不能超过4边面&#xff01;多切割工具进行连接&#xff01; 15.maya常用命令5.创建多边形工具 反转 双显 挤出_哔哩哔哩_bilibili

SpringBoot+SqlServer查询接口

SpringBootSqlServer查询接口 文章目录 SpringBootSqlServer查询接口1. pom环境配置2. common工具包3. 实体类接口映射4. Service层Controller层 需求&#xff1a;根据站号查询前一个小时的所有数据&#xff0c;将数据返回格式为Map<String,List<Map<String,String>…

动手学深度学习(一)深度学习介绍2

目录 二、起源 三、深度学习的成功案例&#xff1a; 四、特点&#xff1a; 五、小结&#xff1a; 二、起源 为了解决各种各样的机器学习问题&#xff0c;深度学习提供了强大的工具。 虽然许多深度学习方法都是最近才有重大突破&#xff0c;但使用数据和神经网络编程的核心思…

Scala入门01

Spark入门 1.入门 spark采用Scala语言开发 Spark是用来计算的 Scala掌握&#xff1a;特性&#xff0c;基本操作&#xff0c;集合操作&#xff0c;函数&#xff0c;模式匹配&#xff0c;trait&#xff0c;样例类&#xff0c;actor等内容。 2.内容讲解 2.1 Scala简介 在http…

2024-01-29 ubuntu 用脚本设置安装交叉编译工具链路径方法,设置PATH环境变量

一、设置PATH环境变量的方法,建议用~/.bash_profile的方法&#xff0c;不然在ssh登录的时候可能没有设置PATH. 二、下面的完整的脚本&#xff0c;里面的echo "export PATH$build_toolchain_path:\$PATH" >> $HOME/.bashrc 就是把交叉编译路径写写到.bashrc设置…

计算机毕业设计 基于SpringBoot的车辆违章信息管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

华为radius认证

组网需求 如图1所示&#xff0c;用户同处于huawei域&#xff0c;Router作为目的网络接入服务器。用户需要通过服务器的远端认证才能通过Router访问目的网络。在Router上的远端认证方式如下&#xff1a; Router对接入用户先用RADIUS服务器进行认证&#xff0c;如果认证没有响应…

链表--114. 二叉树展开为链表/medium 理解度C

114. 二叉树展开为链表 1、题目2、题目分析3、复杂度最优解代码示例4、适用场景 1、题目 给你二叉树的根结点 root &#xff0c;请你将它展开为一个单链表&#xff1a; 展开后的单链表应该同样使用 TreeNode &#xff0c;其中 right 子指针指向链表中下一个结点&#xff0c;而…

跟着cherno手搓游戏引擎【14】封装opengl

本节先把代码粘上&#xff0c;后续会慢慢把注释都给加上&#xff0c;先看代码了解个大概&#xff08;待更新&#xff09; 前置&#xff1a; RendererAPI.h: #pragma once namespace YOTO {enum class RendererAPI {None 0,OpenGL1};class Renderer {public:inline static R…