找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7534|回复: 21
收起左侧

基于51单片机的光驱激光雕刻机源程序电路图+上位机

  [复制链接]
ID:599807 发表于 2019-9-2 16:32 | 显示全部楼层 |阅读模式
根据他人DIY 激光雕刻机  手绘原理图 画得不好勿怪,实验操中
电路原理图如下:
555.jpg

单片机源程序如下:
  1. /*z地址定义
  2. 50 1=x+,2=x-,3=y+,4=y-
  3. 51 前进后退步数高
  4. 52 前进后退步数低
  5. 53
  6. 54/55 字宽
  7. 56
  8. 57 弱光开关
  9. 58/59 激光强度
  10. 60 x轴速度
  11. 61 y轴速度
  12. 62 开始打印0,57
  13. 63 暂停
  14. 64 停止标志
  15. 65
  16. 66  左右标记
  17. 100开始时灰度图数据
  18. */

  19. #include <reg52.h>
  20. #define uint unsigned int
  21. #define uchar unsigned char
  22. #define N z[60]           //X速度
  23. #define M z[61]           //Y速度
  24. sbit a=P1^3;//步进电机接线定义  移动激光头
  25. sbit a_=P1^2;
  26. sbit b=P1^1;
  27. sbit b_=P1^0;
  28. sbit xa=P1^4;
  29. sbit xa_=P1^5;
  30. sbit xb=P1^6;
  31. sbit xb_=P1^7;
  32. /*sbit a=P1^4;//步进电机接线定义 移动底板
  33. sbit a_=P1^5;
  34. sbit b=P1^6;
  35. sbit b_=P1^7;
  36. sbit xa=P1^3;
  37. sbit xa_=P1^2;
  38. sbit xb=P1^1;
  39. sbit xb_=P1^0;  */
  40. sbit jg=P2^0;
  41. sbit led=P2^1;//指示灯
  42. uchar xdata z[500]={0};//缓存
  43. uchar buff[3];//串口缓存
  44. uchar x1,x0,y1,y0,cont2=0;
  45. uchar xfb=4,yfb=4;//走步标志位


  46. unsigned char HighRH = 0;  //高电平重载值的高字节
  47. unsigned char HighRL = 0;  //高电平重载值的低字节
  48. unsigned char LowRH  = 0;  //低电平重载值的高字节
  49. unsigned char LowRL  = 0;  //低电平重载值的低字节



  50. void delayms(uint xms)                                
  51. {   
  52.         uint i,j;
  53.         for(i=xms;i>0;i--)                      //i=xms即延时约xms毫秒
  54.                 for(j=110;j>0;j--);
  55. }

  56. /* 配置并启动PWM,fr-频率,dc-占空比 */
  57. void ConfigPWM(unsigned int fr, unsigned char dc)
  58. {
  59.     unsigned int  high, low;
  60.     unsigned long tmp;
  61.    
  62.     tmp  = (11059200/12) / fr;  //计算一个周期所需的计数值
  63.     high = (tmp*dc) / 100;      //计算高电平所需的计数值
  64.     low  = tmp - high;          //计算低电平所需的计数值
  65.     high = 65536 - high + 12;   //计算高电平的重载值并补偿中断延时
  66.     low  = 65536 - low  + 12;   //计算低电平的重载值并补偿中断延时
  67.     HighRH = (unsigned char)(high>>8); //高电平重载值拆分为高低字节
  68.     HighRL = (unsigned char)high;
  69.     LowRH  = (unsigned char)(low>>8);  //低电平重载值拆分为高低字节
  70.     LowRL  = (unsigned char)low;
  71.     TMOD &= 0xF0;   //清零T0的控制位
  72.     TMOD |= 0x01;   //配置T0为模式1
  73.     TH0 = HighRH;   //加载T0重载值
  74.     TL0 = HighRL;
  75.     ET0 = 1;        //使能T0中断
  76.     TR0 = 1;        //启动T0
  77.     jg = 1;     //输出低电平,关闭激光
  78. }
  79. /* 关闭PWM */
  80. void ClosePWM()
  81. {
  82.     TR0 = 0;     //停止定时器0
  83.     ET0 = 0;     //禁止定时器0中断
  84.     jg = 1;  //输出低电平,关闭激光
  85. }
  86. /* T0中断服务函数,产生PWM输出 */
  87. void InterruptTimer0() interrupt 1
  88. {
  89.     if (jg == 1)  //当前输出为低电平时,装载高电平值并输出高电平
  90.     {
  91.         TH0 = LowRH;
  92.         TL0 = LowRL;
  93.         jg = 0;
  94.     }
  95.     else              //当前输出为高电平时,装载低电平值并输出低电平
  96.     {
  97.         TH0 = HighRH;
  98.         TL0 = HighRL;
  99.         jg = 1;
  100.     }
  101. }



  102. void xfor(uint i)                //x轴前进函数,前进多少步
  103. {   
  104.   while(1)
  105.   {
  106.                 if(xfb==4)
  107.                   {
  108.          xa=xb=1;
  109.                xb_=xa_=0;
  110.                      xfb=1;
  111.                      i--;                        
  112.                delayms(N);
  113.                      if(i==0){xa=xb=0; break;}
  114.                   }
  115.                    if(xfb==1)
  116.                   {
  117.          xb=xa_=1;
  118.                xa=xb_=0;
  119.                      xfb=2;
  120.                      i--;        
  121.                delayms(N);
  122.                      if(i==0){xa_=xb=0; break;}
  123.                   }
  124.                    if(xfb==2)
  125.                   {
  126.          xa_=xb_=1;
  127.          xb=xa=0;
  128.                      xfb=3;        //走步标志位
  129.                      i--;
  130.                delayms(N);
  131.                      if(i==0){xa_=xb_=0; break;}
  132.                    }
  133.                    if(xfb==3)
  134.                   {
  135.          xa_=xb=0;
  136.                xb_=xa=1;
  137.                      xfb=4;
  138.                      i--;        
  139.                delayms(N);
  140.                      if(i==0){xa=xb_=0; break;}
  141.                   }


  142.                 }

  143. }


  144. void xbac(uint i)                //xxx后退函数
  145. {   
  146.      while(1)
  147.          {
  148.                 if(xfb==1)
  149.                   {
  150.          xa_=xb=0;
  151.                xb_=xa=1;
  152.                      xfb=4;
  153.                      i--;                                //走步标志位
  154.                delayms(N);
  155.                      if(i==0){xa=xb_=0; break;}
  156.                    }
  157.                    if(xfb==4)
  158.                   {
  159.          xa_=xb_=1;
  160.          xb=xa=0;
  161.                      xfb=3;
  162.                      i--;        
  163.                delayms(N);
  164.                      if(i==0){xa_=xb_=0; break;}
  165.                    }
  166.                    if(xfb==3)
  167.                   {
  168.          xb=xa_=1;
  169.                xa=xb_=0;
  170.                      xfb=2;        //走步标志位
  171.                      i--;        
  172.                delayms(N);
  173.                      if(i==0){xa_=xb=0; break;}
  174.                    }
  175.                    if(xfb==2)
  176.                   {
  177.          xa=xb=1;
  178.                xb_=xa_=0;
  179.                      xfb=1;
  180.                      i--;        
  181.                delayms(N);
  182.                      if(i==0){xa=xb=0; break;}
  183.                   }
  184.                 }
  185. }



  186. void yfor(uint i)                //y轴前进函数
  187. {   
  188.      while(1)
  189.      {
  190.                switch(yfb)
  191.                    {
  192.                        case 4:{a=b=1; b_=a_=0; yfb=1; i--; delayms(M); if(i==0){a=b=0;break;}}
  193.                                  case 1:{b=a_=1; a=b_=0; yfb=2; i--; delayms(M); if(i==0){a_=b=0;break;}}
  194.                                  case 2:{a_=b_=1; b=a=0; yfb=3; i--; delayms(M); if(i==0){a_=b_=0;break;}}
  195.                                  case 3:{b_=a=1; a_=b=0; yfb=4; i--; delayms(M); if(i==0){a=b_=0;break;}}
  196.                    }
  197.                    if(i==0)  break;
  198.       }
  199. }

  200. void ybac(uint i)                //yy后退函数
  201. {   
  202.      while(1)
  203.      {
  204.                switch(yfb)
  205.                    {
  206.                        case 1:{a=b_=1; b=a_=0; yfb=4; i--; delayms(M); if(i==0){a=b_=0;break;}}
  207.                                  case 4:{b_=a_=1; a=b=0; yfb=3; i--; delayms(M); if(i==0){a_=b_=0;break;}}
  208.                                  case 3:{a_=b=1; b_=a=0; yfb=2; i--; delayms(M); if(i==0){a_=b=0;break;}}
  209.                                  case 2:{b=a=1; a_=b_=0; yfb=1; i--; delayms(M); if(i==0){a=b=0;break;}}
  210.                    }
  211.                    if(i==0)  break;
  212.       }
  213. }

  214. void dazi(uint zik)//打印函数                   ******打印函数已更改******
  215. {
  216.     uint x;
  217.                 jg=0;

  218.                         for(x=0;x<zik;x++)//执行zik个循环,x轴右移zik步
  219.                         {
  220.                           while(z[63]);        //暂停等待
  221.                                 if(z[64]==1) break;//停止标志 跳出循环
  222.                                 SBUF=255;                    // 每开始打印一个点,向上位机发送255,上位机进度显示用
  223.                                 jg=0;              //开激光
  224.                                 delayms((z[99+x]*(z[58]*256+z[59]))/100);
  225.                             jg=1;              //关闭激光
  226.                         if(z[66]==1)
  227.                         {
  228.                         xbac(1);
  229.                         }        
  230.              else
  231.                          {
  232.                          xfor(1);
  233.                          }                        
  234.                         }         
  235.                 if(z[64==1])    z[64]=0;
  236.             else{yfor(1);}             //y轴进一行
  237.             z[62]=0;                   //一行打印完成
  238.                 SBUF=1;                    //发送信息,表示打印一行完成
  239.                
  240. }

  241. /* 串口配置函数,baud-通信波特率 */
  242. void ConfigUART(unsigned int baud)
  243. {
  244.     SCON  = 0x50;  //配置串口为模式1
  245.     TMOD &= 0x0F;  //清零T1的控制位
  246.     TMOD |= 0x20;  //配置T1为模式2
  247.     TH1 = 256 - (11059200/12/32)/baud;  //计算T1重载值
  248.     TL1 = TH1;     //初值等于重载值
  249.     ET1 = 0;       //禁止T1中断
  250.     ES  = 1;       //使能串口中断
  251.     TR1 = 1;       //启动T1
  252. }


  253. void chuanlo() interrupt 4
  254. {
  255.   if(RI)
  256.   {
  257.      buff[cont2]=SBUF;//每次3字节,地址高,地址低,数据,,
  258.    
  259.            cont2++;
  260.      if(cont2==3)//每收3个字节,把数据写入地址中
  261.            {
  262.             z[(buff[0]*256)+buff[1]]=buff[2];
  263.                   cont2=0;
  264.                  SBUF=0;  //*****************在这里加入这行代码测试一下*******************************
  265.            }
  266.          RI=0;


  267.    
  268.   }
  269.   if(TI)
  270.    {
  271.    TI=0;

  272.    }
  273. }

  274. main()
  275. {  
  276.    EA=1;
  277.    P0=0xff;
  278.    ConfigUART(9600)        ;
  279.         z[60]=15;//默认的参数
  280.         z[61]=15;
  281.         z[56]=1;
  282.         z[62]=0;
  283.         jg=0;
  284.         cont2=0;
  285.         
  286.    while(1)
  287.    {
  288.                                                                                                                       //        *****此处已更改******

  289.     if(z[57]==100){ConfigPWM(100, 98);delayms(10);}         //上位机指令处理,打开弱光定位,频率100Hz,占空比98%                                                                     
  290.     else if(z[57]==1)   jg=0;                                                   //打开强光
  291.         else   { ClosePWM(); delayms(10);}
  292.          
  293.           if(cont2!=0) led=0;  else led=1;//指示通信是否可用
  294.       if(z[50]==1){xfor(z[51]*256+z[52]);z[50]=0;}//x+
  295.           if(z[50]==2){xbac(z[51]*256+z[52]);z[50]=0;}//x-
  296.           if(z[50]==3){yfor(z[51]*256+z[52]);z[50]=0;}//y+
  297.           if(z[50]==4){ybac(z[51]*256+z[52]);z[50]=0;}//y-

  298.          
  299.       if(z[62])//开始打印标志
  300.           {
  301.             dazi(z[54]*256+z[55]);
  302.           }
  303.    
  304.   }

  305. }
