UIToolkit是Unity官方推出的最新 UI解决方案,未来将逐步取代现有的UGUI方案,当然现在(2021.7.22)仍处于preview阶段。官方解释这是一套兼顾编辑器和runtime界面开发的更高效的UI框架。
1.创建一个新的项目,unity版本要求2020.2以上
data:image/s3,"s3://crabby-images/4f20c/4f20ce20c9fc566f65b8bcb8cfb33d9d2605709a" alt=""
2.打开菜单栏-window-package manager
data:image/s3,"s3://crabby-images/ec65e/ec65e7f8a33dcbb593af060bcc544231fea4b3ad" alt=""
3.从git链接来添加源:
data:image/s3,"s3://crabby-images/a650f/a650f5a66275fbbbdc8935cea1cb2ef0d4684aad" alt=""
4.输入com.unity.ui,然后点击add会自动下载:
data:image/s3,"s3://crabby-images/03276/032767f111598f75845cfc8514d8186a703907db" alt=""
5.下载完成后,会多出一个uitoolkit并自动安装好了(绿色勾),截止目前(2021.7.22)依旧是preview版本。
data:image/s3,"s3://crabby-images/6a9b9/6a9b9758c65f2edcbeca4a4a3a2e88c7b854a4fd" alt=""
UIToolkit使用了uxml来描述界面的布局,使用uss来制作不同样式,参考了web开发的xml和css方案。Unity2021已经将UIToolkit内置在引擎中,具有和UGUI同等地位。
比如要画一个按钮,对应的uxml
<UXML xmlns="UnityEngine.UIElements" xmlns:uie="UnityEditor.UIElements">
<Button text="UXML Button" name="the-uxml-button" />
</UXML>
按钮的样式uss如下
.some-styled-button {
-unity-font-style: bold;
}
在C#代码可以将名字和样式名绑定在一起添加点击事件。
Action action = () =>
{
container.Query<Button>().ForEach((button) =>
{
button.text = button.text.EndsWith("Button") ? "Button (Clicked)" : "Button";
});
};
// Get a reference to the Button from UXML and assign it its action.
var uxmlButton = container.Q<Button>("the-uxml-button");
uxmlButton.RegisterCallback<MouseUpEvent>((evt) => action());
// Create a new Button with an action and give it a style class.
var csharpButton = new Button(action) { text = "C# Button" };
csharpButton.AddToClassList("some-styled-button");
container.Add(csharpButton);
uxml如果都得用手写那显然太麻烦了,所以unity制作了一个可视化编辑工具uibuilder。所以uibuilder需要通过PackageManger安装(unity2021以后的版本已经内置在引擎中)。
6.安装UIToolKit后,需要安装另一个组件:UIBuilder(界面构建器)。打开高级选项:
data:image/s3,"s3://crabby-images/fe88d/fe88d8782873e98a24e27c33ef04bb17baaacae0" alt=""
7.在高级选项中勾选enable preview packages 启用预览包。
data:image/s3,"s3://crabby-images/4d16a/4d16a257a7ddfbcc9f2bdb917210fa2d3092e5f2" alt=""
8.回到管理界面,切换包的分组源为unity registry
data:image/s3,"s3://crabby-images/c64d3/c64d39fd3f2800b80a52b621e0c79d6e241afaf2" alt=""
9.找到UIBuilder并安装。
data:image/s3,"s3://crabby-images/d1114/d1114f3c57d41f720783989eaa4b0b16c0df89f5" alt=""
10.安装完毕后回到unity编辑器,在层级面板中右键uitoolkit-ui document
data:image/s3,"s3://crabby-images/82b30/82b30aaa57b0ac3430a67b51b1818a86c9760de6" alt=""
11.在项目面板中创建一个ui document
data:image/s3,"s3://crabby-images/fc929/fc929678c3a83719012026c1b7b9eeffead69ab4" alt=""
12.指定层级面板中uidocument的source asset
data:image/s3,"s3://crabby-images/91f97/91f978d0ab892cd3a604e656ce5d5faaae66cd5c" alt=""
13.双击打开project目录下的uxml,会打开uibuilder,这个界面下就可以编辑UI元素
data:image/s3,"s3://crabby-images/46331/4633119a6852efc1388ecb75df7e05132ebbee33" alt=""
14.从containers拖入一个visualement到hierachy中,活着直接拖入viewport中
data:image/s3,"s3://crabby-images/c35bf/c35bf51c9e167c086422e31ca90e75a3e73bcd55" alt=""
15.设置size
data:image/s3,"s3://crabby-images/cf501/cf5011c48d7395d0650b60f782ab81e79d12df05" alt=""
16.设置位置
data:image/s3,"s3://crabby-images/67375/67375bf295a792475f76fbd873a16edad76124f6" alt=""
17.设置背景颜色
data:image/s3,"s3://crabby-images/1bd7d/1bd7d4d4d86984bb3cf1f89ee5d9b9ccb353d2a4" alt=""
18.保存回到场景即可看到效果(第一次有可能需要play下):
data:image/s3,"s3://crabby-images/b7b16/b7b169afbe3b2154f84a94725f47f6280ec369c6" alt=""
19.从library中添加label并改名为countertext
data:image/s3,"s3://crabby-images/63b80/63b8009edcfc368b7d4bbf44a6870b7f8ac1ebfc" alt=""
20.添加一个按钮并改名为counter_button
data:image/s3,"s3://crabby-images/742cc/742cc045de3ffba8d3cd610c0fc104d919944d4b" alt=""
21.设置对其方式为居中对齐
data:image/s3,"s3://crabby-images/73461/7346131d583c6cb0c713714ff2bbbfc0d85fc5e8" alt=""
22.回到编辑器,创建一个脚本:UICounter.cs,挂载到场景的uidocument上,编辑代码:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UIElements;
public class UICounter : MonoBehaviour
{
private Label _counterText;
private Button _counterButton;
// Start is called before the first frame update
void Start()
{
var root = this.GetComponent<UIDocument>().rootVisualElement;
_counterText = root.Q<Label>("Countertext");
_counterButton = root.Q<Button>("Counter_button");
_counterButton.RegisterCallback<ClickEvent>(ev => OnClick());
}
private void OnClick()
{
_counterText.text = $"Click";
}
}
23.看看最终执行的效果
data:image/s3,"s3://crabby-images/881fc/881fc8cb9f833aca5bae662e96cf087214096224" alt=""
说明:UIToolKit合并Drawcall能力要强于UGUI,如果图集数量在8个以内,字体数量在一个以内UIToolKit可以将所有界面都合并成一个DrawCall,相反在UGUI中就会占9个DrawCallle ,如果界面多了出现叠层DrawCal会更多。
UIToolkit是支持UGUI的Atlas图集的,但其实它支持的是Texture,即使把Sprite都打在一个图集中也不定能能合并DrawCall,它支持Sprite的Tight模式,增加顶点数减少填充率。只要按照绘制的顺序它会将前8个Texture合并成一个DrawCall,或者有N个Image只要它们用的都是这8个图中的任意,这些也会合并成一个 DrawCall。
就目前的情况来说UIToolkit是不可能代替UGUI的,比如UI粒子叠层、美术的K帧动画、3D透视界面、复杂的层次结构界面,这些都不适合。但是有些界面,比如头顶血条+文字、弹窗、对性能要求较高的一部分界面可以考虑使用UIToolkit,几乎都能合并成一个DrawCall。目前官方也表示UIToolkit和UGUI可以混合使用。
网友评论