C# GTS四轴运动控制器实例(固高科技步进电机不带编码器)

news2025/1/13 7:30:24

注:由于电机不带编码器,无法做home和当前位置信息读取!

功能:

三个轴的点位运动:前进+后退,并分别显示每个轴的移动脉冲数(可以换算为距离)!

开发环境:VS2017

硬件设备:固高科技三维移动平台

在上一版上添加了如下功能:

  1. 记录每次运行的距离,即使关闭软件,也能记录当前距离原点的距离(原点首次得在机台选定)

  2. 运行超出机台的最大距离后停止运动.

  3. 6a517caa9f6eeede340c14f349a76f50.png

    源码:

  4. using System;
    using System.Windows.Forms;
    using gts;
    using System.Xml;
    using System.Collections.Generic;
    
    
    
    
    namespace 三维平移台控制系统
    {
        public partial class mainFrom : DevComponents.DotNetBar.OfficeForm
        {
            public mainFrom()
    {
                this.EnableGlass = false;
                InitializeComponent();
            }
            short Rtn;
            int  vel = 0;
            int[] pos= {0,0,0 };
            int[] pos1 = { 0, 0, 0 };
            bool flag = false;
            uint clk;
            double prfpos, prfvel, encpos, encvel;
            short AXIS = 1;
    
    
            int X = 0;
            int Y = 0;
            int Z = 0;
    
    
    
    
            private void buttonX1_Click(object sender, EventArgs e)
    {
              
                mc.GT_ZeroPos(AXIS, 1);
                //for (int i=0; i<3;i++)
                //{
                //    pos1[i] += pos[i];
                //}
                pos1[AXIS - 1] += pos[AXIS - 1];
                pos[AXIS-1] = 0;
               
            }
    
    
            private void buttonX2_Click(object sender, EventArgs e)
    {
                //Rtn = mc.GT_Close();
                Rtn = mc.GT_PrfTrap(AXIS);
                mc.TTrapPrm trapprm;
                mc.GT_GetTrapPrm(AXIS, out trapprm);
                trapprm.acc = 0.1;//设置加速度
                trapprm.dec = 0.1;//设置减速度
                trapprm.smoothTime = 1;
                mc.GT_SetTrapPrm(AXIS, ref trapprm);
                pos[AXIS-1] += Convert.ToInt32(textBoxX1.Text)*500;
                vel = Convert.ToInt32(textBoxX2.Text)*2;
                mc.GT_SetPos(AXIS, pos[AXIS-1]);
                mc.GT_SetVel(AXIS, vel);
                // mc.GT_Update(AXIS);
                mc.GT_Update(1 << (AXIS - 1));
                //MessageBox.Show((1 << (AXIS - 1)).ToString());
            }
    
    
            private void buttonX3_Click(object sender, EventArgs e)
    {
                //Rtn = mc.GT_Close();
                Rtn = mc.GT_PrfTrap(AXIS);
                mc.TTrapPrm trapprm;
                mc.GT_GetTrapPrm(AXIS, out trapprm);
                trapprm.acc = 0.1;
                trapprm.dec = 0.1;
                trapprm.smoothTime = 1;
                mc.GT_SetTrapPrm(AXIS, ref trapprm);
                pos[AXIS-1] -= Convert.ToInt32(textBoxX1.Text)*500;
                vel = Convert.ToInt32(textBoxX2.Text)*2;
                mc.GT_SetPos(AXIS, pos[AXIS-1]);
                mc.GT_SetVel(AXIS, vel);
                //mc.GT_Update(AXIS);
                mc.GT_Update(1 << (AXIS - 1));
            }
    
    
            private void timer1_Tick(object sender, EventArgs e)
    {
                //if ()
                //{
                //    mc.GT_GetPrfPos(AXIS, out prfpos, 1, out clk);// profile 起始轴号
                //    mc.GT_GetEncPos(AXIS, out encpos, 1, out clk);// encoder 起始轴号
                //    textBox3.Text = prfpos.ToString();
                //    textBox5.Text = encpos.ToString();
                //    mc.GT_GetPrfVel(AXIS, out prfvel, 1, out clk);// 起始规划轴号
                //    mc.GT_GetEncVel(AXIS, out encvel, 1, out clk);// encoder 起始轴号
                //    textBox4.Text = prfvel.ToString();
                //    textBox6.Text = encvel.ToString();
                //}
                List<KeyValuePair<string, string>> settings = new List<KeyValuePair<string, string>>();
                KeyValuePair<string, string> kv = new KeyValuePair<string, string>("", "");
    
    
                mc.GT_GetPrfPos(AXIS, out prfpos, 1, out clk);// profile 起始轴号
                mc.GT_GetPrfVel(AXIS, out prfvel, 1, out clk);// 起始规划轴号
                if (AXIS == 1)
                {
                    labelX4.Text = "规划位置 : " + (prfpos / 500).ToString() + " mm";
                    labelX5.Text = "规划速度 : " + (prfvel / 2).ToString() + " mm/s";
                    kv = new KeyValuePair<string, string>("X", ((prfpos + pos1[0]) / 500 +X).ToString());
                    settings.Add(kv);
                    labelX10.Text = "距离原点 : " + ((prfpos + pos1[0])/500 + X).ToString() + " mm";
                    if ((prfpos + pos1[0]) / 500 + X > 850)
                        mc.GT_Stop(AXIS, 0);
    
    
                }
                else if (AXIS == 2)
                {
                    labelX6.Text = "规划位置 : " + (prfpos / 500).ToString() + " mm";
                    labelX7.Text = "规划速度 : " + (prfvel / 2).ToString() + " mm/s";
                    kv = new KeyValuePair<string, string>("Y", ((prfpos + pos1[1]) / 500 + Y).ToString());
                    settings.Add(kv);
                    labelX11.Text = "距离原点 : " + ((prfpos + pos1[1]) / 500 + Y).ToString() + " mm";
                    if ((prfpos + pos1[1]) / 500 + Y > 500)
                        mc.GT_Stop(AXIS, 0);
                }
                else if (AXIS == 3)
                {
                    labelX8.Text = "规划位置 : " + (prfpos / 500).ToString() + " mm";
                    labelX9.Text = "规划速度 : " + (prfvel / 2).ToString() + " mm/s";
                    kv = new KeyValuePair<string, string>("Z", ((prfpos + pos1[2]) / 500 + Z).ToString());
                    settings.Add(kv);
                    labelX12.Text = "距离原点 : " + ((prfpos + pos1[2]) / 500 + Z).ToString() + " mm";
                    if ((prfpos + pos1[2]) / 500 + Z > 500)
                        mc.GT_Stop(AXIS, 0);
    
    
                }
                SaveSettings(settings);
    
    
            }
            private void ReadConfigXML()
    {
                XmlDocument xmlDoc = new XmlDocument();
                xmlDoc.Load(AppDomain.CurrentDomain.BaseDirectory + "\\config.xml");
                XmlNode settingNode = xmlDoc.DocumentElement;
    
    
                XmlElement e = settingNode.SelectSingleNode("X") as XmlElement;
                if (e == null)
                {
                    X = 0;
                }
                else
                {
                    int val = 0;
                    if (!int.TryParse(e.InnerText, out val))
                    {
                        X = 0;
                    }
                    else
                    {
                        X = val;
                    }
                }
    
    
                e = settingNode.SelectSingleNode("Y") as XmlElement;
                if (e == null)
                {
                    Y = 0;
                }
                else
                {
                    int val = 0;
                    if (!int.TryParse(e.InnerText, out val))
                    {
                        Y = 0;
                    }
                    else
                    {
                        Y = val;
                    }
                }
    
    
                e = settingNode.SelectSingleNode("Z") as XmlElement;
                if (e == null)
                {
                    Z = 0;
                }
                else
                {
                    int val = 0;
                    if (!int.TryParse(e.InnerText, out val))
                    {
                        Z = 0;
                    }
                    else
                    {
                        Z = val;
                    }
                }
    
    
    
    
            }
    
    
            private void mainFrom_Load(object sender, EventArgs e)
    {
                comboBoxEx1.SelectedIndex = 0;
    
    
                textBoxX1.Text = "4";
                textBoxX2.Text = "5";
               
               
                labelX4.Text = "规划位置 : " + (0).ToString() + " mm";
                labelX5.Text = "规划速度 : " + (0).ToString() + " mm/s";
               
               
                labelX6.Text = "规划位置 : " + (0).ToString() + " mm";
                labelX7.Text = "规划速度 : " + (0).ToString() + " mm/s";
               
                labelX8.Text = "规划位置 : " + (0).ToString() + " mm";
                labelX9.Text = "规划速度 : " + (0).ToString() + " mm/s";
    
    
              
                /*初始化*/
                Rtn = mc.GT_Open(0, 1);
                Rtn = mc.GT_Reset();
                Rtn = mc.GT_LoadConfig("GTS800.cfg"); ;
                Rtn = mc.GT_ClrSts(1, 8); //axis 起始轴号,count 
    
    
                ReadConfigXML();
                labelX10.Text = "距离原点 : " + (X).ToString() + " mm";
                labelX11.Text = "距离原点 : " + (Y).ToString() + " mm";
                labelX12.Text = "距离原点 : " + (Z).ToString() + " mm";
    
    
                labelX13.Text = "最大距离 : " + (850).ToString() + " mm";
                labelX14.Text = "最大距离 : " + (500).ToString() + " mm";
                labelX15.Text = "最大距离 : " + (500).ToString() + " mm";
                timer1.Enabled = true;
            }
    
    
            private void buttonX4_Click(object sender, EventArgs e)
    {
                mc.GT_Stop(AXIS, 0);
            }
    
    
            private void comboBoxEx1_SelectedIndexChanged(object sender, EventArgs e)
    {
                switch (comboBoxEx1.SelectedItem.ToString())
                {
                    case "X轴":
                        AXIS = 1; break;
                    case "Y轴":
                        AXIS = 2; break;
                    case "Z轴":
                        AXIS = 3; break;
                    default:break;
                }
            }
    
    
            public static void SaveSettings(List<KeyValuePair<string, string>> settings)
    {
                try
                {
                    string docPath = AppDomain.CurrentDomain.BaseDirectory + "\\config.xml";
                    XmlDocument xmlDoc = new XmlDocument();
                    xmlDoc.Load(docPath);
                    XmlNode settingNode = xmlDoc.DocumentElement;
                    if (settingNode == null)
                        return;
    
    
                    foreach (var kv in settings)
                    {
                        SetNodeValue(xmlDoc, settingNode, kv.Key, kv.Value);
                    }
    
    
                    xmlDoc.Save(docPath);
                }
                catch { }
            }
    
    
            private static void SetNodeValue(XmlDocument XmlDoc, XmlNode rootnode, string key, string value)
    {
                try
                {
                    XmlElement e = rootnode.SelectSingleNode(key) as XmlElement;
                    if (e == null)
                    {
                        XmlNode node = XmlDoc.CreateNode(XmlNodeType.Element, key, "");
                        node.InnerText = value;
                        rootnode.AppendChild(node);
                    }
                    else
                    {
                        e.InnerText = value;
                    }
                }
                catch { }
            }
    
    
        }
    }

    04bafd9ae1443226924fb3d362995f72.png

    c6fa1fc8e7f7c14a0238e7dc73d32545.png

    ——————————

  5. 经典回顾

    往期推荐

    C# WPF框架Caliburn.Micro入门实例1

    C# WPF MVVM项目实战(进阶①)

    C# WPF MVVM项目实战(进阶②)

    C# WPF框架Caliburn.Micro快速搭建

    C# WPF项目实战

    C# WPF mvvm模式下combobox绑定(list<enum>、Dictionary<int,string>)

    C# WPF MVVM模式下在主窗体显示子窗体并获取结果

    C# WPF Caliburn.Micro框架下利用Mef加载其它项目界面

    C# WPF文本框TextEdit不以科学计数法显示

    C# 通过正则表达式来限制控件输入有效性

    C# datagridview、datagrid、GridControl增加行号

    C# =>符号的使用

    C# 无意间写了一段线程死锁的代码

    C# 看懂这100+行代码,你就真正入门了(经典)

    C# WPF项目实战(经典)

    WPF 如何修改button圆角(经典)

    WPF XAML 为项目设置全局样式

    de491ec415a05606e606f779198a6954.jpeg

  6. -----------------------------------

  7. 需要进技术群交流的,请添加小编zls20210502

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

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

