主要内容

ToggleSwitch属性

控制拨动开关的外观和行为

切换开关是指示逻辑状态的UI组件。属性控制拨动开关的外观和行为。使用点表示法来指代特定的对象和属性。

图= ufigfig;S = uiswitch(fig,'toggle');s.Items ={'冷','热'};

开关

全部展开

对象的元素指定的项目ItemsData数组。默认情况下,价值第一个元素在里面吗项目

指定价值作为项目将开关移动到与该元素匹配的位置。如果ItemsData难道不是空的吗价值必须设置为的元素ItemsData,开关将移动到相关位置。

开关选项,指定为字符向量的单元格数组、字符串数组或1——- - - - - -2分类数组。如果指定一个数组,它必须有两个元素。允许重复的元素。如果将此属性指定为分类数组,MATLAB®使用数组中的值,而不是完整的类别集。

的每个元素关联的数据项目属性值,指定为1 × 2的数值数组或1 × 2的单元格数组。允许重复的元素。

例如,如果您设置项目价值{“冻结”、“沸腾”},然后你可以设置ItemsData对应的温度,单位为摄氏度,[0100].的ItemsData值对应用程序用户不可见。

例子:{“一”“两个”}

例子:20 [10]

开关的方向,指定为“垂直”“水平”

字体

全部展开

字体名称,指定为系统支持的字体名称。万博1manbetx默认字体取决于特定的操作系统和地区。

如果指定的字体不可用,那么MATLAB将在应用程序运行的系统中使用可用字体中的最佳匹配。

例子:“天线”

字体大小,指定为正数。测量单位是像素。默认字体大小取决于特定的操作系统和地区。

例子:14

字体重量,指定为以下值之一:

  • “正常”-由特定字体定义的默认权重

  • “大胆”-较粗的字符轮廓“正常”

并非所有字体都有粗体字体权重。对于不需要的字体,指定“大胆”结果在正常字体权重。

字体角度,指定为“正常”“斜体”.不是所有字体都有斜体字体角度。对于不需要的字体,指定“斜体”结果在正常字体角度。

字体颜色,指定为RGB三元组、十六进制颜色编码或表中列出的选项之一。

RGB三联色和十六进制色码用于指定自定义颜色。

  • RGB三元组是一个三元素行向量,其元素指定颜色的红、绿、蓝成分的强度。强度必须在这个范围内[0, 1];例如,[0.4 0.6 0.7]

  • 十六进制颜色码是字符向量或以散列符号()之后是三个或六个十六进制数字,取值范围从0F.这些值不区分大小写。因此,颜色编码“# FF8800”“# ff8800”“# F80”,“# f80”是等价的。

或者,您也可以通过名称指定一些常用颜色。该表列出了已命名的颜色选项、等效的RGB三组和十六进制颜色编码。

颜色名称 短名称 RGB值 十六进制色码 外观
“红色” “r” [10 0 0] “# FF0000”

样品的颜色为红色

“绿色” ‘g’ [0 1 0] “# 00 ff00”

样品的颜色为绿色

“蓝” “b” [0 0 1] “# 0000 ff”

蓝色的样品

“青色” “c” [0 1 1] “# 00飞行符”

样品的颜色为青色

“红色” “米” [10 0 1] “#就”

洋红色的样品

“黄色” “y” [1 1 0] “# FFFF00”

样品的颜色为黄色

“黑” “k” [0 0 0] # 000000的

样品的颜色为黑色

“白色” ' w ' [1,1 1] “# FFFFFF”

样品的颜色为白色

下面是MATLAB在许多类型的图中使用的默认颜色的RGB三组和十六进制颜色代码。

RGB值 十六进制色码 外观
[0 0.4470 0.7410] “# 0072 bd”

RGB三联体样本[0 0.4470 0.7410],显示为深蓝色

[0.8500 0.3250 0.0980] “# D95319”

