(七)Appdesigner-初步入门及常用组件的使用方法说明

news2025/1/11 14:27:45

目录

前言

一、Appsesigner初步入门

(一)Appsesigner简介

(二)功能布局

二、常用组件

(一)基础知识

(二)实际操作

1.HTML

2.下拉框

3.切换按钮组

4.列表框

5.单选按钮组

6.图像

7.坐标区

8.复选框

9.微调器

10.按钮

11.文本区域、标签、日期选择器

12.树(复选框)

13.滑块

14.状态按钮

15.编辑字段(数值/文本)

16.表

17.超链接

18.指示灯

总结


前言

        本博客简单介绍了Appdesigner的概念以及工具界面,同时针对常用的组件进行了介绍,读者可以根据博客内容对该工具有一个初步的认识和理解,同时在实际操作过程中可以对照文章查看每个组件的使用方法以及回调函数编写方法。


一、Appsesigner初步入门

(一)Appsesigner简介

        Appdesigner是开发基于MATLB程序软件的App开发工具,是GUI的一种替代方案,将逐步替代GUI,因此掌握Appdesigner的使用是一项必备技能。采用面向对象的方式进行编写;各个组件的代码自动生成,用户可以根据需求添加各种组件,并修改组件的回调函数以及属性等就可以实现各种功能。

(二)功能布局

        在MATLB中打开Appdesigner的界面,点击设计App,如下图所示。

        点击之后会出现以下界面,点击空白App,系统会新建一个.mlpp工程。

        之后系统进入以下页面,为软件的设计和开发界面。

        组件库包含了常用的所有组件,读者可以通过拖拽的方式将其放置到软件界面设计区域进行界面的设计编辑;软件界面设计区域主要是完成软件界面中组件的排列分布,使其更加美观和整齐;组件属性编辑区域主要是针对各种组件的属性进行更加详细的编辑,不同的组件其具体的属性不相同,读者可以自行探索;顶部编辑区域会随着设计界面的切换发生改变,在当前界面主要的作用就是保存、运行程序以及编辑对齐组件等,在切换至代码试图界面时,将变为程序的编辑器,如下图所示。

二、常用组件

(一)基础知识

        组件库中包含了各种各样的组件,对于组件的编辑主要有两个内容,一个内容是组件属性的编辑,这里不做过多的详细介绍,读者可以在实际操作过程中自行体会,仅需要点击组件并在右侧的软件属性编辑区进行编辑即可;另一个内容为组件回调函数的添加,组件添加回调函数之后,当用户触发组件的对应事件时候,系统会执行相应的程序,本节将讲述一些常用组件的作用以及回调函数的添加方法,后续会根据需要补充一些其他组件使用方法总结

(二)实际操作

1.HTML

        HTML的作用主要是显示嵌入式的HTML文件,可以实现软件界面的美化或者拓展相应的功能。具体的应用可以参考以下链接。

matlab appdesigner系列-常用1-HTMLicon-default.png?t=N7T8https://blog.csdn.net/weixin_44247155/article/details/135599302

2.下拉框

        下拉框主要用于用户选择相应选项,左侧为下拉框的文本编辑区域,右侧为下拉列表,列表的选项可以在组件属性编辑区域进行修改。其对应的回调函数为:

value = app.t18.Value;
switch value
    case'1'
        %对应内容程序
    case'2'
        %对应内容程序
    case'3'
        %对应内容程序
end

3.切换按钮组

        切换按钮组的默认层数为3层,回调函数将依据选择的按钮不同,执行不同的程序,不同状态按钮的定义在组件属性编辑区。

selecte = app.ButtonGroup.SelectedObject;
switch selecte.Text
    case '1层'
        %对应程序内容
    case '2层'
        %对应程序内容
    case '3层'
        %对应程序内容
end

4.列表框

        列边框显示了不同选项,回调函数中根据你选择的文本内容执行不同的程序。对应的回调函数为:

value = app.ListBox.Value;
switch value
    case '1'
        %对应程序内容
    case '2'
        %对应程序内容
    case '3'
        %对应程序内容
end

5.单选按钮组

        单选按钮组是用于状态选择的组件,回调函数依据选择的文本内容执行不同的程序。对应的回调函数为:

