Creates a breadcrumb UI element for the toolbar to help users navigate a hierarchy. For example, the visual scripting breadcrumb toolbar makes it easier to explore scripts because users can jump to any level of the script by clicking a breadcrumb item. For more information, refer to UXML element ToolbarBreadcrumbs.
Represents a breadcrumb trail to facilitate navigation between related items in a hierarchy.
using UnityEngine; using UnityEngine.UIElements; using UnityEditor.UIElements;
public class CreateBreadcrumbsHelper { ToolbarBreadcrumbs breadcrumbs; public void CreateBreadcrumbs(VisualElement root) { var toolbar = new Toolbar(); root.Add(toolbar); breadcrumbs = new ToolbarBreadcrumbs(); toolbar.Add(breadcrumbs); breadcrumbs.PushItem("myItemGrandParent", GoToRoot); breadcrumbs.PushItem("myItemParent", () => breadcrumbs.PopItem()); breadcrumbs.PushItem("myItem"); }
void GoToRoot() { while (breadcrumbs.childCount > 1) breadcrumbs.PopItem(); } }
firstItemClassName | A Unity style sheet (USS) class for the first element or item in a breadcrumb toolbar. |
itemClassName | A Unity style sheet (USS) class for individual items in a breadcrumb toolbar. |
ussClassName | A Unity style sheet (USS) class for the main ToolbarBreadcrumbs container. |
ToolbarBreadcrumbs | Constructs a breadcrumb UI element for the toolbar to help users navigate a hierarchy. |
PopItem | Removes the last item in the breadcrumb toolbar, which is the deepest item in the hierarchy. |
PushItem | Adds an item to the end of the breadcrumbs, which makes that item the deepest item in the hierarchy. |
disabledUssClassName | USS class name of local disabled elements. |
canGrabFocus | Return true if the element can be focused. |
delegatesFocus | Whether the element should delegate the focus to its children. |
focusable | True if the element can be focused. |
focusController | Return the focus controller for this element. |
tabIndex | An integer used to sort focusables in the focus ring. Must be greater than or equal to zero. |
childCount | Number of child elements in this object's contentContainer. |
contentContainer | Child elements are added to it, usually this is the same as the element itself. |
contentRect | The rectangle of the content area of the element, in the local space of the element. |
customStyle | Returns the custom style properties accessor for this element. |
enabledInHierarchy | Returns true if the VisualElement is enabled in its own hierarchy. |
enabledSelf | Returns true if the VisualElement is enabled locally. |
experimental | Returns the UIElements experimental interfaces. |
generateVisualContent | Called when the VisualElement visual contents need to be (re)generated. |
hierarchy | Access to this element physical hierarchy |
languageDirection | Indicates the directionality of the element's text. The value will propagate to the element's children. |
layout | The position and size of the VisualElement relative to its parent, as computed by the layout system. |
localBound | Returns a Rect representing the Axis-aligned Bounding Box (AABB) after applying the transform, but before applying the layout translation. |
name | The name of this VisualElement. |
paddingRect | The rectangle of the padding area of the element, in the local space of the element. |
panel | The panel onto which this VisualElement is attached. |
parent | The parent of this VisualElement. |
pickingMode | Determines if this element can be pick during mouseEvents or IPanel.Pick queries. |
resolvedStyle | Returns the VisualElement resolved style values. |
schedule | Retrieves this VisualElement's IVisualElementScheduler |
style | Reference to the style object of this element. |
styleSheets | Returns a VisualElementStyleSheetSet that manipulates style sheets attached to this element. |
this[int] | Retrieves the child element at a specific index. |
tooltip | Text to display inside an information box after the user hovers the element for a small amount of time. This is only supported in the Editor UI. |
transform | Returns a transform object for this VisualElement. ITransform |
usageHints | A combination of hint values that specify high-level intended usage patterns for the VisualElement. This property can only be set when the VisualElement is not yet part of a Panel. Once part of a Panel, this property becomes effectively read-only, and attempts to change it will throw an exception. The specification of proper UsageHints drives the system to make better decisions on how to process or accelerate certain operations based on the anticipated usage pattern. Note that those hints do not affect behavioral or visual results, but only affect the overall performance of the panel and the elements within. It's advised to always consider specifying the proper UsageHints, but keep in mind that some UsageHints might be internally ignored under certain conditions (e.g. due to hardware limitations on the target platform). |
userData | This property can be used to associate application-specific user data with this VisualElement. |
viewDataKey | Used for view data persistence (ie. tree expanded states, scroll position, zoom level). |
visible | Indicates whether or not this element should be rendered. |
visualTreeAssetSource | Stores the asset reference, if the generated element is cloned from a VisualTreeAsset. |
worldBound | Returns a Rect representing the Axis-aligned Bounding Box (AABB) after applying the world transform. |
worldTransform | Returns a matrix that cumulates the following operations (in order): -Local Scaling -Local Rotation -Local Translation -Layout Translation -Parent worldTransform (recursive definition - consider identity when there is no parent) |
HasBubbleUpHandlers | Return true if event handlers for the event propagation BubbleUp phase have been attached on this object. |
HasTrickleDownHandlers | Returns true if event handlers, for the event propagation TrickleDown phase, are attached to this object. |
RegisterCallback | Adds an event handler to the instance. If the event handler has already been registered for the same phase (either TrickleDown or BubbleUp) then this method has no effect. |
UnregisterCallback | Remove callback from the instance. |
Blur | Tell the element to release the focus. |
Focus | Attempt to give the focus to this element. |
Add | Add an element to this element's contentContainer |
AddToClassList | Adds a class to the class list of the element in order to assign styles from USS. Note the class name is case-sensitive. |
BringToFront | Brings this element to the end of its parent children list. The element will be visually in front of any overlapping sibling elements. |
Children | Returns the elements from its contentContainer. |
ClassListContains | Searches for a class in the class list of this element. |
Clear | Remove all child elements from this element's contentContainer |
ClearClassList | Removes all classes from the class list of this element. AddToClassList |
Contains | Checks if this element is an ancestor of the specified child element. |
ContainsPoint | Checks if the specified point intersects with this VisualElement's layout. |
ElementAt | Retrieves the child element at a specific index. |
EnableInClassList | Enables or disables the class with the given name. |
FindAncestorUserData | Searches up the hierarchy of this VisualElement and retrieves stored userData, if any is found. |
FindCommonAncestor | Finds the lowest common ancestor between two VisualElements inside the VisualTree hierarchy. |
GetClasses | Retrieve the classes for this element. |
GetFirstAncestorOfType | Walks up the hierarchy, starting from this element's parent, and returns the first VisualElement of this type |
GetFirstOfType | Walks up the hierarchy, starting from this element, and returns the first VisualElement of this type |
IndexOf | Retrieves the child index of the specified VisualElement. |
Insert | Insert an element into this element's contentContainer |
MarkDirtyRepaint | Triggers a repaint of the VisualElement on the next frame. This method is called internally when a change occurs that requires a repaint, such as when BaseField.value is changed or the text in a Label. If you are implementing a custom control, you can call this method to trigger a repaint when a change occurs that requires a repaint such as when using generateVisualContent to render a mesh and the mesh data has now changed. |
PlaceBehind | Places this element right before the sibling element in their parent children list. If the element and the sibling position overlap, the element will be visually behind of its sibling. |
PlaceInFront | Places this element right after the sibling element in their parent children list. If the element and the sibling position overlap, the element will be visually in front of its sibling. |
Remove | Removes this child from the contentContainerhierarchy. |
RemoveAt | Remove the child element located at this position from this element's contentContainer |
RemoveFromClassList | Removes a class from the class list of the element. |
RemoveFromHierarchy | Removes this element from its parent hierarchy. |
SendEvent | Sends an event to the event handler. |
SendToBack | Sends this element to the beginning of its parent children list. The element will be visually behind any overlapping sibling elements. |
SetEnabled | Changes the VisualElement enabled state. A disabled VisualElement does not receive most events. |
Sort | Reorders child elements from this VisualElement contentContainer. |
ToggleInClassList | Toggles between adding and removing the given class name from the class list. |
ExecuteDefaultAction | Executes logic after the callbacks registered on the event target have executed, unless the event has been marked to prevent its default behaviour. EventBase_1.PreventDefault. |
ExecuteDefaultActionAtTarget | Executes logic after the callbacks registered on the event target have executed, unless the event is marked to prevent its default behaviour. EventBase_1.PreventDefault. |