上位机图像处理和嵌入式模块部署(qmacvisual之plc通信)

2024-04-06 02:04

本文主要是介绍上位机图像处理和嵌入式模块部署(qmacvisual之plc通信),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

        传统的非标自动化设备当中,plc发挥了很大的作用。这里面如何对这些电机和机构进行控制,大多数场景下用的就是plc设备了。目前的plc主要分成四派,一部分来自于德国,以西门子为代表;一部分来自于日本,以三菱、欧姆龙为代表;还有一部分来自于中国台湾,以台达为代表;最后一部分就是大陆,这部分以汇川、信捷为代表。当然,我们都知道plc本身就是单片机+上位机编程构成的基本控制工具,之前主要用梯形图进行开发,后期转成了TypeScript。当然,不管是哪一种方式,都需要上位机来进行合理对接的。

        qmacvisual本身支持plc通信,但是目前支持的品牌很少,只有三菱plc。由于手上暂时没有相关的设备,暂时只能手动编写一个tcp server仿真代替。

1、创建工程、创建流程

        要使用qmacvisual,创建好工程和流程是很重要的一步。

2、准备好tcp server工具

        因为没有三菱plc,所以我们可以编写一个简单的tcp server程序来冒充仿真一下。没有这一步的作弊,后面的plc插件很难配置。相关的代码可以通过chatgpt直接生成,

// server.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//#include <iostream>
#include <winsock2.h>
#include <ws2tcpip.h>#pragma comment(lib, "Ws2_32.lib")int main() {// 初始化Winsock库WSADATA wsaData;if (WSAStartup(MAKEWORD(2, 2), &wsaData) != 0) {std::cerr << "WSAStartup failed." << std::endl;return 1;}// 创建服务器的socketSOCKET listenSocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);if (listenSocket == INVALID_SOCKET) {std::cerr << "Error creating socket: " << WSAGetLastError() << std::endl;WSACleanup();return 1;}// 设置服务器地址和端口sockaddr_in serverAddr;serverAddr.sin_family = AF_INET;serverAddr.sin_addr.s_addr = htonl(INADDR_ANY);  // 接受来自任何地址的连接serverAddr.sin_port = htons(12000);  // 设置端口为12000// 绑定socket到服务器地址if (bind(listenSocket, reinterpret_cast<sockaddr*>(&serverAddr), sizeof(serverAddr)) == SOCKET_ERROR) {std::cerr << "Bind failed with error: " << WSAGetLastError() << std::endl;closesocket(listenSocket);WSACleanup();return 1;}// 开始监听连接if (listen(listenSocket, SOMAXCONN) == SOCKET_ERROR) {std::cerr << "Listen failed with error: " << WSAGetLastError() << std::endl;closesocket(listenSocket);WSACleanup();return 1;}std::cout << "Server started, waiting for connections..." << std::endl;// 接受客户端连接SOCKET clientSocket;sockaddr_in clientAddr;int clientAddrSize = sizeof(clientAddr);while (true) {clientSocket = accept(listenSocket, reinterpret_cast<sockaddr*>(&clientAddr), &clientAddrSize);if (clientSocket == INVALID_SOCKET) {std::cerr << "Accept failed with error: " << WSAGetLastError() << std::endl;closesocket(listenSocket);WSACleanup();return 1;}std::cout << "Client connected." << std::endl;// 接收数据char buffer[1024];int bytesReceived = recv(clientSocket, buffer, sizeof(buffer), 0);if (bytesReceived == SOCKET_ERROR) {std::cerr << "Recv failed with error: " << WSAGetLastError() << std::endl;closesocket(clientSocket);continue;}// 打印接收到的数据buffer[bytesReceived] = '\0'; // 添加字符串结束符std::cout << "Received data from client: " << buffer << std::endl;// 发送响应const char* response = "Hello from server!";int bytesSent = send(clientSocket, response, strlen(response), 0);if (bytesSent == SOCKET_ERROR) {std::cerr << "Send failed with error: " << WSAGetLastError() << std::endl;}// 关闭连接closesocket(clientSocket);std::cout << "Client disconnected." << std::endl;}// 关闭监听socketclosesocket(listenSocket);// 清理Winsock库WSACleanup();return 0;
}

3、配置plc设备

        准备好了tcp server仿真程序之后,就可以配置plc设备了。还是在仪器通讯窗口里面,我们首先选择PLC通信,单击添加仪器。准备好了之后,选中Mitsubishi PLC_1,依次设置ip和port,单击保存参数即可。因为之前的tcp server已经启动,所以这部分直接单击连接仪器按钮就行。不出意外的话,我们可以看到一个连接成功的弹窗。

4、使用plc控件

        plc控件的位置位于【通讯工具】下面。我们用鼠标直接拖到流程窗口下面,单击即可。正常情况下,可以看到这样的内容,

        单击更新列表,就可以查找到所有的plc设备。单击添加按钮,就可以看到一个PLC寄存器的链接地址。双击这个链接地址,就会看到新的弹窗内容,

        还是这个窗口,我们会看到多了很多的内容,比如通信的格式、通信的模式、访问方式以及寄存器地址等等。这里我们可以设置一下寄存器地址,单击参数保存之后,同时退回上一页,就可以看到链接的内容发生了变化。单个plc可以设置多个寄存器链接。

        当然,刚才我们看到的仅仅是读取的内容,另外一部分就是写的内容。还是以D0寄存器为例,假设通信模式为写的时候,寄存器写入数值就不再是灰化的状态,需要我们关联一个全局变量,即把寄存器的数值读到这个变量里面。

        当然如果要同时获取读写数据的话,只能通过控件的输入、输出来完成了。

          要使用号这个plc控件并不容易,需要自己去适配对应的设备。另外【通讯工具】下面的【通用I/O】插件功能也并不完整,需要自己补充完相应的代码才能正常使用。但是瑕不掩瑜,整个驱动的结构还是非常清晰的,值得看看、学习一下。

这篇关于上位机图像处理和嵌入式模块部署(qmacvisual之plc通信)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878738

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5