selecte = app.ButtonGroup.SelectedObject;
switch selecte.Text
    case '1层'
        %对应程序内容
    case '2层'
        %对应程序内容
    case '3层'
        %对应程序内容
end

6.图像

        图像可以用来美化软件界面,组件编辑区域可以导入外部的图片,导入的图片可以用作背景或者局部的修饰图片。

7.坐标区

        坐标区主要用于显示绘制的图像,将组件拖拽到软件设计界面之后,可以通过右侧的组件属性编辑区修改图像的标题、网格、坐标轴、字体、颜色等属性,并且需要特别注意的一点是在编写绘图程序时,对应的程序语句必须指明是在那个坐标区执行命令。对应的绘图指令为:

%绘图
plot(app.UIAxes,X,Y);
%app.UIAxes表示坐标区,前面必须加app.用于索引坐标区

        如果需要在坐标区继续绘制图像,对应的程序为:

%继续绘图
hold(app.UIAxes,'on');

8.复选框

        复选框是用来判断用户是否勾选了此选项,对应的回调函数为:

value = app.CheckBox.Value;
if value==1
    %执行对应程序
end

9.微调器

        微调器用来细微调整某些参数的数值,拓展应用可以用来调整颜色等。微调器的默认值、步长、变化范围可以在组件属性编辑区域进行编辑,对应的回调函数为:

function SpinnerValueChanging(app, event)
    changingValue = event.Value;
    %根据需求编写不同程序
end

10.按钮

        按钮的作用是点击后开始执行相应的程序,可以直接添加回调函数,这样就可以直接执行对应的程序。

11.文本区域、标签、日期选择器

        文本区域可以用于显示大段文字,也可以用于显示计算近程,对应的回调函数为:

app.TextArea.Value='计算进度10%';

        标签用来编辑静态文本,可以在右侧的组件属性编辑区更改字体、大小、颜色等属性。

        日期选择器用来显示时间,用户可以通过鼠标选择对应的日期,同时可将选择的日期传递给其他的组件,对应回调函数为:

value = app.DatePicker.Value;

12.树(复选框)

        其本质就时多个复选框组成的组件,分为主节点和子节点。可以在右侧组件属性编辑区或者软件设计界面直接添加或者删除节点。此组件主要包含两个回调函数, CheckedNodesChangedFcn属性指定当用户选中或取消选中树中的节点时要执行的函数。SelectedNodesChangedFcn 属性指定当用户选择树中的节点时要执行的函数。主要用到的属性为Nodedata以及Text属性,在初始定义时,给每个选型定义一个数值,最后根据Check函数的Nodedata结果来判断是否执行对应的回调函数。

checkedNodes = app.Tree.CheckedNodes;
if isempty(checkedNodes)
     app.TextArea.Value = '0';%没有任何复选框被选中
else
     app.TextArea.Value = num2str([checkedNodes.NodeData]); %选中复选框的值数组
end

13.滑块

        滑块的作用与微调器类似,用户可以通过滑动组件的方式对参数的数值进行调节,其步长、取值范围同样可以在组件编辑区进行修改,对应的回调函数为:

function SliderValueChanging(app, event)
    SliderValue=event.Value;
end

14.状态按钮

        状态按钮一共存在两个状态,按下时为‘1’,未按下的状态为‘0’。对应回调函数为:

value = app.Button4.Value;
if value == 1
    %对应程序
elseif value == 0
    %对应程序
end

15.编辑字段(数值/文本)

        该组件主要用于显示或者输出参数,数值编辑字段输入输出的数据为数值格式,文本编辑字段输入输出的数据格式为文本格式,用户可以根据数据类型自行定义对应的组件。对应程序为:

%根据数据类型不同选择文本或者数值编辑字段
%获取输入
value = app.EditField.Value;
%输出显示
app.EditField.Value = ‘显示的数据’ ;

16.表

        主要用来显示数据,也可以用来显示excel中的表格,对应回调函数为:

app.UITable.Data=readtable("data.xlsx");

17.超链接

        超链接可以添加外部网页链接或者外部的matlab文件链接,均可在网页的右侧组件编辑区域进行编辑。

18.指示灯

        指示灯可以用来显示程序运行近程,例如在程序开始和结束部分定义指示灯的两种不同颜色,可以指示程序的运行状态,对应的定义语句为:

app.Lamp.Color = 'r';%程序开始
%程序主体
app.Lamp.Color = 'g';%程序结束

总结

        本文针对Appdesigner进行了简单介绍,并针对常用组件的调用方法进行了总结,但是目前仅仅介绍了部分组件,后续会进行补充总结。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1969079.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ShardingSphere实战(4)- 广播表和默认数据源

上篇博客,我们讲了 ShardingSphere实战(3)- 快速实现分库分表 ,这篇博客,我们解决分库分表以后遗留的两个小问题。 一、广播表 1. 广播表介绍 广播表(Broadcast Table)是一种特殊的表类型&am…

SSM学习10:整合MyBatis、MyBatisPlus

SpringBoot整合MyBatis 与创建spring web项目类型,添加上相应依赖 实体类 public class Account {private int id;public int getId() {return id;}public void setId(int id) {this.id id;}public String getName() {return name;}public void setName(String …

word打印---doc转html后进行打印,window.print、print-js、vue-print-nb

提示&#xff1a;word预览方式—插件 文章目录 [TOC](文章目录) 前言一、vue-office-docx把docx转换html二、调取window.print三、print-js四、vue-print-nb总结 前言 word预览 一、vue-office-docx把docx转换html npm install vue-office-docx -S-DofficeDocx.vue <templ…

Meta发布最新图形分割模型SAM 2:实时视频分割性能大幅提升

Meta发布最新图形分割模型SAM 2:实时视频分割性能大幅提升 在人工智能领域,图形分割是一项重要的技术,它能够识别和提取图像或视频中的目标对象。Meta近期发布的SAM 2(Segment Anything 2)模型在这一领域取得了重大突破。本文将详细介绍SAM 2的创新之处及其在视频对象实时…

vue3学习day02-组合式API-setup选项、reactive(将非响应式数据变为响应式数据)、computed(基本思想和vue2一致)、watch

6、setup选项 &#xff08;1&#xff09;setup选项的执行时机&#xff08;获取不到this&#xff0c;this是undefined&#xff09;&#xff1a;beforeCreate函数之前&#xff0c;自动执行 &#xff08;2&#xff09;写法 1&#xff09;原始写法 需要返回 ①在script中导出s…

【DeepSeek-V2 技术要点介绍】

DeepSeek-V2 是一款基于 Transformer 架构的先进模型&#xff0c;其中每个Transformer块由一个注意力模块和一个前馈网络&#xff08;FFN)组成。然而&#xff0c;对于注意力模块和 FFN&#xff0c;研究团队设计并采用了创新的架构。旨在通过创新的设计提升推理和训练效率。以下…

行为验证码的分类推荐

行为验证码 行为验证码是一种用于确认用户身份或验证用户行为的技术手段&#xff0c;通常用于防止自动化程序&#xff08;例如机器人&#xff09;对网站或应用程序进行恶意操作。它的核心思想是通过要求用户执行特定的交互动作来验证其为真实的人类 是一种通过用户的操作行为…

SDK 多版本管理控制利器 SDKMAN 介绍及使用

一、SDKMAN 假如你同时参与了一个使用JDK 8的项目和一个采用JDK 17特性的项目。每次在两个项目之间切换时&#xff0c;你都面临着版本冲突的问题。如果有那么一个工具类似于 Python 中的 anaconda 工具&#xff0c;可以帮助你管理不同版本的 SDK &#xff0c;是不是非常有用&a…

【32单片机篇】项目:LCD实时显示温湿度

一、项目需求 使用 ESP8266 连接 OneNET 云平台&#xff0c;并通过 MQTT 协议上传 DHT11 获取的温湿度值。 二、项目框图 三、硬件部分 四、项目源码及实现 1.项目源码 https://gitee.com/GeekerGao/upload-the-temperature-and-humidity-to-OneNET 2.项目实现

C语言 之 理解数组(8)数组和指针相关的题目 详细解答 快来观看

文章目录 1. 数组和指针相关题1.1 一维数组1.2 字符数组代码1代码2代码3代码4代码5代码6 1.3 二维数组 1. 数组和指针相关题 这里主要讲解的是通过sizeof和strlen来对数组和指针进行更深入的一些了解&#xff0c;建议有兴趣与初学者可以先尝试自己思考来完成。 1.1 一维数组 …

GPT-Pilot —— 让AI来写代码

1.概述 什么是GPT-Pilot&#xff1f; 一个AI开发者伴侣&#xff0c;可以从0开始构建应用程序&#xff0c;可以自己编写代码、配置开发环境、管理开发任务、调试代码。 项目地址&#xff1a;https://github.com/Pythagora-io/gpt-pilot 不仅仅是一个自动完成功能或 PR 消息的助…

CSP-J 2022 读程题16.答案与解析

知识点 普及 逻辑运算 16. 01 #include <iostream> 02 03 using namespace std; 04 05 int main() 06 { 07 unsigned short x, y; 08 cin >> x >> y; 09 x (x | x << 2) & 0x33; 10 x (x | x << 1) & 0x55; 11 y (y …

常见离线语音识别模块功能说明——天问ASR;机芯智能;海凌科;轻语音

本文章从开发方式及功能等方面上进行说明&#xff0c;便于开发者进行选择与开发。 本文章依据截至2024年8月1日各网站资料进行整理编写。 总结&#xff1a; 开发方式上&#xff1a; 天文ASR 有着最灵活的开发方式&#xff0c;可完全按照程序员意愿进行开发&#xff0c;同时有…

零基础进程最详解:进程状态、僵尸进程、孤儿进程、阻塞态、挂起态、进程切换、进程常用命令、进程创建、队列优先级

目录 强烈建议全文阅读&#xff01;&#xff01;&#xff01; 强烈建议全文阅读&#xff01;&#xff01;&#xff01; 强烈建议全文阅读&#xff01;&#xff01;&#xff01; 一、进程状态 二、僵尸和孤儿进程 1、僵尸进程 Z&#xff08;zombie&#xff09; 2、孤儿进…

[012-1].第12节:Mysql的配置文件的使用

6.配置文件的使用 6.1.配置文件的格式 1.查看配置文件&#xff1a;vim /etc/my.cnf 2.在配置文件中华定义了很多组&#xff0c;组名就分别是server&#xff0c;mysqld&#xff0c;mysqld_safe,client,mysql,mysqladmin&#xff0c;每个组下面就可以定制很多启动项&#xff1b…

scrapy框架2

scrapy框架2 一、中间件 &#xff08;下载中间件&#xff09; 利用中间件加cookie 案例&#xff1a;登录以后下载豆瓣的电影信息 def get_cookie_dict():cookie_str登陆后的cookiecookie_dict{}for item in cookie_str.split(";"):key,valueitem.split(""…

遇到缓存问题

问题&#xff1a;在事务中在进行数据库查询所有的数据后&#xff0c;将其中的数据更改几个后&#xff0c;重新进行查询。发现此时返回的数据并不是修改之后的数据。 经过学习后发现是Mybatis的一级缓存问题,同时也了解的Mybatis的二级缓存&#xff1a; Mybatis一级缓存: 当在…

SpringCloud网关 SpringBoot服务 HTTP/HTTPS路由/监听双支持

背景 一般来说SpringCloud Gateway到后面服务的路由属于内网交互&#xff0c;因此路由方式是否是Https就显得不是那么重要了。事实上也确实如此&#xff0c;大多数的应用开发时基本都是直接Http就过去了&#xff0c;不会一开始就是直接上Https。然而随着时间的推移&#xff0c…

WebGoC题解(16) 386.山洞

题目描述 小C和弟弟一起参观影视城&#xff0c;发现里面有m个圆形排列的“小山洞”&#xff0c;山洞用半径20、颜色号为编号的圆表示&#xff0c;由边长是100的线连接&#xff0c;均匀的发布一圈&#xff08;1号洞在正上方&#xff09;。m为8时如下图&#xff1a; 小C跟弟弟提议…

点赞10W+,销售额上百万,如何搭上奥运的流量快车?

2024巴黎奥运会正如火如荼进行中。一边是紧张的赛事与各种抓马事情&#xff0c;一边是法国的浪漫与中国00后的松弛&#xff0c;这届奥运会的看客仿佛瓜田里的猹&#xff0c;忙得不可开交。 作为全球范围内的重大体育盛事&#xff0c;奥运会一直以来都备受公众的热烈关注。 据腾…