-
Notifications
You must be signed in to change notification settings - Fork 2
Home
小莫 edited this page Oct 11, 2022
·
2 revisions
UnityGameUI地址:https://github.com/GlossMod/UnityGameUI
UnityGameUI(简称UGUI)是一个基于Unity的UI框架,可以在游戏中使用。使用 GameObject 构建,相较于之前的GUILayout大大的提高了运行效率。
GUILayout是运行在 OnGUI() 方法中,该方法会在每一帧都被调用,如果进行了数据调用,将浪费很多的资源,导致游戏卡顿。
UnityGameUI 是在游戏里面创建了一个 GameObject(游戏对象) ,你可以将他理解为一个厚度为0.0001的长方体,创建之后就一直在那里,通过 SetActive(true/false)
来控制是否显示, 在执行效率上没有效率的问题,显示设置为 false
之后也不会影响游戏的使用。
将项目以子模块的形式添加到您的项目 然后 using UnityGameUI
- 需要使用
UIControls.createUICanvas();
创建一个Canvas
当做整个UI的父级(画板) - 使用
UIControls.createUIPanel(GameObject canvas, string height, string width, Sprite BgSprite = null);
创建一个Panel
作为UI的容器 - 接下来就可以根据自己创意,进行自由发挥了。
画布是所有UI的父级对象,所有的UI都需要挂载到画布上,画布是一个独立的对象,可以在游戏中创建多个画布,但是一个画布只能有一个事件系统,所以如果需要多个画布,需要在每个画布上创建一个事件系统。
例子:
GameObject canvas = UIControls.createUICanvas();
面板是UI组件的容器, 可以在面板上嵌套面板,可以将其当做容纳组件的一个框,组件放在面板的上面, 面板为矩形,可以设置宽高,背景图片,背景颜色等。
例子:
GameObject uiPanel = UIControls.createUIPanel(canvas, "300", "500", null);
uiPanel.GetComponent<Image>().color = UIControls.HTMLString2Color("#424242FF"); // 设置背景颜色
// 其他 GameObject 相关的设置也都可以直接使用 请不要被限制想象力
按钮是一个可以点击的组件,可以设置按钮的文字,背景图片,背景颜色,点击事件等。
例子:
string backgroundColor = "#8C9EFFFF";
Vector3 localPosition = new Vector3(elementX, elementY, 0); // elementX, elementY 为按钮的位置, 0, 0位置在 Panel 的中心
GameObject button = UIControls.createUIButton(uiPanel, backgroundColor, "按钮1", btn1OnClick, localPosition);
// 可以根据自己的需求修改按钮样式
button.AddComponent<Shadow>().effectColor = UIControls.HTMLString2Color("#000000FF"); // 添加阴影
button.GetComponent<Shadow>().effectDistance = new Vector2(2, -2); // 设置阴影偏移
button.GetComponentInChildren<Text>().fontSize = 14; // 设置字体大小
button.GetComponent<RectTransform>().sizeDelta = new Vector2(80, 30); // 设置按钮大小
文本是一个可以显示文字的组件,可以设置文字的内容,字体,字体大小,颜色等。
例子:
Sprite txtBgSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#7AB900FF")); // 背景样式
GameObject uiText = UIControls.createUIText(panel, txtBgSprite, "#FFFFFFFF");
uiText.GetComponent<Text>().text = "text"; // 设置文本内容
uiText.GetComponent<RectTransform>().localPosition = new Vector3(elementX, elementY, 0); // 设置文本位置
// 设置字体样式
uiText.GetComponent<Text>().fontSize = 14;
uiText.GetComponent<Text>().fontStyle = FontStyle.Bold;
// ......
创建一个用于输入文本的输入框
例子:
// 输入框
Sprite inputFieldSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#212121FF")); // 背景颜色
GameObject uiInputField = UIControls.createUIInputField(panel, inputFieldSprite, "#FFFFFFFF");
uiInputField.GetComponent<InputField>().text = defaultText; // 设置默认文本
uiInputField.GetComponent<RectTransform>().localPosition = new Vector3(elementX, elementY, 0); // 设置输入框位置
uiInputField.GetComponent<RectTransform>().sizeDelta = new Vector2(width - 60, 30); // 设置输入框大小
// 文本框失去焦点时触发方法
uiInputField.GetComponent<InputField>().onEndEdit.AddListener((string text)=>{
Debug.Log("您输入的内容是: " + text);
});
创建一个用于勾选的复选框
例子:
Sprite toggleBgSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#3E3E42FF")); // 背景颜色
Sprite toggleSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#18FFFFFF")); // 勾选颜色
GameObject uiToggle = UIControls.createUIToggle(panel, toggleBgSprite, toggleSprite);
uiToggle.GetComponentInChildren<Text>().color = Color.white; // 设置文本颜色
uiToggle.GetComponentInChildren<Toggle>().isOn = false; // 设置默认勾选状态
uiToggle.GetComponent<RectTransform>().localPosition = new Vector3(elementX, elementY, 0); // 设置复选框位置
uiToggle.GetComponentInChildren<Text>().text = "Text"; // 设置文本内容
uiToggle.GetComponentInChildren<Toggle>().onValueChanged.AddListener((bool toggle)=>{
Debug.Log($"复选框状态: {toggle}");
});
下拉框用起来稍微有点复杂,
例子:
List<string> options = new List<string>() { "选项1", "选项2", "选项3" }; // 下拉框的选项
// 创建下拉框
Sprite dropdownBgSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#212121FF")); // 背景颜色
Sprite dropdownScrollbarSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#8C9EFFFF")); // 滚动条颜色 (如果有的话
Sprite dropdownDropDownSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#212121FF")); // 框右侧小点的颜色
Sprite dropdownCheckmarkSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#8C9EFFFF")); // 选中时的颜色
Sprite dropdownMaskSprite = UIControls.createSpriteFrmTexture(UIControls.createDefaultTexture("#E65100FF")); // 不知道是哪的颜色
Color LabelColor = UIControls.HTMLString2Color("#EFEBE9FF");
GameObject uiDropDown = UIControls.createUIDropDown(panel, dropdownBgSprite, dropdownScrollbarSprite, dropdownDropDownSprite, dropdownCheckmarkSprite, dropdownMaskSprite, options, LabelColor);
Object.DontDestroyOnLoad(uiDropDown);
uiDropDown.GetComponent<RectTransform>().localPosition = new Vector3(elementX, elementY, 0);
// 下拉框选中时触发方法
uiDropDown.GetComponent<Dropdown>().onValueChanged.AddListener((int index)=>{
Debug.Log($"选择了: {options[index]}");
});