找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4852|回复: 1
打印 上一主题 下一主题
收起左侧

串口三轴CNC控制类(只实现了G00和G01两条命令)

[复制链接]
跳转到指定楼层
楼主
ID:72008 发表于 2015-1-11 20:11 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include
  2. using namespace std;

  3. class CNC //CNC控制类
  4. {
  5. //私有方法部分
  6. protected:
  7. int CNC_x;//x轴当前值
  8. int CNC_y;//y轴当前值
  9. int CNC_Z;//z轴当前值
  10. int CNC_YS_X;//原点x坐标值
  11. int CNC_YS_Y;//原点y坐标值
  12. int CNC_YS_Z;//原点z坐标值

  13. //屏幕GDI函数用到的一些坐标
  14. int CNC_GDI_X; //屏幕显示偏移坐标
  15. int CNC_GDI_Y;
  16. int CNC_GDI_X_x; //x框架轴坐标
  17. int CNC_GDI_X_y;
  18. int CNC_GDI_Y_x; //y轴框架坐标
  19. int CNC_GDI_Y_y;
  20. int CNC_GDI_Z_x; //z轴框架坐标
  21. int CNC_GDI_Z_y;
  22. int CNC_GDI_D_x; /具位置坐标
  23. int CNC_GDI_D_y;
  24. int CNC_GDI_D_Z; //下刀深度

  25. //GDI函数用到的一些句柄
  26. HDC hdc; //获取绘图DC句柄
  27. HPEN hpen_x; //x轴画笔
  28. HBRUSH hbrush_x; //x轴画刷
  29. HPEN hpen_y; //y轴画笔
  30. HBRUSH hbrush_y; //y轴画刷
  31. HPEN hpen_z; //z轴画笔
  32. HBRUSH hbrush_z; //z轴画刷
  33. HPEN hpen_D; /路画笔
  34. HPEN hpen_cls; //清屏画笔
  35. HBRUSH hbrush_cls; //清屏画刷
  36. HPEN hpen_GJ; //工件画笔
  37. HBRUSH hbrush_GJ; //工件画刷




  38. //公共方法部分
  39. public:
  40. CNC(void);
  41. ~CNC(void);
  42. void CNC_GDI_DC(void); //初始化GDI绘图相关句柄
  43. void CNC_GDI_CLS(void); //清屏并画工件
  44. void CNC_GDI(void); //屏幕输出CNC状态
  45. void CNC_X_进(void); //x轴操作
  46. void CNC_X_退(void);
  47. void CNC_Y_进(void); //y轴操作
  48. void CNC_Y_退(void);
  49. void CNC_Z_进(void); //z轴操作
  50. void CNC_Z_退(void);
  51. void CNC_COM(void); //COM口驱动信号输出
  52. void CNC_DuiDao(void); //手动对刀设置原点
  53. int CNC_G00(char x,int x_z,char y,int y_z,char z,int z_z); //G00指令实现
  54. int CNC_G01(char x,int x_z,char y,int y_z,char z,int z_z,int f); //G01指令实现
  55. };


  56. #include "stdafx.h"
  57. #include "CNC控制.h"

  58. int CNC_GDI_DL[440][780];

  59. CNC::CNC(void)
  60. {
  61. //初始化
  62. //屏幕显示参考坐标,整个三轴都以此点为偏移
  63. CNC_GDI_X=30;
  64. CNC_GDI_Y=20;
  65. //为x,y,z轴坐标值及刀具位置坐标赋初值
  66. CNC_GDI_X_x=CNC_GDI_X; //x轴宽度为900像素
  67. CNC_GDI_X_y=CNC_GDI_Y;
  68. CNC_GDI_Y_x=CNC_GDI_X_x+10; //y轴宽度为500像素
  69. CNC_GDI_Y_y=CNC_GDI_X_y-10;
  70. CNC_GDI_Z_x=CNC_GDI_Y_x-10; //z轴深度屏幕上无法表示出来
  71. CNC_GDI_Z_y=CNC_GDI_Y_y+20;
  72. CNC_GDI_D_x=CNC_GDI_Z_x+35; /具位置坐标
  73. CNC_GDI_D_y=CNC_GDI_Z_y+25;
  74. CNC_GDI_D_Z=0; //下刀深度初始化
  75. int x,y;
  76. for(y=0;y<440;y++)
  77. for(x=0;x<780;x++)
  78. {
  79. CNC_GDI_DL[y][x]=0;
  80. }

  81. //////////////////////////////////////
  82. //初始化原点
  83. CNC_YS_X=CNC_GDI_D_x;
  84. CNC_YS_Y=CNC_GDI_D_y;
  85. CNC_YS_Z=CNC_GDI_D_Z;


  86. }

  87. CNC::~CNC(void)
  88. {
  89. // 释放资源
  90. DeleteObject(hpen_x);
  91. DeleteObject(hbrush_x);
  92. DeleteObject(hpen_y);
  93. DeleteObject(hbrush_y);
  94. DeleteObject(hpen_z);
  95. DeleteObject(hbrush_z);
  96. DeleteObject(hpen_x);
  97. DeleteObject(hpen_D);
  98. DeleteObject(hpen_x);

  99. }

  100. void CNC::CNC_GDI_CLS(void)
  101. {
  102. // 为DC选择笔和笔刷
  103. SelectObject(hdc, hpen_cls);
  104. SelectObject(hdc, hbrush_cls);
  105. // 绘制清屏矩形
  106. Rectangle( hdc,0,0,900,550 );
  107. // 为DC选择笔和笔刷
  108. SelectObject(hdc, hpen_GJ);
  109. SelectObject(hdc, hbrush_GJ);
  110. // 绘制工件矩形
  111. Rectangle( hdc,80,60,800,500 );
  112. //绘制刀路
  113. int x,y;
  114. if(CNC_GDI_D_Z>0&&CNC_GDI_D_y>=60&&CNC_GDI_D_x>=70&&CNC_GDI_D_y<=500&&CNC_GDI_D_x<=850)
  115. {
  116. //记录刀路

  117. CNC_GDI_DL[CNC_GDI_D_y-60][CNC_GDI_D_x-70]=CNC_GDI_D_Z;
  118. }

  119. for(y=0;y<440;y++)
  120. for(x=0;x<780;x++)
  121. {
  122. if(CNC_GDI_DL[y][x]!=0)
  123. {
  124. SetPixel (hdc, x+70, y+60,RGB(0,0,255));
  125. }
  126. }

  127. }

  128. void CNC::CNC_GDI_DC(void)
  129. {
  130. //初始化绘图DC
  131. CWnd * pWnd = AfxGetMainWnd();
  132. HWND haha = pWnd->m_hWnd;
  133. hdc = GetDC(haha); //这个DC为全局的
  134. hpen_x=CreatePen(PS_SOLID,1, RGB(255,255,0));
  135. hbrush_x=CreateSolidBrush(RGB(255,255,0));
  136. hpen_y=CreatePen(PS_SOLID,1, RGB(0,255,0));
  137. hbrush_y=CreateSolidBrush(RGB(0,255,0));
  138. hpen_z=CreatePen(PS_SOLID,1, RGB(255,0,0));
  139. hbrush_z=CreateSolidBrush(RGB(255,0,0));
  140. hpen_D=CreatePen(PS_SOLID,1, RGB(0,0,255));
  141. hpen_cls=CreatePen(PS_SOLID,1, RGB(0,0,0));
  142. hbrush_cls=CreateSolidBrush(RGB(0,0,0));
  143. hpen_GJ=CreatePen(PS_SOLID,1, RGB(128,255,255));
  144. hbrush_GJ=CreateSolidBrush(RGB(128,255,255));

  145. }

  146. void CNC::CNC_GDI(void)
  147. {
  148. CNC_GDI_CLS();
  149. // 为DC选择笔和笔刷
  150. SelectObject(hdc, hpen_x);
  151. SelectObject(hdc, hbrush_x);
  152. // 绘制x轴框架
  153. Rectangle( hdc,CNC_GDI_X_x,CNC_GDI_X_y,CNC_GDI_X_x+900,CNC_GDI_X_y+10 );
  154. Rectangle( hdc,CNC_GDI_X_x,CNC_GDI_X_y+510,CNC_GDI_X_x+900,CNC_GDI_X_y+10+510 );
  155. ///////////////////////////////////////////////////
  156. // 为DC选择笔和笔刷
  157. SelectObject(hdc, hpen_y);
  158. SelectObject(hdc, hbrush_y);
  159. // 绘制y轴框架
  160. Rectangle( hdc,CNC_GDI_Y_x,CNC_GDI_Y_y,CNC_GDI_Y_x+10,CNC_GDI_Y_y+540 );
  161. Rectangle( hdc,CNC_GDI_Y_x+40,CNC_GDI_Y_y,CNC_GDI_Y_x+10+40,CNC_GDI_Y_y+540 );
  162. ///////////////////////////////////////////////////
  163. // 为DC选择笔和笔刷
  164. SelectObject(hdc, hpen_z);
  165. SelectObject(hdc, hbrush_z);
  166. // 绘制z轴框架
  167. Rectangle( hdc,CNC_GDI_Z_x,CNC_GDI_Z_y,CNC_GDI_Z_x+70,CNC_GDI_Z_y+10 );
  168. Rectangle( hdc,CNC_GDI_Z_x,CNC_GDI_Z_y+40,CNC_GDI_Z_x+70,CNC_GDI_Z_y+10+40 );
  169. Rectangle( hdc,CNC_GDI_Z_x+30,CNC_GDI_Z_y+20,CNC_GDI_Z_x+40,CNC_GDI_Z_y+30);
  170. }

  171. void CNC::CNC_COM(void)
  172. {
  173. //从串口输出三轴步进电机驱动信号
  174. }

  175. void CNC::CNC_DuiDao(void)
  176. {
  177. //手动对刀设置原点
  178. CNC_YS_X=CNC_GDI_D_x;
  179. CNC_YS_Y=CNC_GDI_D_y;
  180. CNC_YS_Z=CNC_GDI_D_Z;
  181. }

  182. void CNC::CNC_X_进(void)
  183. {
  184. //x轴进给一个单位
  185. if(CNC_GDI_Y_x<(CNC_GDI_X+840))
  186. {
  187. CNC_GDI_Y_x+=1;
  188. CNC_GDI_Z_x+=1;
  189. CNC_GDI_D_x+=1;
  190. CNC_GDI();
  191. CNC_COM();
  192. }
  193. }

  194. void CNC::CNC_X_退(void)
  195. {
  196. //x轴后退一个单位
  197. if(CNC_GDI_Y_x>CNC_GDI_X+10)
  198. {
  199. CNC_GDI_Y_x-=1;
  200. CNC_GDI_Z_x-=1;
  201. CNC_GDI_D_x-=1;
  202. CNC_GDI();
  203. CNC_COM();
  204. }
  205. }

  206. void CNC::CNC_Y_进(void)
  207. {
  208. //y轴进给一个单位
  209. if(CNC_GDI_Z_y<(CNC_GDI_Y+460))
  210. {
  211. CNC_GDI_Z_y+=1;
  212. CNC_GDI_D_y+=1;
  213. CNC_GDI();
  214. CNC_COM();
  215. }
  216. }

  217. void CNC::CNC_Y_退(void)
  218. {
  219. //y轴后退一个单位
  220. if(CNC_GDI_Z_y>(CNC_GDI_Y+10))
  221. {
  222. CNC_GDI_Z_y-=1;
  223. CNC_GDI_D_y-=1;
  224. CNC_GDI();
  225. CNC_COM();
  226. }
  227. }

  228. void CNC::CNC_Z_进(void)
  229. {
  230. if(CNC_GDI_D_Z<10)
  231. {
  232. CNC_GDI_D_Z+=1;
  233. }
  234. CNC_GDI();
  235. CNC_COM();
  236. }

  237. void CNC::CNC_Z_退(void)
  238. {
  239. if(CNC_GDI_D_Z>0)
  240. {
  241. CNC_GDI_D_Z-=1;
  242. }
  243. CNC_GDI();
  244. CNC_COM();
  245. }

  246. int CNC::CNC_G00(char x,int x_z,char y,int y_z,char z,int z_z)
  247. {
  248. //G00指令实现
  249. int a,b,c;
  250. CNC_GDI_D_Z=0;
  251. for( a=1,b=1,c=1;a==1||b==1||c==1;)
  252. {
  253. if((x_z+CNC_YS_X)==CNC_GDI_D_x)
  254. {
  255. a=0;
  256. } else if((x_z+CNC_YS_X)<CNC_GDI_D_x&&a==1)
  257. {
  258. CNC_X_退();
  259. }else if((x_z+CNC_YS_X)>CNC_GDI_D_x&&a==1)
  260. {
  261. CNC_X_进();
  262. }

  263. if((y_z+CNC_YS_Y)==CNC_GDI_D_y)
  264. {
  265. b=0;
  266. } else if((y_z+CNC_YS_Y)<CNC_GDI_D_y&&b==1)
  267. {
  268. CNC_Y_退();
  269. }else if((y_z+CNC_YS_Y)>CNC_GDI_D_y&&b==1)
  270. {
  271. CNC_Y_进();
  272. }

  273. if((z_z+CNC_YS_Z)==CNC_GDI_D_Z)
  274. {
  275. c=0;
  276. } else if((z_z+CNC_YS_Z)<CNC_GDI_D_Z&&c==1)
  277. {
  278. CNC_Z_退();
  279. }else if((z_z+CNC_YS_Z)>CNC_GDI_D_Z&&c==1)
  280. {
  281. CNC_Z_进();
  282. }
  283. Sleep(10);

  284. }


  285. return 1;
  286. }

  287. int CNC::CNC_G01(char x,int x_z,char y,int y_z,char z,int z_z,int f)
  288. {
  289. //G00指令实现
  290. int a,b,c;
  291. for( a=1,b=1,c=1;a==1||b==1||c==1;)
  292. {
  293. if((x_z+CNC_YS_X)==CNC_GDI_D_x)
  294. {
  295. a=0;
  296. } else if((x_z+CNC_YS_X)<CNC_GDI_D_x&&a==1)
  297. {
  298. CNC_X_退();
  299. }else if((x_z+CNC_YS_X)>CNC_GDI_D_x&&a==1)
  300. {
  301. CNC_X_进();
  302. }

  303. if((y_z+CNC_YS_Y)==CNC_GDI_D_y)
  304. {
  305. b=0;
  306. } else if((y_z+CNC_YS_Y)<CNC_GDI_D_y&&b==1)
  307. {
  308. CNC_Y_退();
  309. }else if((y_z+CNC_YS_Y)>CNC_GDI_D_y&&b==1)
  310. {
  311. CNC_Y_进();
  312. }

  313. if((z_z+CNC_YS_Z)==CNC_GDI_D_Z)
  314. {
  315. c=0;
  316. } else if((z_z+CNC_YS_Z)<CNC_GDI_D_Z&&c==1)
  317. {
  318. CNC_Z_退();
  319. }else if((z_z+CNC_YS_Z)>CNC_GDI_D_Z&&c==1)
  320. {
  321. CNC_Z_进();
  322. }
  323. Sleep(f);

  324. }
  325. return 1;
  326. }
复制代码


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:243748 发表于 2017-12-3 12:47 来自手机 | 只看该作者
这是51单片机程序吗
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表