相关文章

编程笔记 Golang基础 007 第一个程序:hello world 使用Goland

编程笔记 Golang基础 007 第一个程序&#xff1a;hello world 使用Goland 步骤1&#xff1a;启动GoLand并创建新项目步骤2&#xff1a;创建主包和主函数步骤3&#xff1a;运行程序小结 开始在Goland环境中编程go语言代码啦。 步骤1&#xff1a;启动GoLand并创建新项目 打开GoL…

[word] word中图片衬于文字下方无法显示 #媒体#微信

word中图片衬于文字下方无法显示 1、如图&#xff0c;图片“衬于文字下方”&#xff0c;文字下方的图象看不见 2、光标这位到图片上这段文字中&#xff0c;点击“格式”&#xff0d;“边框和底纹”&#xff0c;切换到“底纹”选项卡。可发现这两段文字底纹被设置成“白色”了 …

【数学建模入门】

数学建模入门 数学建模需要的学科知识怎么学习数学模型如何读好一篇优秀论文数学建模赛题常见类别数学建模常见问题数学建模组队和分工数学建模准备工作 数学建模需要的学科知识 怎么学习数学模型 &#x1f4a6;推荐阅读书籍&#xff1a; 《数学建模算法与应用》&#xff0c;…

OpenGL学习——17.模型

