首页 > 其他分享 >基于EtherCAT运动控制卡的自定义运动曲线设置说明

基于EtherCAT运动控制卡的自定义运动曲线设置说明

时间:2022-09-28 14:36:06浏览次数:64  
标签:封装 Qt 自定义 控制卡 接口 运动 EtherCAT

今天,正运动小助手给大家分享一下EtherCAT运动控制卡的自定义运动曲线,主要介绍一下如何通过在线命令封装自己想使用的Basic指令到上位机接口中供上位机调用。


一、ECI2828运动控制卡的硬件介绍

ECI2828系列控制卡支持最多达16轴直线插补、任意圆弧插补、空间圆弧、螺旋插补、电子凸轮、电子齿轮、同步跟随、虚拟轴、机械手指令等。采用优化的网络通讯协议可以实现实时的运动控制。

ECI2828系列运动控制卡支持以太网,232通讯接口和电脑相连,接收电脑的指令运行,可以通过EtherCAT总线和CAN总线去连接各个扩展模块,从而扩展输入输出点数或运动轴。

ECI2828系列运动控制卡的应用程序可以使用 VC、VB、VS、C++、C#等多种高级语言来开发,程序运行时需要动态库zmotion.dll。调试时可以把ZDevelop软件同时连接到控制器,从而方便调试、方便观察。

企业微信截图_20220927084609.png

ECI2828控制卡本身的硬件接口也十分丰富。具有8个本地脉冲轴,每个轴带独立编码器,最多16个虚拟轴。板上自带24个通用输入口(其中4路是高速输入口可以作为高速锁存使用),16个通用输出口(其中4路是高速输出口可以实现4路的PSO),2路AD和DA。

自带1个 RS232串口,1个以太网接口。带一个CAN总线接口,支持通过ZCAN协议来连接扩展模块。带一个CANOPEN接口(功能需要软件版本支持)。带一个EtherCAT总线接口可扩展数字模拟IO以及脉冲定位模块等,带一个手轮接口。

企业微信截图_20220927084628.png

 

二、运动控制卡的Qt开发流程

1.新建Qt 项目

企业微信截图_20220927084655.png

企业微信截图_20220927084729.png

企业微信截图_20220927084748.png
企业微信截图_20220927084803.png

 

(1)将函数库相关的文件复制到新建的项目中。

企业微信截图_20220927085041.png

 

(2)向新建的项目里面添加函数库的静态库。(zmotion.lib)

企业微信截图_20220927085100.png

企业微信截图_20220927085115.png 

企业微信截图_20220927085130.png

(3)添加函数库相关的头文件到项目中(zmcaux.cpp、zmcaux.h、Zmotion.h)。

企业微信截图_20220927085141.png

 

(4)声明相关头文件,并定义连接句柄。

企业微信截图_20220927085156.png

 

2.PC函数介绍

(1)PC函数手册也在光盘资料里面,具体路径如下:“光盘资料\8.PC函数\函数库2.1\ZMotion函数库编程手册V2.1.pdf”。

企业微信截图_20220927085211.png

(2)PC编程一般需要建立上位机和控制器之间的链接。和控制卡的连接一般习惯使用网口方式进行链接,具体接口说明如下。
企业微信截图_20220927085223.png

(3)如果想将Basic指令封装成上位机可以直接调用的接口就必须使用在线命令这个接口进行函数封装,在线命令接口说明如下。

企业微信截图_20220927085235.png

企业微信截图_20220927085248.png
企业微信截图_20220927085300.png

(4)Basic指令SPEED的封装示例。

 

企业微信截图_20220927085316.png

 

3.Qt进行Move_Pt指令的封装,实现自定义曲线的运动。

(1)自定义曲线运动例程Qt界面如下。

企业微信截图_20220927085340.png

(2)通过Qt的connect将【连接按钮】的单击事件绑定一个槽函数进行链接控制器的操作。
企业微信截图_20220927085355.png

