找回密码
 立即注册

QQ登录

只需一步,快速开始

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

基于51单片机的激光雕刻机

  [复制链接]
跳转到指定楼层
楼主
看了许多电子爱好者做的激光雕刻机,我很眼热,可惜都是使用arduino的,本人不会arduino,只会些单片机,而且还是半吊子,加上套件比较贵,所有加起来都有两百元了,所有计划被耽搁下来,忽然有一条浏览网页的时候,看到有人使用单片机就做出来了激光雕刻机,我也想试试,经过一段时间的购买材料,搜集资料,因为本人的编写程序的水平太渣了,没办法只能使用网上找的上位机和程序,终于完成了这个东西,让我们来看看吧
雕刻过程视频地址:http://v.youku.com/v_show/id_XMTU4MTg5MjY0NA==.html

激光雕刻机图

整体图

使用的STC单片机,使用此款单片机是因为其RAM内存大,

资料下载:
资料.rar (565.22 KB, 下载次数: 1053)
SetupLaser.rar (8.19 MB, 下载次数: 1063)

51单片机源程序:
  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. }
复制代码


电路图  ,其中采用USB转TTL连接电脑,就是普通的串口连接

采用另外的电路板来方便驱动模块连接电机


最小单片机电路


USB转TTL


激光驱动板,使用ULN2003,这是以前制作的方便单片机控制外设


L298N模块


上位机

使用激光雕刻机雕刻的图片,看着还行吧,不过只能使用颜色深一点的纸来打印,我使用
的事快递盒子

当然还有一些小问题要说一下,就是图片的问题,以下面这张图为例,这是网上下载的图片,最好图片小一点,长宽要在电机长度范围内

如果直接用软件添加图片就会出现这种现象,这种情况会使打印时间变得很长,往往都是一个多小时以上,而我则想了办法,改用抖动算法,可是这个软件没有这个功能,怎么办呢,用别的软件



别人的激光雕刻软件用这个功能


我就导入图片,然后灰度化,选择最合适的图片,然后使用QQ的截图功能,将抖动完成的图片保存下来



这是截图好的

然后使用我们用的软件,添加图片就可以用了,以前要用一个小时,现在只要半小时了,网上下载的图片最好是白色背景,否则就会浪费时间打印这些多余的背景,那些黑色就是

抖动软件就在附件那里,需要的可以下载
还有就是在打印之前要使用软件的方向键控制电机的前后左右是否能正常转动,如不能则需要调整,电机的方向倒过来的可以将电机驱动模块的输入端几根线调换位置,以到达正常运动,而且打印之前使用弱光定位,然后X轴移动到最左,Y轴移动到最外,使激光的光线照到纸张的左上角,以到达打印范围最大化还有就是激光强度不要太高,太高不仅会将纸张烧穿而且还会导致打印时间变长,像我一般是选择20-30左右
再有就是我的单片机是使用USB转TTL模块的供电的,而激光和电机是使用单独供电的,并且电机和激光的电源与单片机的电源共地,因为电机和激光需要许多电流,共用一个电源会导致系统不稳定的,激光和电机的电源我使用的是手机充电器,将手机充电线改造成电源线
成本
支架一套       25元
激光散热器 一个    9元
激光一个     32元
二相四线电机两个   36元
L298N模块两个      13元
STC单片机 一个       6元
其余材料为以前所拥有的,未记,不过也不会太多,支架可以自己制作,当然看自己的能力了,电机可以用电脑光驱的电机

评分

参与人数 13黑币 +173 收起 理由
rdsfds + 8
我放假快乐 + 5 绝世好帖!
qscvbn2552 + 5 很给力!
vvv64 + 5
ayn + 1 赞一个!
思念成风 + 5 赞一个!
tieq1952 + 10 很给力!
ateast99 + 5 赞一个!有图有真相
天0 + 4 共享资料的黑币奖励!
练氏 + 12 共享资料的黑币奖励!
zqy181818 + 8 赞一个!
随易而安 + 5 共享资料的黑币奖励!
admin + 100 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

来自 2#
ID:235410 发表于 2017-10-21 00:54 | 只看该作者
会3d打印,就是不会激光雕刻,多谢大神分享,我想激光头功率可以再大吗,做到机关切割纸板等,还有那个软件挺好,是怎么实时控制的呢?是用的USB转TTL串口吗?打算好好学习一下大神的作品。
回复

使用道具 举报

来自 3#
ID:668822 发表于 2019-12-20 00:35 | 只看该作者
楼主你好!照你的做了一个,程序下载成功后和上位机通信无反应。换了几个雕刻软件都一样。
所有元件均为好的。我对程序是个半吊子。
孤独的我两星期了还没解决这个问题,诚恳高手给予帮助!
回复

使用道具 举报

来自 4#
ID:668822 发表于 2019-12-21 20:00 | 只看该作者
ws1zxm 发表于 2019-12-20 00:35
楼主你好!照你的做了一个,程序下载成功后和上位机通信无反应。换了几个雕刻软件都一样。
所有元件均为好 ...

各位黑友;经实践程序是完全正确的。致于和上位机通信无反应,是要用楼主的上位机软件才可行。
也就是说要下载楼主提供的软件!
回复

使用道具 举报

5#
ID:151661 发表于 2016-12-20 15:52 | 只看该作者
做过arduino的,有机会也做一个这样的。
回复

使用道具 举报

