单片机串口通信学号显示_触摸屏与单片机串口通信测试

工业现场在使用触摸屏的时候,与第三方控制器进行通信连接的时候,一般都是使用成熟的通信协议进行通信连接。而这些协议的实现过程,触摸屏厂商也已经在编程环境中进行了封装集成,对于使用的工程师来说,通信的数据交换过程我们无需要关心。仅需要设置配置好控制器(PLC)的品牌,型号系列及基本的通信通道就可以了。当然,这是触摸屏通信的常规使用方法,这里就使用自定义协议如何实现触摸屏与控制器(如,单片机)的通信方法,分享给大家。以下通信测试方法除电脑外无需任何硬件,感兴趣的话可以依照以下步骤还原测试过程。

工具及环境准备

在开始测试前,我们需要准备以下工具及软件。

  • 触摸屏编程软件:台达DOPSoft 2.00.07
  • 虚拟串口:Virtual Serial Port Driver
  • 串口助手调试工具:stc-isp-15xx-v6.86v
e2f3d30f0305ea5134e8f858f0c2e7ae.png

DOPSoft 2.00.07

7d670d3bbefa1c2bf63b15b4f8280568.png

Virtual Serial Port Driver

617d2304f6c386f02929aa458b8eb2a3.png

stc-isp-15xx-v6.86v

虚拟串口

打开“Virtual Serial Port Driver”软件,添加COM1、COM2两个串口。添加完成后,如下所示;

f3836930a4e09bd42edf66960b593264.png

串口助手设置

打开串口助手软件(stc-isp-15xx-v6.86v)。在串口助手的串口号中设置为COM1,9600,8,n,1。此处设置为COM1后,触摸屏中就只能配置为COM2。其必须与虚拟串口设置的串口号对应。

c7302411b3de82c629b3ec7508216fc8.png

到此,就完成了测试环境的搭建。以下开始触摸屏部分的配置。

触摸屏设置

触摸屏设置为本次测试的核心。

STEP1

打开“DOPSoft 2.00.07”软件,并新建工程。

f537322c41770c9026a85d7cc83d71b4.png

STEP2

在通信端口配置页面,按照如下配置通信端口。这里以触摸屏的COM2作为此处测试的连接端口,故需要将触摸屏的COM2的“连接“复选框取消选中。这样才可以将其用作自定义通信方式使用。

b197571a13e159663c8397a66b64581f.png

SETP3

在画面编辑页面,按照下图所示,设置10个数值输入框。并将其地址设置为触摸屏内部存储区域的$0-$10。

652461573fa783142574130c80c4b0b5.png

双击数值输入框,弹出数值输入框的配置对话框,如下所示。

3d69b2e9249bf85c371ac5de3c362ac4.png

在写入地址对话框的后侧,点击“…”,弹出输入对话框。将连线名称设置为内部存储区域(Internal Memory)。再将原件地址设置为“0”。

de03ae572020645190deb561affd8d93.png

依照以上方法,将其他数值输入框设置到地址1-10.

STEP4

设置画面运行过程中的脚本程序。

选中画面,在右侧的属性栏,选择“画面Cycle宏”。

eec4c49231512e7bc6acb9d20373a89f.png

弹出触摸屏脚本编辑对话框,点击下图所示按钮,打开脚本程序代码编写向导对话框。

3d2d04661912ee81fe2278e0125ddc6c.png

在脚本程序代码编写向导对话框中,选择“命令”-“通信”-选择命令。配置完成代码参数后,选择“更新宏”,完成代码的添加。

23bd051ac0e9d6cba3881c18f4cf0fb8.png

代码添加完成后,如下图所示。

6aae34a44bf07b20d5ed568b1c8c7b0c.png

$M0 = INITCOM(1, 0, 1, 0, 0, 6, 0)//初始化端口

SELECTCOM(1)//设置触摸屏通信端口为2号端口

$M1 = PUTCHARS($0, 20, 3000)//发送触摸屏内部$0开始的20个连续地址数据

Delay(300)//延时

$M0 = 0//清除端口初始化标志

$M1 = 0//清除数据发送完成标志

CLEARCOMBUFFER(1, 1)//清除串口缓存

STEP5

启动触摸屏在线仿真。弹出如下所示的对话框,按照如图所示的方式配置。

ec74eca5b0080849650156a9318f6e80.png
14840fb00d9da8ea5191e06009aeaf17.png