RGB三联体样本[0.8500 0.3250 0.0980],呈暗橙色

[0.9290 0.6940 0.1250] “# EDB120”

RGB三联体样品[0.9290 0.6940 0.1250],呈暗黄色

[0.4940 0.1840 0.5560] “# 7 e2f8e”

RGB三联体样本[0.4940 0.1840 0.5560],呈深紫色

[0.4660 0.6740 0.1880] “# 77 ac30”

RGB三联体样本[0.4660 0.6740 0.1880],呈现中绿色

[0.3010 0.7450 0.9330] “# 4 dbeee”

RGB三联体样本[0.3010 0.7450 0.9330],显示为浅蓝色

[0.6350 0.0780 0.1840] “# A2142F”

RGB三联体样品[0.6350 0.0780 0.1840],呈暗红色

交互性

全部展开

可见状态,指定为“上”“关闭”,或作为数字或逻辑1真正的)或0).的值“上”等于真正的,“关闭”等于.因此,您可以将此属性的值用作逻辑值。该值存储为类型的开/关逻辑值matlab.lang.OnOffSwitchState

  • “上”—显示对象。

  • “关闭”—隐藏对象,不删除对象。您仍然可以访问不可见UI组件的属性。

要使您的应用程序启动更快,请设置可见财产“关闭”用于所有不需要在启动时出现的UI组件。

操作状态,指定为“上”“关闭”,或作为数字或逻辑1真正的)或0).的值“上”等于真正的,“关闭”等于.因此,您可以将此属性的值用作逻辑值。该值存储为类型的开/关逻辑值matlab.lang.OnOffSwitchState

  • 如果将此属性设置为“上”,应用程序用户可以与组件交互。

  • 如果将此属性设置为“关闭”,该组件显示为灰色,表示应用程序用户无法与它交互,也不会触发回调。

工具提示,指定为字符向量、字符向量的单元格数组、字符串数组或一维分类数组。使用此属性可在用户在运行时将指针悬停在组件上时显示一条消息。即使禁用了组件,工具提示也会显示出来。若要显示多行文本,请指定字符向量的单元格数组或字符串数组。数组中的每个元素都成为单独的一行文本。如果将此属性指定为分类数组,MATLAB将使用数组中的值,而不是完整的类别集。

上下文菜单,指定为快捷菜单对象创建的。uicontextmenu函数。使用此属性可在右键单击组件时显示上下文菜单。

位置

全部展开

开关的位置和大小,不包括状态标记和标签,指定为矢量,[左底宽高].这个表描述了向量中的每个元素。

元素 描述
从父容器的左内缘到开关的左外缘的距离
从父容器的内底边到开关的外底边的距离
宽度 开关左右外边缘之间的距离,不包括标签
高度 开关的上下外边缘之间的距离,不包括标签

所有的测量都以像素为单位。

位置值相对于可拉的区域父容器的。可绘制区域是容器边界内的区域,不包括菜单栏或标题等装饰所占的区域。