前情提要&#xff1a;本文代码源自Github上的学习文档“LearnOpenGL”&#xff0c;我仅在源码的基础上加上中文注释。本文章不以该学习文档做任何商业盈利活动&#xff0c;一切著作权归原作者所有&#xff0c;本文仅供学习交流&#xff0c;如有侵权&#xff0c;请联系我删除。L…

FlinkCDC详解

1、FlinkCDC是什么 1.1 CDC是什么 CDC是Chanage Data Capture&#xff08;数据变更捕获&#xff09;的简称。其核心原理就是监测并捕获数据库的变动&#xff08;例如增删改&#xff09;&#xff0c;将这些变更按照发生顺序捕获&#xff0c;将捕获到的数据&#xff0c;写入数据…

Vue | (二)Vue组件化编程 | 尚硅谷Vue2.0+Vue3.0全套教程

文章目录 &#x1f4da;模块与组件、模块化与组件化&#x1f4da;非单文件组件&#x1f407;基本使用&#x1f407;关于组件的几个注意点&#x1f407;组件的嵌套 &#x1f4da;单文件组件&#x1f407;一个.vue 文件的组成&#x1f407;实例 学习链接&#xff1a;尚硅谷Vue2.0…

多线程、分布式运行用例

python多线程 threading模块 多线程实例 # -*- coding: utf-8 -*- # Time : 2024/2/7 15:50 # Author : 居里夫人吃橘子 # File : class01.py # Software: PyCharm import threading from time import sleepdef run(name):print(name 该起床了)sleep(2)print(name …