STEP6

按照地址,从上到下设置为1到10.

155eb2a2da8e2ee2ceb2bd900f1119f7.png

STEP7

打开串口助手,可以看到在串口助手的接收区域,已经接收到触摸屏在线仿真发送出来的数据,且数据中可以看到有1到10(串口助手配置为16进制显示模式,其中16进制的A即为十进制的10)。

8dbcd4027406e823129db1534a907ab5.png

STEP8

在触摸屏在线仿真页面,将第一个数据改为9999。

e5fe44618a763d0c3c42557ce9264e9c.png

再次查看串口助手中接收到的数据,其中第一个数据已经变为0F 27.

4e9509b7305e7c453146e47c9e6f832d.png

为了验证数据的正确性,打开电脑的计算器工具,将其设置为程序员模式。选择16进制输入模式。输入0F27,可以看到转换为十进制后数据为3879,这与触摸屏输入的数据9999无法对应。这是什么地方错了吗?其实不是。这只是数据的高低字节交换了,这在通信数据传输处理的时候需要特别注意。初次进行串口通信调试,很多都被这个给折腾过。

79d6b801cf0eecf9d3c6df1abe2427b3.png

在计数器模式下,输入270F。可以看到其转换后的十进制数据为9999.与设置的输入数据一致。

02a84ec3498b6743a86ff0f7536d80bf.png

自此,使用触摸屏进行串口自定义协议通信的测试就已经完成。

(转载请注明来源函控自动化工程师头条号)

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

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

相关文章

2020笔记本性价比之王_2020轻薄本性价比之王_2020轻薄本哪款好

随着科技的进步,如今笔记本的功能愈发强大,接听电话、开展商务会议等,因此现在人们对于笔记本电脑的依赖程度愈发明显。厚重的商务本和游戏本显然不适合随身携带,因此轻薄本的出现受到白领们的广泛吹捧,那么2020哪款轻…

scp命令默认传输速度多大_每天一个linux命令(60):scp命令

scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的。可能会稍微影响一下速度。当你服务器硬盘变为只读 read only system时&#xff0c…

asp绑定gridview属性_如何在ASP.NET Core中自定义Azure Storage File Provider

主题:如何在ASP.NET Core中自定义Azure Storage File Provider作者: Lamond Lu地址: https://www.cnblogs.com/lwqlun/p/10406566.html项目源代码: https://github.com/lamondlu/AzureFileProvider背景ASP.NET Core是一个扩展性非常高的框架…

mysql中为表创建副本_如何为数据库建立一个副本?

展开全部大多情况下,需要可靠而有效地克隆 MySQL 实例e69da5e887aa62616964757a686964616f31333433643663数据。这包括 MySQL 高可用的解决方案,其中需要在将实例加入组复制集群之前配置实例,或者在经典复制模型中将其添加为 Slave。为复制拓…

mysql考勤系统设计函数_Mysql实战之员工考勤系统数据库建立

一、项目背景随着企业的规模不断扩大,企业人事管理的日趋复杂和企业人员的增多,迫切需要开发基于网络的员工考勤管理系统来提高管理工作的效率。二、研究目的以中小型企业的考勤管理业务为依托,结合科学管理的理论,设计并开发一个…

linux mysql 修改字符集_linux下mysql修改字符集,远程连接

安装时候很简单,但是安装了后一般不能用安装后 首先执行mysql -u root mysql这是就会进入mysql命令窗口,这样是可以使用的,但是我们要先设置密码1、先设置密码UPDATE user SET PasswordPASSWORD(123456) where USERroot;2、重新设置一遍密码&…

mysql授权远程访问命令_mysql 授权远程连接

解决方案改表法可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称…

MySQL根据员工姓名所在部门_用一条SQL语句显示所有人员的姓名及所在部门

给定以下两个表:部门ID部门名称1部门12部门23部门34部门4人员ID人员姓名部门ID1姓名112姓名213姓名324姓名435姓名55(1)用一条SQL语句显示所有人员的姓名及所在部门,没有部门的用“...给定以下两个表:部门ID 部门名称1 部门12 部门23 部门34 …

mysql begin operations_MySQL入门(七):More JOIN operations

Sqlzoo习题练习:More JOIN operations下面会涉及到更多连接的概念。数据库由三个表组成:movie , actor 和 casting以及三个表之间的关系。下面为More JOIN 习题内容:--#1/*List the films where the yr is 1962 [Show id, title]*/SELECT id,…

