第 11章 MATLAB图形用户界面设计
11.1 菜单设计
11.2 对话框设计
11.3 图形用户界面设计工具
11.1 菜单设计
11.1.1 建立用户菜单要建立用户菜单可用 uimenu函数,因其调用方法不同,
该函数可以用于建立一级菜单项和子菜单项。
建立一级菜单项的函数调用格式为:
一级菜单项句柄 =uimenu(图形窗口句柄,属性名 1,属性值 1,属性名 2,属性值 2,…)
建立子菜单项的函数调用格式为:
子菜单项句柄 =uimenu(一级菜单项句柄,属性名 1,属性值 1,属性名 2,属性值 2,…)
11.1.2 菜单对象常用属性菜单对象具有 Children,Parent,Tag,Type、
UserData,Visible等公共属性,除公共属性外,还有一些常用的特殊属性。
例 11-1 建立图 11-1所示的图形演示系统菜单。菜单条中含有 3个菜单项,Plot,Option和 Quit。 Plot中有 Sine
Wave和 Cosine Wave两个子菜单项,分别控制在本图形窗口画出正弦和余弦曲线。 Option菜单项的内容如图 11-1所示,其中 Grid on和 Grid off控制给坐标轴加网格线,Box
on和 Box off控制给坐标轴加边框,而且这 4项只有在画有曲线时才是可选的。 Window Color控制图形窗口背景颜色。 Quit控制是否退出系统。
11.1.3 快捷菜单快捷菜单是用鼠标右键单击某对象时在屏幕上弹出的菜单。
这种菜单出现的位置是不固定的,而且总是和某个图形对象相联系。在 MATLAB中,可以使用 uicontextmenu函数和图形对象的 UIContextMenu属性来建立快捷菜单,具体步骤为:
(1) 利用 uicontextmenu函数建立快捷菜单。
(2) 利用 uimenu函数为快捷菜单建立菜单项。
(3) 利用 set函数将该快捷菜单和某图形对象联系起来。
例 11-2 绘制曲线 y=2sin(5x)sinx,并建立一个与之相联系的快捷菜单,用以控制曲线的线型和曲线宽度。
11.2 对话框设计
11.2.1 对话框的控件在对话框上有各种各样的控件,利用这些控件可以实现有关控制。下面先介绍这些控件。
(1) 按钮 (Push Button)。
(2) 双位按钮 (Toggle Button)。
(3) 单选按钮 (Radio Button)。
(4) 复选框 (Check Box)。
(5) 列表框 (List Box)。
(6) 弹出框 (Popup Menu)。
(7) 编辑框 (Edit Box)。
(8) 滑动条 (Slider)。
(9) 静态文本 (Static Text)。
(10) 边框 (Frame)。
11.2.2 对话框的设计
1.建立控件对象
MATLAB提供了用于建立控件对象的函数 uicontrol,
其调用格式为:
对象句柄 =uicontrol(图形窗口句柄,属性名 1,属性值 1,
属性名 2,属性值 2,…)
其中各个属性名及可取的值和前面介绍的 uimenu函数相似,但也不尽相同,下面将介绍一些常用的属性。
2.控件对象的属性
MATLAB的 10种控件对象使用相同的属性类型,但是这些属性对于不同类型的控件对象,其含义不尽相同。除
Children,Parent,Tag,Type,UserData,Visible等公共属性外,还有一些常用的特殊属性。
例 11-3 建立如图 11-10所示的数制转换对话框。在左边输入一个十进制整数和 2~ 16之间的数,单击“转换”按钮能在右边得到十进制数所对应的 2~ 16进制字符串,单击
“退出”按钮退出对话框。
例 11-4 建立如图 11-11所示的图形演示对话框。在编辑框输入绘图命令,当单击“绘图”按钮时,能在左边坐标轴绘制所对应的图形,弹出框提供色图控制,列表框提供坐标网格线和坐标边框控制。
11.3 图形用户界面设计工具
MATLAB的用户界面设计工具共有 6个,它们是:
(1) 图形用户界面设计窗口:在窗口内创建、安排各种图形对象。
(2) 菜单编辑器 (Menu Editor):创建、设计、修改下拉式菜单和快捷菜单。
(3) 对象属性查看器 (Property Inspector):可查看每个对象的属性值,也可修改设置对象的属性值。
(4) 位置调整工具 (Alignment Tool):可利用该工具左右、
上下对多个对象的位置进行调整。
(5) 对象浏览器 (Object Browser):可观察当前设计阶段的各个句柄图形对象。
(6) Tab顺序编辑器 (Tab Order Editor):通过该工具,设置当用户按下键盘上的 Tab键时,对象被选中的先后顺序。
11.3.1 图形用户界面设计窗口
1,GUI设计模板在 MATLAB主窗口中,选择 File菜单中的 New菜单项,再选择其中的 GUI命令,就会显示图形用户界面的设计模板。
MATLAB为 GUI设计一共准备了 4种模板,分别是 Blank
GUI(默认 ),GUI with Uicontrols(带控件对象的 GUI模板 ),GUI with Axes and Menu(带坐标轴与菜单的 GUI模板 )与 Modal Question Dialog(带模式问话对话框的 GUI模板 )。
当用户选择不同的模板时,在 GUI设计模板界面的右边就会显示出与该模板对应的 GUI图形。
2,GUI设计窗口在 GUI设计模板中选中一个模板,然后单击 OK按钮,就会显示 GUI设计窗口。选择不同的 GUI设计模式时,在
GUI设计窗口中显示的结果是不一样的。
GUI设计窗口由菜单栏、工具栏、控件工具栏以及图形对象设计区等部分组成。 GUI设计窗口的菜单栏有 File、
Edit,View,Layout,Tools和 Help 6个菜单项,使用其中的命令可以完成图形用户界面的设计操作。
3,GUI设计窗口的基本操作在 GUI设计窗口创建图形对象后,通过双击该对象,就会显示该对象的属性编辑器。例如,创建一个 Push Button
对象,并设计该对象的属性值。
11.3.2 对象属性查看器利用对象属性查看器,可以查看每个对象的属性值,也可以修改、设置对象的属性值,从 GUI设计窗口工具栏上选择 Property Inspector命令按钮,或者选择 View菜单下的
Property Inspector子菜单,就可以打开对象属性查看器。
另外,在 MATLAB命令窗口的命令行上输入 inspect,也可以看到对象属性查看器。
在选中某个对象后,可以通过对象属性查看器,查看该对象的属性值,也可以方便地修改对象属性的属性值。
11.3.3 菜单编辑器利用菜单编辑器,可以创建、设置、修改下拉式菜单和快捷菜单。从
GUI设计窗口的工具栏上选择 Menu Editor命令按钮,或者选择 Tools
菜单下的 Menu Editor子菜单,就可以打开菜单编辑器。
菜单编辑器左上角的第一个按钮用于创建一级菜单项。第二个按钮用于创建一级菜单的子菜单。
菜单编辑器的左下角有两个按钮,选择第一个按钮,可以创建下拉式菜单。选择第二个按钮,可以创建 Context Menu菜单。选择它后,菜单编辑器左上角的第三个按钮就会变成可用,单击它就可以创建
Context Menu主菜单。在选中已经创建的 Context Menu主菜单后,
可以单击第二个按钮创建选中的 Context Menu主菜单的子菜单。与下拉式菜单一样,选中创建的某个 Context Menu菜单,菜单编辑器的右边就会显示该菜单的有关属性,可以在这里设置、修改菜单的属性。
菜单编辑器左上角的第四个与第五个按钮用于对选中的菜单进行左移与右移,第六与第七个按钮用于对选中的菜单进行上移与下移,最右边的按钮用于删除选中的菜单。
11.3.4 位置调整工具利用位置调整工具,可以对 GUI对象设计区内的多个对象的位置进行调整。从 GUI设计窗口的工具栏上选择 Align
Objects命令按钮,或者选择 Tools菜单下的 Align Objects
菜单项,就可以打开对象位置调整器。
对象位置调整器中的第一栏是垂直方向的位置调整。。
对象位置调整器中的第二栏是水平方向的位置调整。。
在选中多个对象后,可以方便的通过对象位置调整器调整对象间的对齐方式和距离。
11.3.5 对象浏览器利用对象浏览器,可以查看当前设计阶段的各个句柄图形对象。从 GUI设计窗口的工具栏上选择 Object Browser命令按钮,或者选择 View菜单下的 Object Browser子菜单,
就可以打开对象浏览器。例如,在对象设计区内创建了 3
个对象,它们分别是 Edit Text,Push Button,ListBox对象,此时单击 Object Browser按钮,可以看到对象浏览器。
在对象浏览器中,可以看到已经创建的 3个对象以及图形窗口对象 figure。用鼠标双击图中的任何一个对象,可以进入对象的属性查看器界面。
11.3.6 Tab顺序编辑器利用 Tab顺序编辑器 (Tab Order Editor),可以设置用户按键盘上的 Tab键时,对象被选中的先后顺序。选择 Tools菜单下的 Tab Order Editor菜单项,就可以打开 Tab顺序编辑器。例如,若在 GUI设计窗口中创建了 3个对象,与它们相对应的 Tab顺序编辑器。
例 11-5 利用 GUI设计工具设计图 11-23所示的用户界面。
该界面包括一个用于显示图形的轴对象,显示的图形包括表面图、网格图或等高线图。绘制图形的功能通过 3个命令按钮来实现,用户通过单击相应的按钮,即可绘制相应图形。绘制图形所需要的数据通过一个弹出框来选取。在弹出框中包括 3个选项,分别对应 MATLAB的数据函数
peaks,membrane和用户自定义的绘图数据 sinc,用户可以通过选择相应的选项来载入相应的绘图数据。在图形窗口缺省的菜单条上添加一个菜单项 Select,Select下又有两个子菜单项 Yellow和 Red,选中 Yellow项时,图形窗口将变成黄色,选中 Red项时,图形窗口将变成红色。