Version: 2019.3
视觉树
UXML 格式

布局引擎

UIElements 包括一个布局引擎,可根据布局和样式属性定位视觉元素。该布局引擎是 Yoga 开源项目,实现了名为 Flexbox 的 HTML/CSS 布局系统的子集。

要开始使用 Yoga 和 Flexbox,请参阅以下外部资源:

默认情况下,所有视觉元素都是布局的一部分。布局具有以下默认行为:

  • 容器垂直分配其子项。
  • 容器矩形的位置包括其子矩形。其他布局属性可能限制此行为。
  • 带文本的视觉元素在其大小计算中使用文本大小。其他布局属性可能限制此行为。

UIElements 包括标准 UI 控件的内置控件,如按钮、开关、文本字段或标签。这些内置控件具有影响其布局的样式。

下面列出了有关如何使用布局引擎的技巧:

  • 设置 widthheight 来定义元素的大小。

  • 使用 flexGrow 属性(USS 格式为:flex-grow: <value>;)为元素分配灵活的大小。当元素的大小由其同级决定时,flexGrow 属性的值用作加权。

  • flexDirection 属性设置为 row(USS 格式为:flex-direction: row;)以切换到水平布局。

  • 使用相对定位根据元素的原始布局位置来偏移元素。

  • position 属性设置为 absolute 以便相对于父位置矩形来放置某个元素。在这种情况下不会影响其同级和父项的布局。


  • 2018–11–02 页面已修订
视觉树
UXML 格式