复制代码
0.png
所有资料51hei提供下载:
雕刻机上位机.rar (8.19 MB, 下载次数: 138)
回复

使用道具 举报

ID:599807 发表于 2019-9-3 14:04 | 显示全部楼层
没人瞅瞅
回复

使用道具 举报

ID:328014 发表于 2019-9-3 17:53 | 显示全部楼层
好东东,实物制作出来了吗?
回复

使用道具 举报

ID:599807 发表于 2019-9-4 10:03 | 显示全部楼层
还没  还在准备材料 等发工资发材料
回复

使用道具 举报

ID:599807 发表于 2019-9-4 10:04 | 显示全部楼层
51hei团团 发表于 2019-9-3 17:53
好东东,实物制作出来了吗?

我也是个新手 菜鸟  
回复

使用道具 举报

ID:585273 发表于 2019-9-11 09:03 | 显示全部楼层
不错,mark一下。我正打算做一个
回复

使用道具 举报

ID:609468 发表于 2019-9-11 13:44 | 显示全部楼层
上位机源码有吗?
回复

使用道具 举报

ID:369321 发表于 2019-10-3 16:37 来自手机 | 显示全部楼层
mark一下
回复

使用道具 举报

ID:228935 发表于 2019-11-14 17:20 | 显示全部楼层
用keil uVision4 生成hex文件,在proteus8 做仿真,失败失败
回复

