class in UnityEngine.UIElements
/
Inherits from:UIElements.VisualElement
/
Implemented in:UnityEngine.UIElementsModule
Displays its contents inside a scrollable frame. For more information, refer to the ScrollView user manual page.
Both the ListView and the TreeView contain a ScrollView that you can manipulate through C# code.
This example creates a ScrollView that contains multiple labels and uses a Button to scroll to a selected label.
using UnityEngine; using UnityEngine.UIElements;
[RequireComponent(typeof(UIDocument))] public class ScrollViewScrollToExample : MonoBehaviour { // To use this example in runtime, add a UIDocument component to your Scene and attach a UXML file to the UIDocument component. // The UXML file can be empty. public UIDocument uiDocument; public int numberOfPotions = 100; public int scrollToButton = 50;
Label[] labels;
void OnEnable() { var scrollView = new ScrollView { name = "MyPotionsInventory" }; var inventoryColor = new Color(0.65f, 0.3f, 0.2f, 1f);
// Create a list of labels representing potions, with a special label for the potion we want to scroll to. labels = new Label[numberOfPotions]; for (int i = 0; i < numberOfPotions; i++) { var label = new Label { text = " Unnamed Potion #" + (i) }; label.style.backgroundColor = inventoryColor;
if (scrollToButton == i) { label.text = "Very Important Potion"; label.style.color = Color.yellow; }
labels[i] = label; scrollView.Add(label); }
// Add a title for the list and make it noticeable. var title = new Label { text = "Potions Inventory" }; title.style.unityFontStyleAndWeight = FontStyle.Bold; title.style.fontSize = 20; title.style.color = inventoryColor; title.style.unityTextAlign = TextAnchor.MiddleCenter;
var button = new Button { text = "Click to locate the Very Important Potion in the inventory" }; button.clicked += DoScrollTo;
uiDocument.rootVisualElement.Add(title); uiDocument.rootVisualElement.Add(button); uiDocument.rootVisualElement.Add(scrollView); }
void DoScrollTo() { var scrollView = uiDocument.rootVisualElement.Q<ScrollView>("MyPotionsInventory"); scrollView.ScrollTo(labels[scrollToButton]); } }
contentAndVerticalScrollUssClassName | USS class name of content elements in elements of this type. |
contentUssClassName | USS class name of content elements in elements of this type. |
horizontalVariantContentUssClassName | USS class name that's added when the ContentContainer is in horizontal mode. ScrollViewMode.Horizontal |
horizontalVariantUssClassName | USS class name that's added when the ScrollView is in horizontal mode. ScrollViewMode.Horizontal |
horizontalVariantViewportUssClassName | USS class name that's added when the Viewport is in horizontal mode. ScrollViewMode.Horizontal |
hScrollerUssClassName | USS class name of horizontal scrollers in elements of this type. |
ussClassName | USS class name of elements of this type. |
verticalHorizontalVariantContentUssClassName | USS class name that's added when the ContentContainer is in both horizontal and vertical mode. ScrollViewMode.VerticalAndHorizontal |
verticalHorizontalVariantUssClassName | USS class name that's added when the ScrollView is in both horizontal and vertical mode. ScrollViewMode.VerticalAndHorizontal |
verticalHorizontalVariantViewportUssClassName | USS class name that's added when the Viewport is in both horizontal and vertical mode. ScrollViewMode.VerticalAndHorizontal |
verticalVariantContentUssClassName | USS class name that's added when the ContentContainer is in vertical mode. ScrollViewMode.Vertical |
verticalVariantUssClassName | USS class name that's added when the ScrollView is in vertical mode. ScrollViewMode.Vertical |
verticalVariantViewportUssClassName | USS class name that's added when the Viewport is in vertical mode. ScrollViewMode.Vertical |
viewportUssClassName | USS class name of viewport elements in elements of this type. |
vScrollerUssClassName | USS class name of vertical scrollers in elements of this type. |
contentContainer | Contains full content, potentially partially visible. |
contentViewport | Represents the visible part of contentContainer. |
elasticAnimationIntervalMs | The minimum amount of time, in milliseconds, between executions of elastic spring animation. |
elasticity | The amount of elasticity to use when a user tries to scroll past the boundaries of the scroll view. |
horizontalPageSize | This property controls the speed of the horizontal scrolling when using a keyboard or the on-screen scrollbar buttons (arrows and handle), based on the size of the page. |
horizontalScroller | Horizontal scrollbar. |
horizontalScrollerVisibility | Specifies whether the horizontal scroll bar is visible. |
mode | Controls how the ScrollView allows the user to scroll the contents. ScrollViewMode |
mouseWheelScrollSize | This property controls the scrolling speed only when using a mouse scroll wheel, based on the size of the page. |
nestedInteractionKind | The behavior to use when scrolling reaches limits of a nested ScrollView. |
scrollDecelerationRate | Controls the rate at which the scrolling movement slows after a user scrolls using a touch interaction. |
scrollOffset | The current scrolling position. |
touchScrollBehavior | The behavior to use when a user tries to scroll past the boundaries of the ScrollView content using a touch interaction. |
verticalPageSize | This property controls the speed of the vertical scrolling when using a keyboard or the on-screen scrollbar buttons (arrows and handle), based on the size of the page. |
verticalScroller | Vertical Scrollbar. |
verticalScrollerVisibility | Specifies whether the vertical scroll bar is visible. |
ScrollView | Constructor. |
ScrollTo | Scroll to a specific child element. |
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 | If false, this prevents the element from being focused. |
focusController | Return the focus controller for this element. |
tabIndex | An integer used to sort focusable elements in the focus ring. Must be greater than or equal to zero. |
childCount | Number of child elements in this object's contentContainer. |
contentContainer | Logical container where child elements are added. If a child is added to this element, the child is added to this element's content container instead. |
contentRect | The rectangle of the content area of the element, in the local space of the element. (Read Only) |
customStyle | The custom style properties accessor of a VisualElement (Read Only). |
dataSource | Assigns a data source to this VisualElement which overrides any inherited data source. This data source is inherited by all children. |
dataSourcePath | Path from the data source to the value. |
dataSourceType | The possible type of data source assignable to this VisualElement. This information is only used by the UI Builder as a hint to provide some completion to the data source path field when the effective data source cannot be specified at design time. |
disablePlayModeTint | Play-mode tint is applied by default unless this is set to true. It's applied hierarchically to this VisualElement and to all its children that exist on an editor panel. |
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 | Delegate function to generate the visual content of a visual element. |
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. (Read Only) |
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 the target of pointer events or picked by IPanel.Pick queries. |
resolvedStyle | The final rendered style values of a visual element, as it's rendered in the current frame.(Read Only) |
scaledPixelsPerPoint | Return the resulting scaling from the panel that considers the screen DPI and the customizable scaling factor, but not the transform scale of the element and its ancestors. See Panel.scaledPixelsPerPoint. This should only be called on elements that are part of a panel. |
schedule | Retrieves the IVisualElementScheduler associated to this VisualElement. Use it to enqueue actions. |
style | Sets the style values on a VisualElement. |
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 styles 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, such as tree expanded states, scroll position, or 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 to 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. |
RegisterCallbackOnce | Adds an event handler to the instance. The event handler is automatically unregistered after it has been invoked exactly once. |
UnregisterCallback | Remove callback from the instance. |
Blur | Tell the element to release the focus. |
Focus | Attempt to give the focus to this element. |
Add | Adds an element to the contentContainer of this element. |
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 |
ClearBinding | Removes a binding from the element. |
ClearBindings | Removes all bindings from the element. |
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. |
GetBinding | Gets the binding instance for the provided targeted property. |
GetBindingInfos | Gets information on all the bindings of the current element. |
GetClasses | Retrieve the classes for this element. |
GetDataSourceContext | Queries the dataSource and dataSourcePath of a binding object. |
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 |
GetHierarchicalDataSourceContext | Queries the dataSource and dataSourcePath inherited from the hierarchy. |
HasBinding | Allows to know if a target property has a binding associated to it. |
IndexOf | Retrieves the child index of the specified VisualElement. |
Insert | Insert an element into this element's contentContainer |
MarkDirtyRepaint | Marks that the VisualElement requires a repaint. |
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 hierarchy of its contentContainer. |
RemoveAt | Removes a child, at the provided index, from the list of children of the current element. |
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. |
SetBinding | Assigns a binding between a target and a source. |
SetEnabled | Changes the VisualElement enabled state. A disabled visual element 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. |
TryGetBinding | Gets the binding instance for the provided targeted property. |
TryGetDataSourceContext | Queries the dataSource and dataSourcePath of a binding object. |
TryGetLastBindingToSourceResult | Returns the last BindingResult of a binding object from the UI to the data source. |
TryGetLastBindingToUIResult | Returns the last BindingResult of a binding object from the data source to the UI. |
HandleEventBubbleUp | Executes logic on this element during the BubbleUp phase, immediately before this element's BubbleUp callbacks. Calling StopPropagation will prevent further invocations of this method along the propagation path. |
HandleEventTrickleDown | Executes logic on this element during the TrickleDown phase, immediately after this element's TrickleDown callbacks. Calling StopPropagation will prevent further invocations of this method along the propagation path. |
NotifyPropertyChanged | Informs the data binding system that a property of a control has changed. |