ReorderableList

请明月發表於2024-10-15

目錄
  • 簡介
  • 常用委託事件
  • 程式碼示例

簡介

列表重寫的資料類,一般使用在Editor下

常用委託事件

委託名 作用
drawElementCallback 用於繪製list裡的每個element
drawHeaderCallback 用於繪製header
elementHeightCallback 用於設定每個element的高度
onAddCallback element新增時的回撥
onAddDropdownCallback +號點選後可出現列表的回撥
onRemoveCallback element移除時的回撥

程式碼示例

//將對應的列表轉換為ReorderableList
reorderableList = new ReorderableList(serializedObject, serializedObject.FindProperty("moduleList"), true, true, true, true);

// 自定義DrawElement回撥函式,控制列表每一項的顯示
reorderableList.drawElementCallback = (Rect rect, int idx, bool isActive, bool isFocused) =>
{
    var element = reorderableList.serializedProperty.GetArrayElementAtIndex(idx).objectReferenceValue as BaseAudioModule;

    EditorGUI.LabelField(rect, element.name);
};

//列表新增,需要點選加號時出現列表
reorderableList.onAddDropdownCallback = (rect,list) =>
{
    GenericMenu menu = new GenericMenu();

    //新增選項到下拉選單
    menu.AddItem(new GUIContent("UIModule"), false, AddUIModule);
    menu.AddItem(new GUIContent("FadeModule"), false, AddFadeModule);

    menu.ShowAsContext();
};
//列表移除,需要點選減號時出現提示或者支援撤銷
reorderableList.onRemoveCallback = (list) =>
{
    if (EditorUtility.DisplayDialog("提示", "確認移除音效模組", "確定", "取消"))
    {
        int idx = list.index;
        if (idx >= 0 && idx < list.count)
        {
            //移除
            var property = list.serializedProperty.GetArrayElementAtIndex(idx).objectReferenceValue as BaseAudioModule;
            //myTarget.Remove(property);
            DestroyImmediate(property, true);
            list.serializedProperty.DeleteArrayElementAtIndex(idx);
            serializedObject.ApplyModifiedProperties();
            AssetDatabase.ImportAsset(path);
            AssetDatabase.Refresh();
        }
        EditorUtility.SetDirty(target);
    }
};