EXCEL使用VBA一键批量转换成PDF

EXCEL使用VBA一键批量转换成PDF 上图是给定转换路径 Sub 按钮1_Click() Dim a(1 To 1000) As String Dim a2 As String Dim myfile As String Dim wb As Workbook a2 Trim(Range("a2"))myfile Dir(a2 & "\" & "*.xls")k 0Do While m…

【LeetCode】树的BFS(层序遍历)精选6题

目录 1. N 叉树的层序遍历&#xff08;中等&#xff09; 2. 二叉树的锯齿形层序遍历&#xff08;中等&#xff09; 3. 二叉树的最大宽度&#xff08;中等&#xff09; 4. 在每个树行中找最大值&#xff08;中等&#xff09; 5. 找树左下角的值&#xff08;中等&#xff09…

2024.2.20

使用多进程完成两个文件的拷贝&#xff0c;父进程拷贝前一半&#xff0c;子进程拷贝后一半&#xff0c;父进程回收子进程的资源 #include<myhead.h> int main(int argc, const char *argv[]) {char str[100]"";puts("please input str:");//从终端读…

手动实现new操作符

<script>//前置知识// 每一个函数在创建之初就会有一个prototype属性&#xff0c;这个属性指向函数的原型对象// function abc(){// }// abc.prototype--> {constructor: f}// 在JS中任意的对象都有内置的属性叫做[[prototype]]这是一个私有属性&#xff0c;这个私有属…

GEE数据集——美国两个主要石油和天然气(OG)产区内与石油和天然气(OG)相关的基础设施的位置

该数据集提供了美国两个主要石油和天然气&#xff08;O&G&#xff09;产区内与石油和天然气&#xff08;O&G&#xff09;相关的基础设施的位置&#xff1a;德克萨斯州西部和新墨西哥州南部二叠纪盆地的特拉华子盆地以及犹他州的乌因塔盆地。前言 – 人工智能教程 石油…

deep learning 代码笔记

1. pandas数据读取和预处理 # import pandas and load dataset import pandas as pd names [Sex, Length, Diameter, Height, Whole_weight, Shucked_weight, Viscera_weight, Shell_weight, Rings] data pd.read_csv(data_file, headerNone, namesnames) print(data) …

【前沿】头戴式光场显示技术研究进展

摘要&#xff1a;光场显示器旨在通过重建三维场景在不同方向发出的几何光线来渲染三维场景的视觉感知&#xff0c;从而为人的视觉系统提供自然舒适的视觉体验&#xff0c;解决传统平面立体三维显示器中的聚散调节冲突问题。近年来&#xff0c;多种光场显示方法被尝试应用到头戴…

沁恒CH32V30X学习笔记11---使用外部时钟模式2采集脉冲计数

使用外部时钟模式2采集脉冲计数 使用外部触发模式 2 能在外部时钟引脚输入的每一个上升沿或下降沿计数。将 ECE 位置位时,将使用外部时钟源模式 2。使用外部时钟源模式 2 时,ETRF 被选定为 CK_PSC。ETR 引脚经过可选的反相器(ETP),分频器(ETPS)后成为 ETRP,再经过滤波…

Stable Diffusion——stable diffusion基础原理详解与安装秋叶整合包进行出图测试

前言 在2022年&#xff0c;人工智能创作内容&#xff08;AIGC&#xff09;成为了AI领域的热门话题之一。在ChatGPT问世之前&#xff0c;AI绘画以其独特的创意和便捷的创作工具迅速走红&#xff0c;引起了广泛关注。随着一系列以Stable Diffusion、Midjourney、NovelAI等为代表…

【Linux权限】 Linux权限管理 | 粘滞位

文章目录 Linux权限管理什么是权限 ❓&#x1f4a6; 文件访问者的分类(人)&#x1f4a6; 文件类型和访问权限(事物属性) &#x1f4a6; 文件访问权限的相关设置方法目录的权限 粘滞位 Linux权限管理 什么是权限 ❓ 权限本质上是决定某件事情&#xff0c;某人能否做。 Linux下…

【GameFramework框架内置模块】2、数据节点(Data Node)

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 【GameFramework框架】系列教程目录&#xff1a; https://blog.csdn.net/q7…

AMD FPGA设计优化宝典笔记(1)触发器

高亚军老师的这本书《AMD FPGA设计优化宝典》&#xff0c;他主要讲了两个东西&#xff1a; 第一个东西是代码的良好风格&#xff1b; 第二个是设计收敛等的本质。 这个书的结构是一个总论&#xff0c;加上另外的9个优化&#xff0c;包含的有&#xff1a;时钟网络、组合逻辑、触…

从starrocks安装说起和Oracle的OLAP殊途同归

StarRocks是一款分析型数据库&#xff08;他的定语也很多&#xff0c;分布式存算分离等等&#xff09;。作为数据库他的运行和维护迟早也是落在我这里的。对于做数据库的人都知道什么是交易型数据库&#xff0c;什么是分析型数据库。以及什么是事务分析混合型数据库。但是对于非…