主要内容

matlab.ui.componentcontainer.ComponentContainer类

包:matlab.ui.componentcontainer

用于开发自定义UI组件对象的基类

描述

matlab.ui.componentcontainer.ComponentContainer是一个您构建在其上的自定义UI组件对象的类。类定义此基类的子类时,可以使用ComponentContainer属性和方法来构建UI组件对象。类定义文件的第一行指定此语法,以直接继承ComponentContainer类,MyComponent是对象的名称:

MyComponent < matlab.ui.componentcontainer.ComponentContainer

matlab.ui.componentcontainer.ComponentContainer类是一个处理类。

类属性

摘要
真正的
ConstructOnLoad
真正的
HandleCompatible
真正的

有关类属性的信息,请参见类属性

属性

全部展开

颜色和样式

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

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

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

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

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

颜色名称 短名称 RGB值 十六进制颜色代码 外观
“红色” “r” (1 0 0) “# FF0000”

样品的颜色为红色

“绿色” “g” (0 1 0) “# 00 ff00”

样品的颜色为绿色

“蓝色” “b” (0 0 1) “# 0000 ff”

蓝色的样品

“青色” “c” (0 1 1) “# 00飞行符”

样品的颜色为青色

“红色” “m” (1 0 1) “#”就

洋红色的样品

“黄色” “y” (1 1 0) “# FFFF00”

样品的颜色为黄色

“黑色” “k” (0 0 0) “000000 #”

样品的颜色为黑色

“白色” “w” (1 1 1) “# FFFFFF”

样品的颜色为白色

这里是RGB三组和十六进制颜色编码的默认颜色MATLAB®在许多类型的情节中使用。

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],呈暗红色

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
GetObservable
真正的
SetObservable
真正的
交互性

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

  • “上”—显示对象。

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

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

更改不可见容器的大小将触发SizeChangedFcn回调,当它变得可见。

改变了可见容器的属性的值可见子组件的属性。即使隐藏容器会导致隐藏子组件,情况也是如此。

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
GetObservable
真正的
SetObservable
真正的

上下文菜单,指定为快捷菜单对象创建的。uicontextmenu函数。当右键单击组件中不包含任何底层UI组件或图形对象的区域时,使用此属性可显示上下文菜单。

若要在自定义UI组件的任何部分上单击右键时显示上下文菜单,请编写代码设置快捷菜单属性的所有底层UI组件和图形对象快捷菜单属性已设置。

示例:组件与上下文菜单

这段代码在网格布局管理器中创建了一个带有标签和按钮的简单自定义UI组件。类的实例时SimpleComponent类中的代码将上下文菜单分配给组件更新方法然后将该相同的上下文菜单分配给底层GridLayout按钮,标签对象。

classdefSimpleComponent < matlab.ui.componentcontainer.ComponentContainer属性(Access = private, Transient, NonCopyable) GridLayoutmatlab.ui.container.GridLayout按钮matlab.ui.control.Button标签matlab.ui.control.Label结束方法(访问=保护)函数设置(obj)%设置组件大小obj。位置= [100 100 220 50];%创建网格obj。GridLayout = uigridlayout(obj,[1 2]);%创建组件obj。标签= uilabel (obj。GridLayout,...“文本”“我的组件”);obj。按钮= uibutton (obj.GridLayout);结束函数update(obj) obj. gridlayout . contextmenu = obj. contextmenu;obj.Label.ContextMenu = obj.ContextMenu;obj.Button.ContextMenu = obj.ContextMenu;结束结束结束

创建一个SimpleComponent对象并指定上下文菜单。右键单击组件中的空白处和标签。出现上下文菜单。

无花果= uifigure;厘米= uicontextmenu(图);m1 = uimenu(厘米);SimpleComponent(图,“快捷菜单”厘米);

属性:

GetAccess
公共
SetAccess
公共
NonCopyable
真正的
瞬态
真正的
GetObservable
真正的
SetObservable
真正的
位置

UI组件的大小和位置,不包括轴标签和勾标记等装饰的空白。将此属性指定为形式向量[左底宽高]

请注意

当UI组件的父组件是GridLayout

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的

计量单位,指定为“像素”

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
GetObservable
真正的
SetObservable
真正的

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

例如,这段代码将图像组件放在其父网格的第三行和第二列中。

G = uigridlayout([4 3]);我=用户界面图像(g);即时通讯。ImageSource =“peppers.png”;即时通讯。ScaleMethod =“填满”;im.Layout.Row = 3;im.Layout.Column = 2;

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

im.Layout.Column = [2 3];

属性:

GetAccess
公共
SetAccess
公共
回调

大小变化回调函数,指定为以下值之一:

  • 一个处理函数。

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

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

SizeChangedFcn回调执行时间:

  • 组件第一次变得可见。

  • 当组件的大小发生变化时,它是可见的。

  • 该组件在其大小改变后第一次变得可见。这种情况发生在组件不可见时大小发生变化,然后组件稍后变为可见时。

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
AbortSet
真正的
GetObservable
真正的
SetObservable
真正的
NonCopyable
真正的

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

  • 函数处理。

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

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

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

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

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

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

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
AbortSet
真正的
GetObservable
真正的
SetObservable
真正的
NonCopyable
真正的

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

  • 函数处理。

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

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

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

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

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

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
AbortSet
真正的
GetObservable
真正的
SetObservable
真正的
NonCopyable
真正的
回调执行控制

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

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

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

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