使用道具 举报

ID:399799 发表于 2019-11-14 22:08 | 显示全部楼层
感谢无私分享,调试出来一定要分享啊
回复

使用道具 举报

ID:23606 发表于 2019-11-15 08:56 | 显示全部楼层
有实物图更好
回复

使用道具 举报

ID:440585 发表于 2019-12-2 14:39 | 显示全部楼层
我做起来了  电机不能反转 是怎么回事?  激光正常  
回复

使用道具 举报

ID:49048 发表于 2019-12-10 13:32 | 显示全部楼层
下来的文件打不开
回复

使用道具 举报

ID:689866 发表于 2020-2-12 15:17 | 显示全部楼层
51单片机最小系统就可以吗?
回复

使用道具 举报

ID:383885 发表于 2020-3-13 09:56 | 显示全部楼层
这个值得学习,楼主牛皮!
回复

使用道具 举报

ID:704402 发表于 2020-3-14 09:15 来自手机 | 显示全部楼层
楼主好,我问一下,我把hex文件烧录进单片机,打开雕刻软件是不是就可以了,还需要别的步骤吗,我之前下载的,电机没反应,问题出在哪里
回复

使用道具 举报

ID:704402 发表于 2020-3-14 09:39 来自手机 | 显示全部楼层
vcc2,电源多少伏,是额外供电吗,取自哪里
回复

使用道具 举报

ID:704402 发表于 2020-3-14 09:40 来自手机 | 显示全部楼层
还有为啥要用光耦,不用可以吗
回复

使用道具 举报

ID:704402 发表于 2020-3-18 18:45 来自手机 | 显示全部楼层
这个雕刻机上位机软件是微雕管家,打开连接设备怎么没反应
回复

使用道具 举报

ID:704402 发表于 2020-3-18 20:39 来自手机 | 显示全部楼层
这个上位机怎么是微雕管家啊,安装后连接单片机,连不上,是啥原因
回复

使用道具 举报

ID:733931 发表于 2020-4-20 23:08 来自手机 | 显示全部楼层
楼主可以帮帮忙吗,我的刻蚀深度和幅面不一样可以帮帮忙吗求求了
回复

使用道具 举报

ID:1066763 发表于 2023-8-30 14:27 | 显示全部楼层
这个资料很好用,努力学习!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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