GridLayout 属性
控制网格布局管理器行为
网格布局管理器沿一个不可见网格的行和列定位 UI 组件,该网格跨整个图窗或图窗中的一个容器。通过更改网格布局的属性值,您可以修改其行为的某些方面。使用圆点表示法引用特定的对象和属性:
fig = uifigure; g = uigridlayout(fig); g.ColumnWidth = {100,'1x'};
网格
ColumnWidth
— 列宽
{'1x','1x'}
(默认) | 元胞数组 | 字符串数组 | 数值数组
列宽,指定为元胞数组,其中包含 'fit'
、数字或与 'x'
字符配对的数字。您可以指定值的任意组合。元胞数组中的元素数量控制网格中的列数。例如,要创建四列网格,请指定一个 1×4 元胞数组。只有指定的元素类型相同(例如 ["1x" "2x" "1x"]
或 [100 200 50]
)时,列宽才能指定为字符串数组或数值数组。
有三种不同类型的列宽:
适应宽度 - 指定
'fit'
。列宽会自动调整以适应其内容。对于基于文本的组件,'fit'
宽度根据字体属性进行调整,以显示整个文本。对于非基于文本的组件,'fit'
宽度基于组件的默认大小和其他因素。如果您要避免对列宽进行硬编码以适应组件,或如果您的 App 翻译成另一种语言或在不同平台上运行,请使用'fit'
宽度。固定宽度(以像素为单位)- 指定一个数字。列宽固定为您指定的像素数。在父容器调整大小时,列宽不变。
可变宽度 - 指定与
'x'
字符配对的数字(例如,'1x'
)。当父容器调整大小时,列宽会增大或减小。可变宽度列填充等宽列不使用的其余水平空间。与'x'
字符配对的数字是用于在所有可变宽度列中划分其余空间的权重。如果网格只有一个可变宽度列,则它将使用所有其余空间,而不管配对数字设置如何。如果有多个可变宽度列且它们的配对数字相同,则它们会均匀地共享空间。在其他情况下,空间量与配对数字成正比。
例如,{'fit',200,'2x','1x'}
指定第一列的宽度大小可调整以适合其内容,第二列固定为 200 像素,最后两列共享剩余的水平空间。第三列使用的空间是第四列的两倍。
更改布局的某些方面可能会影响此属性的值。例如,向已填满的网格添加更多组件会更改网格的大小以容纳新组件。
在已包含组件的网格布局上更改 ColumnWidth
属性不会更改组件的布局。例如,如果您尝试动态删除包含若干组件的列,则在将这些组件移出该列之前,ColumnWidth
属性不会更改。
RowHeight
— 行高
{'1x','1x'}
(默认) | 元胞数组 | 字符串数组 | 数值数组
行高,指定为元胞数组,其中包含 'fit'
、数字或与 'x'
字符配对的数字。您可以指定值的任意组合。元胞数组中的元素数量控制网格中的行数。例如,要创建一个具有 4 行的网格,请指定一个 1×4 元胞数组。只有指定的元素类型相同(例如 ["1x" "2x" "1x"]
或 [100 200 50]
)时,行高才能指定为字符串数组或数值数组。
行高有三种不同类型:
适应高度 - 指定
'fit'
。行高会自动调整以适应其内容。对于基于文本的组件,'fit'
高度根据字体属性进行调整,以显示整个文本。对于非基于文本的组件,'fit'
高度基于组件的默认大小和其他因素。如果您要避免对行高进行硬编码以适应组件,或如果您的 App 翻译成另一种语言或在不同平台上运行,请使用'fit'
高度。等高(以像素为单位)- 指定一个数字。行高固定为您指定的像素数。在父容器调整大小时,行高不变。
可变高度 - 指定与
'x'
字符配对的数字(例如,'1x'
)。当父容器调整大小时,行高会增大或减小。可变高度行填充等高行不使用的其余垂直空间。与'x'
字符配对的数字是用于在所有可变高度行中划分其余空间的权重。如果网格只有一个可变高度行,则它将使用所有其余空间,而不管配对数字设置如何。如果有多个可变高度行且它们使用相同的配对数字,则它们会均匀地共享空间。在其他情况下,空间量与配对数字成正比。
例如,{'fit',200,'2x','1x'}
指定第一行的高度大小可调以适应其内容,第二行固定为 200 像素,最后两行共享剩余的垂直空间。第三行使用的空间是第四行的两倍。
更改布局的某些方面可能会影响此属性的值。例如,向已填满的网格添加更多组件会更改网格的大小以容纳新组件。
在已包含组件的网格布局上更改 RowHeight
属性不会更改组件的布局。例如,如果您尝试动态删除包含若干组件的行,则在将这些组件移出该行之前,RowHeight
属性不会更改。
ColumnSpacing
— 列间距
10
(默认) | 数字
列间距,指定为网格中相邻列之间的标量像素数。您指定的数字会应用于所有列。
RowSpacing
— 行间距
10
(默认) | 数字
行间距,指定为网格中相邻行之间的标量像素数。您指定的数字会应用于所有行。
Padding
— 填充
[10 10 10 10]
(默认) | [left bottom right top]
围绕网格外围进行填充,指定为 [left bottom right top]
形式的向量。下表描述了向量的元素。
向量元素 | 描述 |
---|---|
left | 父容器的内部左边缘与网格左边缘之间的距离(以像素为单位)。 |
bottom | 父容器的内部下边缘与网格下边缘之间的距离(以像素为单位)。 |
right | 父容器的内部右边缘与网格右边缘之间的距离(以像素为单位)。 |
top | 父容器的内部上边缘与网格上边缘之间的距离(以像素为单位)。父容器的内部上边缘从所有装饰元素(如标题、选项卡标签或菜单栏)下方开始。 |
颜色
BackgroundColor
— 背景色
[0.94 0.94 0.94]
(默认) | RGB 三元组 | 十六进制颜色代码 | 'r'
| 'g'
| 'b'
| ...
背景颜色,指定为 RGB 三元组、十六进制颜色代码或下表中列出的颜色选项之一。
RGB 三元组和十六进制颜色代码对于指定自定义颜色非常有用。
RGB 三元组是包含三个元素的行向量,其元素分别指定颜色中红、绿、蓝分量的强度。强度值必须位于
[0,1]
范围内,例如[0.4 0.6 0.7]
。十六进制颜色代码是字符向量或字符串标量,以井号 (
#
) 开头,后跟三个或六个十六进制数字,范围可以是0
到F
。这些值不区分大小写。因此,颜色代码"#FF8800"
与"#ff8800"
、"#F80"
与"#f80"
是等效的。
此外,还可以按名称指定一些常见的颜色。下表列出了命名颜色选项、等效 RGB 三元组和十六进制颜色代码。
颜色名称 | 短名称 | RGB 三元组 | 十六进制颜色代码 | 外观 |
---|---|---|---|---|
"red" | "r" | [1 0 0] | "#FF0000" | |
"green" | "g" | [0 1 0] | "#00FF00" | |
"blue" | "b" | [0 0 1] | "#0000FF" | |
"cyan" | "c" | [0 1 1] | "#00FFFF" | |
"magenta" | "m" | [1 0 1] | "#FF00FF" | |
"yellow" | "y" | [1 1 0] | "#FFFF00" | |
"black" | "k" | [0 0 0] | "#000000" | |
"white" | "w" | [1 1 1] | "#FFFFFF" |
以下是 MATLAB® 在许多类型的绘图中使用的默认颜色的 RGB 三元组和十六进制颜色代码。
RGB 三元组 | 十六进制颜色代码 | 外观 |
---|---|---|
[0 0.4470 0.7410] | "#0072BD" | |
[0.8500 0.3250 0.0980] | "#D95319" | |
[0.9290 0.6940 0.1250] | "#EDB120" | |
[0.4940 0.1840 0.5560] | "#7E2F8E" | |
[0.4660 0.6740 0.1880] | "#77AC30" | |
[0.3010 0.7450 0.9330] | "#4DBEEE" | |
[0.6350 0.0780 0.1840] | "#A2142F" |
交互性
Visible
— 子级的可见性
'on'
(默认) | on/off 逻辑值
子级的可见性,指定为 'on'
或 'off'
,或者指定为数值或逻辑值 1
(true
) 或 0
(false
)。值 'on'
等效于 true
,'off'
等效于 false
。因此,您可以使用此属性的值作为逻辑值。该值存储为 matlab.lang.OnOffSwitchState
类型的 on/off 逻辑值。
将此属性设置为 'off'
可隐藏网格中的所有子组件及其后代后代。无论 Visible
属性的值如何,都隐藏后代及其后代后代。隐藏组件后,即使它们未显示在 App 中,您也可以获取并设置其属性。
将此属性设置为 'on'
时,仅当其 Visible
属性也设置为 'on'
时,后代及其后代后代才可见。
在网格上设置 Visible
属性不会更改其后代后代的 Visible
属性的值。
Scrollable
— 滚动能力
'off'
(默认) | on/off 逻辑值
滚动能力,指定为 'off'
或 'on'
,或者指定为数值或逻辑值 1
(true
) 或 0
(false
)。值 'on'
等效于 true
,'off'
等效于 false
。因此,您可以使用此属性的值作为逻辑值。该值存储为 matlab.lang.OnOffSwitchState
类型的 on/off 逻辑值。
将此属性设置为 'on'
可以在网格布局管理器内滚动。要进行滚动,还必须满足以下条件:
为网格布局管理器的
'RowHeight'
属性指定的值的总和必须大于父容器的高度。为网格布局管理器的
'ColumnWidth'
属性指定的值的总和必须大于父容器的宽度。网格布局管理器中有至少一行或一列必须设置为固定的像素高度或宽度。
网格布局管理器必须包含组件。
某些类型的图和坐标区不支持可滚动容器。但是,您可以将图或坐标区放在不可滚动的面板中,然后将该面板放在可滚动的容器中。有关详细信息,请参阅在 App 设计工具中显示图形。
ContextMenu
— 上下文菜单
空 GraphicsPlaceholder
数组 (默认) | ContextMenu
对象
上下文菜单,指定为 ContextMenu
对象。使用此属性可在您右键点击网格布局管理器时显示上下文菜单。使用 uicontextmenu
函数创建上下文菜单。
位置
Position
— 网格布局管理器的位置和大小
[left bottom width height]
此 属性 为只读。
网格布局管理器的位置和大小,以 [left bottom width height]
形式的四元素向量形式返回。此表介绍该向量中的每个元素。
元素 | 描述 |
---|---|
left | 父容器的内部左边缘与网格布局管理器的左边缘之间的距离 |
bottom | 父容器的内部下边缘与网格布局管理器的下边缘之间的距离 |
width | 网格布局管理器左边缘和右边缘之间的距离 |
height | 网格布局管理器下边缘和上边缘之间的距离 |
所有测量值都以像素为单位。
此图显示由具有一些 UI 组件的网格布局管理器的 Position
值(橙色实线)和 InnerPosition
值(蓝色虚线)定义的区域。
InnerPosition
— 网格布局管理器的位置和大小,不包括填充
[left bottom width height]
此 属性 为只读。
网格布局管理器的位置和大小,不包括填充,以 [left bottom width height]
四元素向量形式返回。此表介绍该向量中的每个元素。
元素 | 描述 |
---|---|
left | 父容器的内部左边缘与网格布局管理器中可放置组件的区域的内部左边缘之间的距离 |
bottom | 父容器的内部下边缘与网格布局管理器中可放置组件的区域的内部下边缘之间的距离 |
width | 网格布局管理器中可放置组件的区域的内部左边缘和内部右边缘之间的距离 |
height | 网格布局管理器中可放置组件的区域的内部下边缘和内部上边缘之间的距离 |
所有测量值都以像素为单位。
InnerPosition
值受 Padding
属性的值影响。如果 Padding
为 [0 0 0 0]
,则 InnerPosition
属性值与 Position
属性值相同。
此图显示由具有一些 UI 组件的网格布局管理器的 Position
值(橙色实线)和 InnerPosition
值(蓝色虚线)定义的区域。
OuterPosition
— 网格布局管理器的位置和大小
[left bottom width height]
此 属性 为只读。
网格布局管理器的位置和大小,以 [left bottom width height]
形式的四元素向量形式返回。所有测量值都以像素为单位。
此属性值等同于网格布局管理器的 Position
属性值。
Layout
— 布局选项
空 LayoutOptions
数组 (默认) | GridLayoutOptions
对象
布局选项,指定为 GridLayoutOptions
对象。此属性指定嵌套网格布局容器的选项。如果网格布局不是另一个网格布局容器的子级(例如,它是图窗或面板的子级),则此属性为空且不起作用。但是,如果网格布局是另一个网格布局的子级,则可以通过设置 GridLayoutOptions
对象上的 Row
和 Column
属性,将该子网格放在父网格的所需行和列中。
例如,以下代码在 grid1
的第三行第二列上嵌套 grid2
。
grid1 = uigridlayout([4 3]); grid2 = uigridlayout(grid1); grid2.Layout.Row = 3; grid2.Layout.Column = 2;
Row
或 Column
属性指定为二元素向量。例如,此命令使 grid2
跨 grid1
的第 2
列到第 3
列:grid2.Layout.Column = [2 3];
回调
CreateFcn
— 创建函数
''
(默认) | 函数句柄 | 元胞数组 | 字符向量
对象创建函数,指定为下列值之一:
函数句柄。
第一个元素是函数句柄的元胞数组。元胞数组中的后续元素是传递到回调函数的参量。
包含有效 MATLAB 表达式的字符向量(不推荐)。MATLAB 在基础工作区计算此表达式。
有关将回调指定为函数句柄、元胞数组或字符向量的详细信息,请参阅App 设计工具中的回调。
此属性指定要在 MATLAB 创建对象时执行的回调函数。MATLAB 将在执行 CreateFcn
回调之前初始化所有属性值。如果不指定 CreateFcn
属性,则 MATLAB 执行默认的创建函数。
对现有组件设置 CreateFcn
属性没有任何作用。
如果将此属性指定为函数句柄或元胞数组,则可以使用回调函数的第一个参量访问正在创建的对象。否则,使用 gcbo
函数访问该对象。
DeleteFcn
— 删除函数
''
(默认) | 函数句柄 | 元胞数组 | 字符向量
对象删除函数,指定为下列值之一:
函数句柄。
第一个元素是函数句柄的元胞数组。元胞数组中的后续元素是传递到回调函数的参量。
包含有效 MATLAB 表达式的字符向量(不推荐)。MATLAB 在基础工作区计算此表达式。
有关将回调指定为函数句柄、元胞数组或字符向量的详细信息,请参阅App 设计工具中的回调。
此属性指定在 MATLAB 删除对象时要执行的回调函数。MATLAB 在销毁对象的属性之前执行 DeleteFcn
回调。如果不指定 DeleteFcn
属性,则 MATLAB 执行默认的删除函数。
如果将此属性指定为函数句柄或元胞数组,则可以使用回调函数的第一个参量访问要删除的对象。否则,使用 gcbo
函数访问该对象。
回调执行控件
Interruptible
— 回调中断
'on'
(默认) | on/off 逻辑值
回调中断,指定为 'on'
或 'off'
,或者指定为数值或逻辑值 1
(true
) 或 0
(false
)。值 'on'
等效于 true
,'off'
等效于 false
。因此,您可以使用此属性的值作为逻辑值。该值存储为 matlab.lang.OnOffSwitchState
类型的 on/off 逻辑值。
此属性确定是否可以中断运行中回调。有以下两种回调状态要考虑:
运行中回调是当前正在执行的回调。
中断回调是试图中断运行中回调的回调。
每次执行处理回调队列的命令时,MATLAB 都会确定回调中断行为。这些命令包括 drawnow
、figure
、uifigure
、getframe
、waitfor
和 pause
。
如果运行中回调不包含上述命令之一,则不会发生中断。MATLAB 首先完成执行运行中回调,然后执行中断回调。
如果运行中回调确实包含上述命令之一,则由运行中回调所属对象的 Interruptible
属性来确定是否发生中断:
如果
Interruptible
的值为'off'
,则不会发生中断。此时,由中断回调所属对象的BusyAction
属性确定中断回调是被丢弃还是添加到回调队列中。如果
Interruptible
的值为'on'
,则发生中断。下次 MATLAB 处理回调队列时,它会停止运行中回调的执行,并执行中断回调。在中断回调完成后,MATLAB 将继续执行运行中回调。
注意
回调的中断和执行在以下情况下会有不同的表现:
如果中断回调是
DeleteFcn
、CloseRequestFcn
或SizeChangedFcn
回调,则无论是否存在Interruptible
属性值都会发生中断。如果运行中回调当前正在执行
waitfor
函数,则无论是否存在Interruptible
属性值都会发生中断。如果中断回调由
Timer
对象所有,则回调将根据调度执行,而不考虑Interruptible
属性值。
BusyAction
— 回调排队
'queue'
(默认) | 'cancel'
回调排队,指定为 'queue'
或 'cancel'
。BusyAction
属性决定 MATLAB 如何处理中断回调的执行。有以下两种回调状态要考虑:
运行中回调是当前正在执行的回调。
中断回调是试图中断运行中回调的回调。
BusyAction
属性仅在同时满足以下两个条件时才确定回调排队行为:
在这些情况下,由中断回调所属对象的 BusyAction
属性确定 MATLAB 如何处理中断回调。以下是 BusyAction
属性的可能值:
'queue'
- 将中断回调放入队列中,以便在运行中回调执行完毕后进行处理。'cancel'
- 不执行中断回调。
BeingDeleted
— 删除状态
on/off 逻辑值
此 属性 为只读。
删除状态,以 matlab.lang.OnOffSwitchState
类型的 on/off 逻辑值形式返回。
当 DeleteFcn
回调开始执行时,MATLAB 会将 BeingDeleted
属性设置为 'on'
。BeingDeleted
属性将一直保持 'on'
设置状态,直到组件对象不再存在为止。
在查询或修改对象之前,请先检查其 BeingDeleted
属性的值,以确认它不是待删除项。
父级/子级
Parent
— 父容器
Figure
对象 (默认) | Panel
对象 | Tab
对象 | ButtonGroup
对象 | GridLayout
对象
父容器,指定为使用 uifigure
函数创建的 Figure
对象或其子容器之一:Tab
、Panel
、ButtonGroup
或 GridLayout
。如果未指定容器,MATLAB 将调用 uifigure
函数以创建一个新 Figure
对象来充当父容器。
Children
— 子级
空 GraphicsPlaceholderArray
| 由 UI 组件对象组成的数组
子级,以 UI 组件对象数组的形式返回。使用此属性可查看子级列表,或重新排列子级顺序(通过将该属性设置为其自身的置换来完成)。您不能使用此属性添加或删除子级。要向该列表中添加子级,请设置子 UI 组件的 Parent
属性。
对子级重新排序不会影响网格中组件的位置。要更改网格中组件的位置,请设置其 Layout
属性。
HandleVisibility
— 对象句柄的可见性
'on'
(默认) | 'callback'
| 'off'
对象句柄的可见性,指定为 'on'
、'callback'
或 'off'
。
此属性控制对象在其父级的子级列表中的可见性。当对象未显示在其父级的子级列表中时,通过搜索对象层次结构或查询属性来获取对象的函数不会返回该对象。这些函数包括 get
、findobj
、clf
和 close
。对象即使在不可见时也有效。如果可以访问某个对象,则可以设置和获取其属性,并将其传递给针对对象进行运算的任意函数。
HandleVisibility 值 | 描述 |
---|---|
'on' | 对象始终可见。 |
'callback' | 对象对于回调或回调调用的函数可见,但对于命令行调用的函数不可见。此选项阻止通过命令行访问对象,但允许回调函数访问它。 |
'off' | 对象始终不可见。该选项用于防止另一函数无意中对 UI 进行更改。将 HandleVisibility 设置为 'off' 可在执行该函数时暂时隐藏对象。 |
标识符
Type
— 图形对象的类型
'uigridlayout'
此 属性 为只读。
图形对象的类型,以 'uigridlayout'
形式返回。
Tag
— 对象标识符
''
(默认) | 字符向量 | 字符串标量
对象标识符,指定为字符向量或字符串标量。您可以指定唯一的 Tag
值作为对象的标识符。如果需要访问您代码中其他位置的对象,可以使用 findobj
函数基于 Tag
值搜索对象。
UserData
— 用户数据
[]
(默认) | 数组
用户数据,指定为任何 MATLAB 数组。例如,您可以指定标量、向量、矩阵、元胞数组、字符数组、表或结构体。使用此属性存储对象上的任意数据。
如果您在 App 设计工具中工作,请在该 App 中创建公共或私有属性以共享数据,而不是使用 UserData
属性。有关详细信息,请参阅在用 App 设计工具创建的 App 内共享数据。
版本历史记录
在 R2018b 中推出R2022b: 访问网格布局管理器的大小和位置
使用网格布局管理器的 Position
、InnerPosition
和 OuterPosition
属性来访问其大小和位置。所有属性都为只读属性。
R2022a: 表、列表框和图像 UI 组件调整大小以适应内容
现在,行高或列宽为 'fit'
的网格布局管理器可以调整大小以适应表、列表框和图像 UI 组件的内容。
在以前的版本中,当行或列包含表、列表框或图像 UI 组件时,行高或列宽为 'fit'
的网格布局管理器会缩放到固定大小。
表 UI 组件 - 在以前版本中行高和列宽调整为 300 像素大小。
列表框 UI 组件 - 在以前版本中行高调整为最多显示四个项目。根据您的设置,显示四个项目的确切像素值可能会有所不同。
图像 UI 组件 - 在以前版本中行高和列宽调整为 100 像素大小。
在 R2022a 之前的版本中,要按其原来大小显示表、列表框或图像,请将 GridLayout
对象的 RowHeight
和 ColumnWidth
属性的对应元素设置为其各自的固定大小。
R2020b: GridLayout
背景不再透明
从 R2020b 开始,GridLayout
对象具有 BackgroundColor
属性,不再透明。默认背景颜色是所有容器(例如,图窗和面板)的默认颜色。
如果您的 App 在容器中的一个网格布局具有非默认颜色,则将 GridLayout
对象的 BackgroundColor
属性设置为该颜色以保留 App 的外观。
如果您的 App 在网格后面有您要保持可见的对象,请通过使这些对象成为 GridLayout
的子级,将这些对象移至网格中。
MATLAB 命令
您点击的链接对应于以下 MATLAB 命令:
请在 MATLAB 命令行窗口中直接输入以执行命令。Web 浏览器不支持 MATLAB 命令。
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)