SimpleEditorTableView provides a simple way to create a TableView in Unity Editor GUI. It encapsulates Unity's MultiColumnHeader and ScrollView, but with a simpler and more direct interface, supporting click sorting and custom element rendering.
For a complete Demo, see DemoWindow.cs
-
Place
SimpleEditorTableView.cs
in the Editor directory. -
Define a data structure to store the data in the TableView.
-
Create a new EditorWindow or Editor class.
-
Add a member of the
SimpleEditorTableView<TData>
class in your Editor class.public class LightItem { public bool enabled; public string name; public LightType type; public LightShape shape; public Color color; public float intensity; } public class MyEditor : EditorWindow { private SimpleEditorTableView<LightItem> _tableView; }
Call the SimpleEditorTableView<TData>.AddColumn()
method to define the columns in the TableView. The caller decides how to draw each element, including various properties, how to sort, etc.
private void CreateTable()
{
_tableView = new SimpleEditorTableView<LightItem>();
// first column is a toggle, with a minimum width of 50 and a maximum width of 80
_tableView.AddColumn("Enabled", 50, (rect, item) =>
{
item.enabled = EditorGUI.Toggle(rect, item.enabled);
}).SetMaxWidth(80);
// second column is a text field, can be sorted by name
_tableView.AddColumn("Name", 100, (rect, item) =>
{
item.name = EditorGUI.TextField(rect, item.name);
}).SetMaxWidth(200).SetSorting((a, b) => a.name.CompareTo(b.name, StringComparison.Ordinal));
// define more columns here
// ...
}
-
For the AddColumn method, the following parameters are required:
- title: The title of the column.
- minWidth: The minimum width of the column.
- onDrawItem: A delegate for drawing the controls for each element. It accepts two parameters, one is Rect, which represents the position and size of the control, and the other is TData, which represents the data of the current element.
-
The return value of AddColumn can be chained:
- SetMaxWidth: Sets the maximum width of the column.
- SetTooltip: Sets the tooltip for the column.
- SetAutoResize: Sets whether the column should automatically resize.
- SetAllowToggleVisibility: Sets whether the column can be hidden.
- SetSorting: Sets the sorting rule. Pass in a comparator to compare the size of two elements. Only ascending order sorting needs to be implemented; descending order sorting will be handled automatically.
Call the SimpleEditorTableView<TData>.DrawTableGUI()
method in OnGUI to set the data. A TData array needs to be passed in. It can be inserted anywhere in OnGUI.
private LightItem[] _lightItems = new LightItem[] {
// ...
};
private void OnGUI()
{
// Draw some GUI here
_tableView.DrawTableGUI(_lightItems);
// Draw more GUI here
}