Version: 2020.3
言語: 日本語
UXML テンプレートの作成
UXML 要素リファレンス

UXML を C# からロードする

UXML テンプレートからユーザーインターフェースをビルドするには、最初にそのテンプレートを VisualTreeAsset にロードする必要があります。

var template = EditorGUIUtility.Load("path/to/file.uxml") as VisualTreeAsset;

以下はより直接的な方法です。

var template = AssetDatabase.LoadAssetAtPath<VisualTreeAsset>("path/to/file.uxml");

次に、ビジュアルツリーを作成し親要素にアタッチします。

template.CloneTree(parentElement, slots);

上のステートメントでは、テンプレートの <UXML> 要素は VisualElement には変換されません。その代わりに、すべての子は parentElement で指定された要素にアタッチされます。

テンプレートがインスタンス化されると、UQuery (JQuery/Linq の Unity への実装) を使って要素のビジュアルツリーから特定の要素を取得することができます。

例えば、次のコードは新しい EditorWindow を作成し、そのコンテンツとして UXML ファイルをロードする方法を示しています。


public class MyWindow : EditorWindow  {
    [MenuItem ("Window/My Window")]
    public static void  ShowWindow () {
        EditorWindow w = EditorWindow.GetWindow(typeof(MyWindow));

        VisualTreeAsset uiAsset = AssetDatabase.LoadAssetAtPath<VisualTreeAsset>("Assets/MyWindow.uxml");
        VisualElement ui = uiAsset.CloneTree(null);

        w.rootVisualElement.Add(ui);
    }

    void OnGUI () {
        // IMGUI も処理する必要がある場合を除いては、ここでは何も行う必要はありません。
    }
}

  • 2018–11–02 修正されたページ
UXML テンプレートの作成
UXML 要素リファレンス
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961