例子:[100 200 40 90 .

开关的内部位置和大小,不包括状态标记和标签,指定为矢量,[左底宽高].位置值相对于父容器。所有的测量都以像素为单位。属性值与位置财产。

此属性是只读的。

开关的外部位置和大小,包括状态标记和标签,指定为矢量,[左底宽高].位置值相对于父容器。所有的测量都以像素为单位。

布局选项,指定为GridLayoutOptions对象。此属性为网格布局容器的子组件指定选项。如果组件不是网格布局容器的子组件(例如,它是图形或面板的子组件),则此属性为空,没有任何效果。但是,如果组件是网格布局容器的子组件,则可以将组件放置在网格的所需行和列中而且的属性GridLayoutOptions对象。

例如,这段代码将拨动开关放在其父网格的第三行和第二列中。

G = uigridlayout([4 3]);S = uiswitch(g,“切换”);s.Layout.Row = 3;s.Layout.Column = 2;

若要使开关跨越多行或多列,请指定属性作为双元素向量。例如,该开关跨越列2通过3.

s.Layout.Column = [2 3];

回调

全部展开

值更改回调,指定为以下值之一:

  • 函数句柄。

  • 单元格数组,其中第一个元素是函数句柄。单元格数组中的后续元素是传递给回调函数的参数。

  • 包含有效MATLAB表达式的字符向量(不推荐)。MATLAB在基本工作区中计算这个表达式。

当应用程序中交换机的状态发生变化时,此回调将执行。当用户执行以下任何一种操作时,交换机的状态将发生变化:

  • 单击并释放交换机上的任何位置的鼠标按钮(包括状态标签)

  • 单击交换机,拖动,然后释放鼠标按钮,同时仍然在交换机上。

回调函数不会执行价值属性以编程方式更改。

这个回调函数可以访问关于用户与交换机交互的特定信息。MATLAB将此信息传递到ValueChangedData对象作为回调函数的第二个参数。在App Designer中,这个参数被调用事件.可以使用点表示法查询对象属性。例如,事件。PreviousValue返回开关的前一个值。的ValueChangedData对象不能用于指定为字符向量的回调函数。

的属性ValueChangedData对象。

财产 价值
价值 应用程序用户最近一次与开关交互后的开关值
PreviousValue 在应用程序用户最近一次与它交互之前的开关值
执行回调的组件
EventName “ValueChanged”

有关编写回调函数的更多信息,请参见应用程序设计器中的回调

对象创建函数,指定为以下值之一:

  • 函数处理。

  • 单元格数组,其中第一个元素是函数句柄。单元格数组中的后续元素是传递给回调函数的参数。

  • 字符向量包含有效的MATLAB表达式(不推荐)。MATLAB在基本工作区中计算这个表达式。

有关将回调指定为函数句柄、单元格数组或字符向量的详细信息,请参见应用程序设计器中的回调

此属性指定MATLAB创建对象时要执行的回调函数。函数执行之前,MATLAB初始化所有属性值CreateFcn回调。如果不指定CreateFcn属性,然后MATLAB执行一个默认的创建函数。

设置CreateFcn属性对现有组件没有影响。

如果将此属性指定为函数句柄或单元格数组,则可以使用回调函数的第一个参数访问正在创建的对象。否则,使用gcbo函数来访问对象。

对象删除函数,指定为以下值之一:

  • 函数处理。

  • 单元格数组,其中第一个元素是函数句柄。单元格数组中的后续元素是传递给回调函数的参数。

  • 字符向量包含有效的MATLAB表达式(不推荐)。MATLAB在基本工作区中计算这个表达式。

有关将回调指定为函数句柄、单元格数组或字符向量的详细信息,请参见应用程序设计器中的回调

此属性指定在MATLAB删除对象时执行的回调函数。MATLAB执行DeleteFcn在销毁对象的属性之前调用。如果不指定DeleteFcn属性,然后MATLAB执行一个默认删除函数。

如果将此属性指定为函数句柄或单元格数组,则可以使用回调函数的第一个参数访问正在删除的对象。否则,使用gcbo函数来访问对象。

回调执行控制

全部展开

回调中断,指定为“上”“关闭”,或作为数字或逻辑1真正的)或0).的值“上”等于真正的,“关闭”等于.因此,您可以将此属性的值用作逻辑值。该值存储为类型的开/关逻辑值matlab.lang.OnOffSwitchState

此属性确定正在运行的回调是否可以中断。有两种回调状态需要考虑:

  • 运行回调是当前正在执行的回调。

  • 打断回调是一个试图中断正在运行的回调的回调。

MATLAB在执行处理回调队列的命令时确定回调中断行为。这些命令包括drawnow数字uifiguregetframe等待,暂停

如果正在运行的回调不包含这些命令中的任何一个,则不会发生中断。MATLAB首先完成运行回调的执行,然后执行中断回调。

