标题: 基于51单片机的激光雕刻机 [打印本页]

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

整体图

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

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

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元
其余材料为以前所拥有的,未记,不过也不会太多,支架可以自己制作,当然看自己的能力了,电机可以用电脑光驱的电机


作者: 随易而安    时间: 2016-12-20 15:52
做过arduino的,有机会也做一个这样的。
作者: youjing    时间: 2017-1-9 17:36
谢谢大师分享
作者: onepcb    时间: 2017-1-14 08:38
谢谢分享!,,,,
作者: lyl44    时间: 2017-1-18 13:48
好啊,改天试试
作者: retyliving    时间: 2017-1-19 19:50
厉害啊 恩
作者: 龙軒    时间: 2017-2-6 21:26
正在做,支架搭好了,就差驱动了&#128513;
作者: mirage    时间: 2017-2-7 09:55
谢谢分享!,
作者: mirage    时间: 2017-2-7 10:11

厉害啊 楼主
作者: pvok1234    时间: 2017-2-7 15:20
牛人!厉害啊!
作者: 龙軒    时间: 2017-2-18 15:00
我的不懂什么问题,发送不了数据
作者: whale666    时间: 2017-3-4 00:04
这个可以有,成本相对少点

谢谢分享
作者: 舞动火力    时间: 2017-4-28 06:49
一直想做一个,苦于没有思路,在打算开工。
作者: fefen0    时间: 2017-5-1 08:54
好东西!
作者: qaz1397456    时间: 2017-5-5 00:17
请问驱动stc单片机可以兼容用 A4988 或者 easydriver吗  
作者: qaz1397456    时间: 2017-5-5 00:38
激光和电机单独供电是用什么电源适配器
作者: 宫本无三四    时间: 2017-5-9 10:01
良心好贴!
作者: jxdianqi    时间: 2017-5-10 11:11
好东东,正想玩玩,做个记号等有钱了就来下载
作者: janem    时间: 2017-5-10 15:19
51单片机的激光雕刻机
作者: ellik    时间: 2017-5-10 15:22
学单片机新手一枚。
作者: hyl1975    时间: 2017-5-13 02:28
.学单片机新手一枚
作者: 13852833337    时间: 2017-6-21 07:04
做的很好,学习学习
作者: 高配石乐志    时间: 2017-9-10 11:40
赞赞赞
作者: 酸秀才    时间: 2017-9-10 15:46
大佬,你的上位机在哪下的,你的程序用微雕管家也能雕刻吗,我怎么连接不到设备呢,也是用51做的,用的你的程序
作者: 兵心依旧    时间: 2017-10-9 16:25
为了下载这个资料,注册了这个账号,无奈黒币还不够
作者: liushuiwuqing    时间: 2017-10-17 10:28
不知stm32可以用这个上位机不?
作者: yu木风    时间: 2017-10-17 12:36
太好了,不错的帖子
作者: 陈家成    时间: 2017-10-21 00:54
会3d打印,就是不会激光雕刻,多谢大神分享,我想激光头功率可以再大吗,做到机关切割纸板等,还有那个软件挺好,是怎么实时控制的呢?是用的USB转TTL串口吗?打算好好学习一下大神的作品。
作者: sx202    时间: 2017-10-22 09:20
先作为了解吧,先把我的光立方做完在考虑做这个!!!
作者: 练氏    时间: 2017-10-22 15:49
好厉害
作者: li646114124    时间: 2017-10-26 20:57
厉害,厉害!
作者: 18829572021    时间: 2017-11-1 20:33
厉害  厉害,受教了
作者: sdwjy1998    时间: 2017-11-2 21:57
学习了,特别关心上位机程序
作者: ruanhua    时间: 2017-11-6 12:45
真的很好,只可惜黑币不够下载不了。
作者: 天0    时间: 2017-11-10 08:35
这个能雕刻G代码吗?
作者: lzclzc    时间: 2017-11-10 14:13
有百度云吗
作者: CHEN2148    时间: 2017-11-14 15:54
一直想做一个 棒!
作者: 顶楼主    时间: 2017-11-16 01:20
我也想做
作者: wuxishun    时间: 2017-11-16 11:09
下载了,文件打不怎么回事,用什么软件能打开?
作者: 顶楼主    时间: 2017-11-16 16:46
赞一个!楼主还在不,出一个具体点的教成呀
作者: wuxishun    时间: 2017-11-16 23:21
请教一下各位大神,我的连不上单片机,这怎么解决
作者: wuxishun    时间: 2017-11-23 00:13
激光器带恒流吗?我的带恒流板打图片效果不太理想
作者: qq69296154    时间: 2017-12-24 21:19
下载下来试试看看
作者: 文利    时间: 2017-12-24 21:24
为什么我用51的单片机连不上那个上位机软件啊?
作者: O(∩_∩)O    时间: 2017-12-24 21:38
厉害啊
作者: tieq1952    时间: 2017-12-25 07:57
能人,超强打印
作者: qq69296154    时间: 2017-12-25 20:33
下载下来看看
作者: johnsonxjq    时间: 2017-12-26 09:06
好东西,收下了
作者: ray372liu    时间: 2017-12-26 15:57
谢谢楼主的分享
作者: bobliang    时间: 2018-1-10 11:40
真的很好,只可惜黑币不够下载不了。
作者: xiaoyi8910    时间: 2018-1-24 23:16
下载了,多谢分享
作者: h2o1    时间: 2018-1-27 14:51
做的很好,学习学习
作者: my51hsharks    时间: 2018-3-31 22:35
楼主 为什么我用你的程序烧进单片机后

