• MATLAB GUI制作快速入门


    创建空白的GUI
    在MATLAB命令行中输入guide
    新建GUI,选择Blank GUI (Default),点击确定后就生成了一个空白的GUI制作界面,如下图所示


    图1
    制作GUI的具体过程
    简单加法器
    将可编辑文本拖入界面中
    双击可编辑文本,在String栏中可以修改相应的文字,Tag栏是相当于给每个文本的一个标记,在后面的输入输出环节作用非常大。
    将静态文本拖入界面中,双击它,同样可以在String栏中修改文本内容;同理,将按钮拖入界面中,修改其String为运行,它的作用相当于运行程序的开关。
    点击菜单栏中的对齐对象,选中界面中的相应组件,调整布局得到如下结果

    图2
    前两个可编辑文本为输入,后一个为输出,选中运行,单击鼠标右键,选择查看回调里的Callback,在 pushbuttonX_Callback函数下编写如下语句(这里X表示你具体在运行的Tag中设置的是多少)
    global a1;
    global a2;
    global a3;
    a1 = str2double(get(handles.edit1,'String'));
    a2 = str2double(get(handles.edit2,'String'));
    a3 = a1 + a2;
    set(handles.edit3,'String',a3);
    1
    2
    3
    4
    5
    6
    7
    在GUI界面中点击菜单栏的运行图形,在前两个可编辑文本中输入数据,点击运行,得到结果如下

    图3

    PS:
    1、其实GUI制作并不复杂,理论上你编写的任何m程序都可以打包成一个GUI,只需要你解决输入参数以及结果输出的问题。
    2、在编写程序时,发现在某个函数A下定义一个全局变量s,想在另一个函数B下使用它,必须在函数B下重新s为全局变量(下文将会继续提到)。
    导入EXCEl数据
    MATLAB是一款处理数据的利器,在实际过程中,可能需要向GUI中导入数据,下面将详细介绍:

    需要导入的数据如图:


    图4
    将按钮拖入界面中,修改String为导入数据,选中它,单击鼠标右键→查看回调→Callback,在pushbuttonX_Callback函数中编写如下语句。
    global sj;
    [fname_od,pname_od] = uigetfile('.xlsx','请选择您想导入的数据’);
    if fname_od == 0
    return
    end
    str = fullfile(pname_od,fname_od);
    [num,txt,sj] = xlsread(str);
    %下面语句的作用是删除数据第一行
    sj(1,:) = [];
    sj = cell2mat(sj);
    %导入进来的是一个元胞数组,需要转换成矩阵
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    上述代码中,可以根据自己的实际需求做出相应修改,如文件格式为xls,则在uigetfile中可将xlsx改为xls

    GUI中显示上述数据
    在GUI界面中拖入表,此时它的Tag应该是uitable1,选中它,单击鼠标右键→查看回调→CreateFcn
    在uitableX_CreateFcn函数输入如下程序:
    DATA = {0,0,0,0,0,0}
    %表格的初始值
    set(hObject,'ColumnName',{'语文','数学','英语','物理’,'化学’,'生物'},'data',DATA,...
    'ColumnEditable',true);
    %设置表格的栏目名
    1
    2
    3
    4
    5
    在GUI界面中,点击菜单栏中的运行图形,调整布局后,得到如图结果:


    图5
    选中运行按钮,点击鼠标右键→查看回调→Callback,继续在pushbuttonX_Callback函数下编写如下语句
    global sj;
    %此处就是上文中提到的再一次定义全局变量
    set(handles.uitable1,'data',sj);
    1
    2
    3
    在GUI界面中,点击运行图形,在可编辑文本中输入数据,单击导入数据按钮,弹出的界面如图

    图6
    选择上述数据的EXCEL文件,再点击运行按钮,可以得到如下结果


    图7
    上面的步骤虽然只是讲述了如何将数据导入GUI,并通过GUI将原数据导出,但是通过上述方法,你可以对导入的数据进行相关处理后,根据实际的需要将结果输出。
    弹出式菜单的简要介绍
    下拉菜单是GUI中常见的组件,下面对其使用方法进行相关介绍

    将弹出式菜单拖入GUI界面,双击它,在String栏中点击小正方形,在里面输入你需要的内容,如图

    图8
    选中弹出式菜单→查看回调→Callback,在popupmenuX_Callback函数中输入如下代码
    global a4;
    val = get(handles.popupmenu1,'value');
    switch val
    case 1
    a4 = 0;
    case 2
    a4 = 5;
    case 3
    a4 = 9;
    case 4
    a4 = 15;
    end
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    选中运行→查看回调→Callback,在 pushbuttonX_Callback函数下编写如下语句
    global a1;
    global a2;
    global a3;
    global a4;

    a1 = str2double(get(handles.edit1,'String'));
    a2 = str2double(get(handles.edit2,'String'));
    a3 = a1 + a2 + a4;
    set(handles.edit3,'String',a3);

    global sj;
    set(handles.uitable1,'data',sj);
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    在GUI菜单栏中点击运行图形,在下拉菜单中选择你所要的数据

    在文本中输入数据,并按照上述过程导入你想要处理的数据,点击运行按钮,得到如下结果

    图9
    结束语
    上述内容是自己在做项目的时候,查阅相关资料所总结出来的一些经验。由于能力有限,上述内容难免会有疏漏和错误,欢迎各位大佬批评指正。
    --------------------- 

  • 相关阅读:
    spring cloud stream定时器 配置rabbitmq插件安装
    字母、单词统计
    动手动脑
    原码补码反码
    ATM
    开学第一课
    周进度报告8
    周进度报告7
    JavaWeb进度报告1
    周进度报告6
  • 原文地址:https://www.cnblogs.com/hyhy904/p/10977570.html
Copyright © 2020-2023  润新知