win10安装mysql5.7.15_win10上如何安装mysql5.7.16(解压缩版)

注:本文涉及的是解压缩版的安装安装教程下载mysql解压缩下载的文件修改ini文件(在解压缩后的mysql文件夹中)实际上修改的是my-default.ini文件在文件中添加如下路径和地址其中的data文件夹是没有的必须自己创建。# These are commonly set, remove the # and set as…

mysql error log清理_手动删除mysql日志/var/log/mysql/error.log导致的mysql无法启动

问题环境ubuntu-mate for raspberrymysql默认配置问题起源最近在搞fail2ban这东西,顺便翻了翻各种日志,然后看见mysql的日志有点多就想清理一下,于是直接sudo rm -r /var/log/mysql了一下,结果重启之后发现mysql就不跑了。。。手动…

mysql开启权限控制_mysql开启远程访问及相关权限控制

开启mysql远程访问:授予用户user 密码 passwd 所有权限 所有主机IP可访问授权语句:Grant on 表名[(列名)] to 用户 With grant option或 GRANT ON FROM GRANT ALL PRIVILEGES ON *.* TO user% IDENTIFIED BY passwd WITH GRANT OPTION;ALL PRIVILEGES表示…

mysql awr 上海用户组_mysql awr v1.0.3修正说明以及发布

本版本计划修正或者包含如下内容:1、innodb buffer_pool只是分配的vm大小,实际并不一定真正使用这么多,还可能会有内存泄露,故调整从innodb_buffer_pool_stats获取实际值并显示,同时获取mysqld进程实际占用的物理内存&…

mysql如何备份一个表单_Mysql亿级数据大表单表备份

上一篇Mysql已有亿级数据大表按时间分区,介绍了亿级数据大表如何按时间分区,也留下了一个问题:备份亿级数据大表要耗时多久。本篇将就如何备份亿级数据大表展开讨论。注意:我这里所说的备份指的是数据从一张表拷贝到另外一张表&am…

mysql mos login_MySQL 中常用的函数

一、DATE_FORMAT()需求:按照日期月份统计数据,但数据库存储的格式是 2020-10-01 10:20:45 ,因此需要格式化日期语法:DATE_FORMAT(date,format)第一个参数:指定的日期,第二个参数:需要获取的格式…

mysql用户信息备份还原_mysql迁移之新建用户、备份还原数据库

事例➜ 1 mysql -uzixie -pzixie game < /temp/zixie_back.sqlmysql: [Warning] Using a password on the command line interface can be insecure.➜ 1 mysql -uzixie -p"zixie"mysql: [Warning] Using a password on the command line interface can be insecu…

centos radius mysql_FreeRadius2 MySQL配置

FreeRadius2可以和MySQL进行集成&#xff0c;集成的内容包括创建符合要求的数据库和表结构&#xff0c;为MySQL进行的相关配置&#xff0c;基于数据库安装Web管理程序(如daloradius,ARA等)&#xff0c;大部分内容可以参见0. 环境FreeRadius2 / MySQL 5 /CentOS 5.5(VirtualBox)…

需求调研的方法及过程_培训需求调研方法

课程设计与开发是每一位职业培训师都必须会的技能&#xff0c;今天我们就来分享一下如何开发课程。第一节课&#xff0c;让我们先从培训需求调研开始。培训需求调研方法有很多&#xff0c;从个体层次分为&#xff1a;问卷法、观察法、访谈法&#xff1b;从组织层次分为&#xf…

java报错空指针异常_java – 空指针异常错误,没有明显的代码错误

我在这里有一个错误,我不知道它来自哪里.我在初学者的java课程是高中,所以我在这里还没有太多的经验.我有3个相互合并的程序.我有一个卡片类,可以创建一张扑克牌//********************************************************************// Card.java Author: Lewis and Loftus…

mysql表的设计几种方式_支持多种登录方式的数据表设计 | 六阿哥博客

一个带有用户系统的应用最基本登录方式是站内账号登录&#xff0c;但这种方式往往不能满足我们的需求。现在的应用基本都有站内账号、email、手机和一堆第三方登录&#xff0c;那么如果需要支持这么多种登录方式&#xff0c;或者还有银行卡登录、身份证登录等等更多的登录方式&…