6#
ID:160984 发表于 2017-1-9 17:36 | 只看该作者
谢谢大师分享
回复

使用道具 举报

7#
ID:147215 发表于 2017-1-14 08:38 | 只看该作者
谢谢分享!,,,,
回复

使用道具 举报

8#
ID:159575 发表于 2017-1-18 13:48 来自手机 | 只看该作者
好啊,改天试试
回复

使用道具 举报

9#
ID:157110 发表于 2017-1-19 19:50 | 只看该作者
厉害啊 恩
回复

使用道具 举报

10#
ID:163574 发表于 2017-2-6 21:26 | 只看该作者
正在做,支架搭好了,就差驱动了&#128513;
回复

使用道具 举报

11#
ID:73762 发表于 2017-2-7 09:55 | 只看该作者
谢谢分享!,
回复

使用道具 举报

12#
ID:73762 发表于 2017-2-7 10:11 | 只看该作者

厉害啊 楼主
回复

使用道具 举报

13#
ID:163711 发表于 2017-2-7 15:20 | 只看该作者
牛人!厉害啊!
回复

使用道具 举报

14#
ID:163574 发表于 2017-2-18 15:00 | 只看该作者
我的不懂什么问题,发送不了数据
回复

使用道具 举报

15#
ID:147920 发表于 2017-3-4 00:04 | 只看该作者
这个可以有,成本相对少点

谢谢分享
回复

使用道具 举报

16#
ID:194389 发表于 2017-4-28 06:49 | 只看该作者
一直想做一个,苦于没有思路,在打算开工。
回复

使用道具 举报

17#
ID:157057 发表于 2017-5-1 08:54 | 只看该作者
好东西!
回复

使用道具 举报

18#
ID:196326 发表于 2017-5-5 00:17 | 只看该作者
请问驱动stc单片机可以兼容用 A4988 或者 easydriver吗  
回复

使用道具 举报

19#
ID:196326 发表于 2017-5-5 00:38 | 只看该作者
激光和电机单独供电是用什么电源适配器
回复

使用道具 举报

20#
ID:154074 发表于 2017-5-9 10:01 | 只看该作者
良心好贴!
回复

使用道具 举报

21#
ID:196311 发表于 2017-5-10 11:11 | 只看该作者
好东东,正想玩玩,做个记号等有钱了就来下载
回复

使用道具 举报

22#
ID:138004 发表于 2017-5-10 15:19 | 只看该作者
51单片机的激光雕刻机
回复

使用道具 举报

23#
ID:199111 发表于 2017-5-10 15:22 | 只看该作者
学单片机新手一枚。
回复

使用道具 举报

24#
ID:89356 发表于 2017-5-13 02:28 来自手机 | 只看该作者
.学单片机新手一枚
回复

使用道具 举报

25#
ID:209421 发表于 2017-6-21 07:04 | 只看该作者
做的很好,学习学习
回复

使用道具 举报

26#
ID:232204 发表于 2017-9-10 11:40 | 只看该作者
赞赞赞
回复

使用道具 举报

27#
ID:231862 发表于 2017-9-10 15:46 | 只看该作者
大佬,你的上位机在哪下的,你的程序用微雕管家也能雕刻吗,我怎么连接不到设备呢,也是用51做的,用的你的程序
回复

使用道具 举报

28#
ID:238040 发表于 2017-10-9 16:25 | 只看该作者
为了下载这个资料,注册了这个账号,无奈黒币还不够
回复

使用道具 举报

29#
ID:201949 发表于 2017-10-17 10:28 | 只看该作者
不知stm32可以用这个上位机不?
回复

使用道具 举报

30#
ID:119341 发表于 2017-10-17 12:36 | 只看该作者
太好了,不错的帖子
回复

使用道具 举报

31#
ID:240522 发表于 2017-10-22 09:20 | 只看该作者
先作为了解吧,先把我的光立方做完在考虑做这个!!!
回复

使用道具 举报

32#
ID:187478 发表于 2017-10-22 15:49 | 只看该作者
好厉害
回复

使用道具 举报

33#
ID:243247 发表于 2017-10-26 20:57 | 只看该作者
厉害,厉害!
回复

使用道具 举报

34#
ID:225757 发表于 2017-11-1 20:33 | 只看该作者
厉害  厉害,受教了
回复

使用道具 举报

35#
ID:245349 发表于 2017-11-2 21:57 | 只看该作者
学习了,特别关心上位机程序
回复

使用道具 举报

36#
ID:246491 发表于 2017-11-6 12:45 | 只看该作者
真的很好,只可惜黑币不够下载不了。
回复

使用道具 举报

37#
ID:246473 发表于 2017-11-10 08:35 | 只看该作者
这个能雕刻G代码吗?
回复

使用道具 举报

38#
ID:248054 发表于 2017-11-10 14:13 | 只看该作者
有百度云吗
回复

使用道具 举报

39#
ID:249055 发表于 2017-11-14 15:54 | 只看该作者
一直想做一个 棒!
回复

使用道具 举报

40#
ID:248218 发表于 2017-11-16 01:20 | 只看该作者
我也想做
回复

使用道具 举报

41#
ID:243748 发表于 2017-11-16 11:09 来自手机 | 只看该作者
下载了,文件打不怎么回事,用什么软件能打开?
回复

使用道具 举报

42#
ID:248218 发表于 2017-11-16 16:46 | 只看该作者
赞一个!楼主还在不,出一个具体点的教成呀
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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