每当MATLAB调用回调时,该回调将试图中断正在运行的回调(如果存在的话)。的可中断属性的属性确定是否允许中断。

  • 的值“上”允许其他回调函数中断对象的回调函数。中断发生在MATLAB处理队列的下一个点,例如当有drawnow数字uifiguregetframe等待,或暂停命令。

    • 如果正在运行的回调包含这些命令中的一个,那么MATLAB将在该点停止回调的执行,并执行中断回调。当中断回调完成时,MATLAB继续执行正在运行的回调。

    • 如果正在运行的回调不包含这些命令中的任何一个,那么MATLAB将不中断地完成回调的执行。

  • 的值“关闭”阻塞所有中断尝试。的BusyAction属性的属性确定中断回调是被丢弃还是放入队列中。

请注意

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

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

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

  • 计时器对象根据调度执行,而不考虑可中断属性值。

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

属性:

GetAccess
公共
SetAccess
公共
GetObservable
真正的
SetObservable
真正的

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

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

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

每当MATLAB调用回调时,该回调将试图中断正在运行的回调。的可中断属性的属性确定是否允许中断。如果不允许中断,则BusyAction属性的属性确定是丢弃该中断回调还是将其放入队列中。这些是可能的值BusyAction属性:

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

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

属性:

GetAccess
公共
SetAccess
公共
GetObservable
真正的
SetObservable
真正的

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

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

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

属性:

GetAccess
公共
SetAccess
受保护的
GetObservable
真正的
SetObservable
真正的
父/子

组件的父容器,指定为数字面板选项卡,或GridLayout对象。

属性:

GetAccess
公共
SetAccess
公共
瞬态
真正的
依赖
真正的
NonCopyable
真正的
GetObservable
真正的
SetObservable
真正的

UI组件的子组件,返回为空GraphicsPlaceholder数组中。自定义UI组件没有子组件。设置此属性没有效果。

属性:

GetAccess
公共
SetAccess
公共
瞬态
真正的
依赖
真正的
NonCopyable
真正的

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

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

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

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
GetObservable
真正的
SetObservable
真正的
标识符

UI组件对象的类型,作为包含组件名称的字符向量返回。

属性:

GetAccess
公共
SetAccess
受保护的
NonCopyable
真正的
瞬态
真正的

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

属性:

GetAccess
公共
SetAccess
公共
依赖
真正的
GetObservable
真正的
SetObservable
真正的

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

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

属性:

GetAccess
公共
SetAccess
公共
瞬态
真正的
GetObservable
真正的
SetObservable
真正的

方法

全部展开

例子

全部折叠

定义一个名为IPAddressComponent它创建了一个自定义组件,用于输入四个值来形成一个IP地址。

要定义类,创建一个名为IPAddressComponent.m它包含以下具有以下特性的类定义:

  • 一个价值存储IP地址的公共属性。

  • NumericField而且GridLayout在水平行中放置四个数字编辑字段的私有属性。

  • 一个设置初始化方法NumericField而且GridLayout

  • 一个更新方法更新NumericField的值。

  • 一个handleNewValue方法,设置价值属性根据4个数值编辑字段的值设置。

classdefIPAddressComponent < matlab.ui.componentcontainer.ComponentContainerIPAddressComponent用于IP地址输入的4个编辑字段的集合属性价值(1,4) {mustBeNonnegative, mustBeInteger, mustBeLessThanOrEqual(Value, 255)}= [192 168 1 2];结束事件(HasCallbackProperty, NotifyAccess = protected) ValueChanged将生成% ValueChangedFcn回调属性结束属性(Access = private, Transient, NonCopyable(1、4)matlab.ui.control.NumericEditFieldGridLayoutmatlab.ui.container.GridLayout结束方法(访问=保护)函数设置(obj)设置此组件的初始位置obj。位置= [100 100 150 22];%的布局obj。GridLayout = uigridlayout (obj,(1、5),...“RowHeight”{22},“ColumnWidth”{30日,30日,30日,30日,22},...“填充”,0,“列空间”2);%的构建块obj. numericfield (k) = uieditfield(obj. numbericfield)。GridLayout,“数字”...“限制”255年[0],“RoundFractionalValues”,真的,...“字体名”“快递新”“FontWeight”“大胆”...“ValueChangedFcn”@ (o, e) obj.handleNewValue ());结束结束函数更新(obj)%更新视图j. numericfield (k). k = 1:4。值= obj.Value (k);结束结束结束方法(访问=私人)函数handleNewValue (obj) obj。价值= [obj.NumericField.Value];执行事件监听器和ValueChangedFcn回调属性通知(obj,“ValueChanged”);结束结束结束

接下来,通过调用IPAddressComponent构造函数方法提供的ComponentContainer类,并返回对象为h.指定一个函数,当组件值发生变化时,在命令窗口中显示新的IP地址。

h = IPAddressComponent;h.ValueChangedFcn = @(o,e) disp([“值更改为:”num2str (h.Value)]);

输入IP地址192.168.1.10进入编辑字段。MATLAB®在命令窗口中显示更新后的IP地址。

更多关于

全部展开

版本历史

介绍了R2020b

Baidu
map