一、FairyGUI编辑器中
1.新建按钮、新建组件
编辑器中界面简易设计如下
data:image/s3,"s3://crabby-images/89a47/89a47d7c6cd302d1f22662b3114638346fb57ff3" alt=""
2.文件-发布设置-发布路径:自己unity项目Resources所在的路径
data:image/s3,"s3://crabby-images/064ba/064ba25e91b25b2235a2922431446159cc73e5bc" alt=""
二、Unity 使用代码展示UI
data:image/s3,"s3://crabby-images/5d9f8/5d9f83762df95072efa93cb46fe3f8fb50aeb525" alt=""
csharp
using FairyGUI;
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class FguiTest : MonoBehaviour
{
/// <summary>
/// 普通按钮
/// </summary>
private GButton comBtn1;
private GButton comBtn3;
void Start()
{
GRoot.inst.SetContentScaleFactor(1920,1080); //初始化设置分辨率
UIPackage.AddPackage("Panels/PanelMain"); //加载打包好的项目
GComponent component = UIPackage.CreateObject("PanelMain", "Component1").asCom;
//加载对应的组件 通过.asCom(或as GComponent)类型转换将它转换为GComponent组件类型
GRoot.inst.AddChild(component); //把当前组件实例化到UI Panel(GRoot实际上是UI Panel)的下面
comBtn1 = component.GetChild("n1").asButton;
comBtn1.onClick.Add(() =>
{
Debug.Log("按钮1被点击了!!");
});
comBtn3 = component.GetChild("n3").asButton;
comBtn3.onClick.Add(() =>
{
Debug.Log("普通按钮2被点击!!!");
});
}
}
三、Unity 无代码展示UI
在Hierarchy中创建Stage Camera和 UIPanel
data:image/s3,"s3://crabby-images/b3fbf/b3fbf5e8a780e38fbef24870c411aa465ed2a087" alt=""
data:image/s3,"s3://crabby-images/b1e6c/b1e6cf2bb8ed1f29a4cfb35d29d9f5e2f100433d" alt=""
data:image/s3,"s3://crabby-images/d4217/d42179b30970e18ea479b453235ec9f4c902680f" alt=""
四、备注:场景中Main Camera的属性 Culling Mask 中不勾选UI,否则会出现两个相机画面。
data:image/s3,"s3://crabby-images/3aa19/3aa190735331d31f74a957ac950160b76e04024f" alt=""