如果正在运行的回调函数包含这些命令中的一个,则可中断属性的值确定中断是否发生:

  • 的值可中断“关闭”,则不会出现中断。相反,BusyAction属性的属性确定中断回调是被丢弃还是被添加到回调队列。

  • 的值可中断“上”,则中断发生。下一次MATLAB处理回调队列时,它将停止正在运行的回调的执行,并执行中断的回调。在中断回调完成后,MATLAB继续执行正在运行的回调。

请注意

回调中断和执行在以下情况下表现不同:

  • 如果中断回调函数是DeleteFcnCloseRequestFcn,或SizeChangedFcn回调函数,则中断发生而不管可中断属性值。

  • 如果正在运行的回调函数当前正在执行等待函数,则中断发生而不管可中断属性值。

  • 如果中断回调函数属于计时器对象,则回调函数将根据调度执行,而不考虑可中断属性值。

请注意

当中断发生时,MATLAB不会保存属性或显示的状态。方法返回的对象gcagcf命令可能在执行另一个回调时更改。

回调队列,指定为“队列”“取消”.的BusyAction属性决定了MATLAB如何处理中断回调的执行。有两种回调状态需要考虑:

  • 运行回调是当前正在执行的回调。

  • 打断回调是一个试图中断正在运行的回调的回调。

BusyAction属性仅在满足以下两个条件时确定回调队列行为:

在这些条件下,BusyAction拥有中断回调对象的属性决定了MATLAB如何处理中断回调。这些是可能的值BusyAction属性:

  • “队列”—在正在运行的回调完成执行后,将中断回调放入队列中进行处理。

  • “取消”—不执行中断回调。

此属性是只读的。

删除状态,作为类型的开/关逻辑值返回matlab.lang.OnOffSwitchState

MATLAB设置BeingDeleted财产“上”DeleteFcn回调开始执行。的BeingDeleted物业仍设为“上”直到组件对象不再存在。

的值BeingDeleted属性以在查询或修改对象之前验证该对象是否即将被删除。

父/子

全部展开

父容器,指定为数字对象创建的。uifigure函数或它的子容器之一:选项卡面板ButtonGroup,或GridLayout.如果没有指定容器,MATLAB调用uifigure函数来创建一个新的数字对象,它充当父容器。

对象句柄的可见性,指定为“上”“回调”,或“关闭”

此属性控制对象在其父对象列表中的可见性。当一个对象在其父对象的子列表中不可见时,通过搜索对象层次结构或查询属性获得对象的函数不会返回该对象。这些函数包括得到findobjclf,关闭.即使对象不可见,它们也是有效的。如果可以访问对象,就可以设置和获取其属性,并将其传递给对对象进行操作的任何函数。

HandleVisibility价值 描述
“上” 对象总是可见的。
“回调” 对象在回调函数或回调函数调用的函数中可见,但在从命令行调用的函数中不可见。该选项阻止在命令行访问对象,但允许回调函数访问它。
“关闭” 这个物体在任何时候都是看不见的。这个选项对于防止另一个函数对UI的意外更改非常有用。设置HandleVisibility“关闭”在函数执行期间临时隐藏对象。

标识符

全部展开

此属性是只读的。

图形对象的类型,返回为“uitoggleswitch”

对象标识符,指定为字符向量或字符串标量。您可以指定一个惟一的标签值作为对象的标识符。当需要访问代码中其他地方的对象时,可以使用findobj方法搜索对象标签价值。

用户数据,指定为任何MATLAB数组。例如,可以指定标量、向量、矩阵、单元格数组、字符数组、表或结构。使用此属性可在对象上存储任意数据。

如果您正在使用App Designer,请在应用程序中创建公共或私有属性来共享数据,而不是使用用户数据财产。有关更多信息,请参见在应用程序设计程序中共享数据

版本历史

在R2016a中介绍

另请参阅

功能