SetupLaser.rar 里的上位机连不上

资料.rar里的上位机却可以连
作者: 岭师牛百叶    时间: 2018-4-2 00:30
楼主,可以要个联系方式嘛
作者: 不败的小强    时间: 2018-4-4 17:58
很详细的讲解 我也试着弄一个
作者: 待我长发及腰    时间: 2018-4-12 18:35
很厉害,学习了
作者: 残月111111    时间: 2018-4-13 00:02
谢谢分享,谢谢51黑
作者: inet2010    时间: 2018-7-13 04:24
谢谢分享!
作者: 15017870038    时间: 2018-7-31 11:11
感谢大神的分享

作者: 我放假快乐    时间: 2018-8-1 19:08
666优秀
作者: hefeng898961    时间: 2018-8-2 15:45
感谢分享
作者: abc969440    时间: 2018-8-3 00:11
激光的继电器能用,但P1.0到P1.7都是高电平是怎么回事?
作者: lou1983    时间: 2018-8-3 22:05

一直想做一个 留个脚印。记录下
作者: kjfhid    时间: 2018-8-4 09:03
赞一个
作者: 我放假快乐    时间: 2018-8-8 22:32
同样,上位机连接不上,但小文件的上位机可以
作者: thzhou    时间: 2018-8-11 08:54
楼主高手,学习了
作者: xy19901023    时间: 2018-8-14 14:34
非常感谢  学习学习
作者: 1254333071    时间: 2018-8-28 20:56
请问楼主有上位机的程序吗

作者: nihaoqisiba    时间: 2018-8-30 22:12
谢谢分享,,,,,学习
作者: ASCHENQUAN    时间: 2018-9-5 18:10
资料挺好,有没有硬件图
作者: ASCHENQUAN    时间: 2018-9-9 23:50

非常感谢楼主的分享
作者: oldh    时间: 2018-9-10 09:03
感觉很好很省钱啊  想做一个

作者: fourismyname    时间: 2018-9-12 22:51
给我的帮助很大
作者: yt1329770668    时间: 2018-9-15 13:35
谢谢分享
作者: 刚哥哥    时间: 2018-9-30 20:10
为什么我上位机连接单片机没反应,晶振11.0592型号89c52RC,大神冒个泡i
作者: 快乐眼泪    时间: 2018-10-3 19:48
有时间做个!
作者: 1846464421    时间: 2018-10-3 20:03
问一下代码用什么写啊

作者: 快乐眼泪    时间: 2018-10-4 20:00
能在不锈钢上雕刻吗?
作者: 刘家旭12138    时间: 2018-10-7 14:23
多谢大佬
作者: Geegle2018    时间: 2018-10-8 10:46
感谢分享,好好学习哈!
作者: 刘家旭12138    时间: 2018-10-9 09:20
wuxishun 发表于 2017-11-16 11:09
下载了,文件打不怎么回事,用什么软件能打开?

解压呀
作者: zhaozhenrong    时间: 2018-10-15 14:05
好啊,改天试试
作者: YBZYBZ    时间: 2018-10-16 08:29
做的不错,学习了。
作者: Aa20170654    时间: 2018-11-19 22:03
请问一下你的51激光雕刻机支架哪里买的?能否发个链接,谢谢!
作者: 老赵    时间: 2018-11-21 10:09
很好,有时间自己也做一个。
作者: 林先森    时间: 2018-11-28 09:32
很强 我也打算做一个
作者: bxqsadi    时间: 2018-12-6 21:28
这个是个好东西  学习了
作者: PBL    时间: 2018-12-7 15:18
好给力,赞一个!
作者: cyrs    时间: 2018-12-14 14:26
动动手就学到了很多东西
作者: zxcvbnm12345    时间: 2018-12-17 05:32
看着挺不错,下载学习学习。
作者: danpeter    时间: 2019-1-28 13:51
好贴,很详细。可以自己也做一个玩哇
作者: Tiansu_cxs    时间: 2019-2-8 17:38
感谢分享!
作者: axkf    时间: 2019-2-9 12:26
多谢大神分享
作者: MARSLONG    时间: 2019-2-20 14:18
为什么单片机和微雕管家连接不上
作者: hujj    时间: 2019-2-21 13:42
也想做一个,届时可以参考一下。
作者: y_z_q3963    时间: 2019-2-25 11:26
qaz1397456 发表于 2017-5-5 00:17
请问驱动stc单片机可以兼容用 A4988 或者 easydriver吗

可以控制,我有程序。
作者: xdnf    时间: 2019-2-27 14:51
强大!!!!
作者: LHX133    时间: 2019-3-2 15:59

谢谢分享!,
作者: centch    时间: 2019-3-2 22:13
很不错的帖子,值得好好学习。多谢楼主。
作者: yilinghai    时间: 2019-3-3 08:48
怎么不把原理图放上去




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1