(3)通过定时器更新控制器各个轴的位置和速度信息。
企业微信截图_20220927085409.png

 

(4)Basic指令Move_Pt的介绍。

企业微信截图_20220927085421.png

(5)Move_Pt的接口封装。

A.通过在线命令ZAux_DirectCommand()进行接口封装。
QQ截图20220927085620.png

B.Qt例程调用刚刚封装的接口MyApi::ZAux_Direct_MovePt()。

企业微信截图_20220927085833.png
企业微信截图_20220927085849.png

C.示波器波形抓取。

企业微信截图_20220927085905.png

(6)封装一个API可以下发多个move_ptabs指令进行加工。A.一次下发多个move_ptabs指令的封装。
QQ截图20220927085934.png

 B.Qt例程调用刚封装的接口MyApi::ZAux_Direct_MovePtAbsS()。

企业微信截图_20220927090030.png

C.Qt抓取轴运动的位置数据,产生位置波形图。
QQ截图20220927090054.png

D.抓波形图查看效果。a.Y=((-sin(PI*2*i/T)/(PI*2))+i/T)*500速度和位置曲线。

企业微信截图_20220927090227.png

b.Qt抓取Y=((-sin(PI*2*i/T)/(PI*2))+i/T)*500的位置曲线。

企业微信截图_20220927090258.png

本次,正运动技术EtherCAT运动控制卡的自定义运动曲线,就分享到这里。

标签:封装,Qt,自定义,控制卡,接口,运动,EtherCAT
From: https://www.cnblogs.com/zmtion/p/16737934.html

相关文章

  • antdv 添加自定义svg图标
    1引入importIconfrom'@ant-design/icons-vue'2调用添加icon的方法Icon.add使用方式:<a-icontype="svg1"/>因为是添加到ant-design的,升级antdv出现异常时要查阅源码......
  • WPF 自定义可拖动标题栏
    要注意,拖拽的地方,需要加背景色,否则DrageMove 将无效MainWindows.xaml<Windowx:Class="Report.MainWindow"xmlns="http://schemas.microsoft.com......
  • elelment中el-cascader怎样自定义显示的lable 与value
    1、后端返回的数据类型  2、页面代码  3、重点在于 :props="{value:'id',label:'className',children:'childNode'}"  ......
  • VueJs 自定义过滤器使用总结
    在这个教程中,我们将会通过几个例子,了解和学习VueJs的过滤器。我们参考了一些比较完善的过滤器,比如orderBy和filterBy。而且我们可以链式调用过滤器,一个接一个过滤。因此,我......
  • Echarts自定义提示框案例
    官方文档:#tooltip.formatter两种方法,如trigger:'axis'的情况下,均在tooltip节点下添加如下:1.模板字符串formatter:'<spanstyle="font-size:10px">{b}</span><div......
  • java异常--自定义异常
    java异常--自定义异常步骤:创建自定义异常类。在方法中通过throw关键字抛出异常对象。处理异常try-catch捕获并处理,否则在方法声明处通过throws关键字指明抛出给......
  • django rest-framework 自定义异常捕获类
    djangorest-framework自定义异常捕获类环境:django3.2python3先创建文件exceptions.py(文件名称可以自定义)1、重写exception_handler,自定义异常类#-*-coding:ut......
  • 创建自定义UserInfo表
    models.py中fromdjango.contrib.auth.modelsimportAbstractUserfromdjango_pandas.managersimportDataFrameManager#Createyourmodelshere.classUserIn......
  • vue3+ts项目自定义input组件
    官网讲解v-model的原理<inputv-model="searchText"/>//等同于<input:value="searchText"@input="searchText=$event.target.value"/>//当用在组件上时,v-mode......
  • 注解-自定义注解-元注解和解析注解
    注解-自定义注解-元注解元注解:就是用于描述注解的注解@Target:描述注解能够作用的位置@Retention:苗猪注解被保留的阶段@Documented:描述注解是......