久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 37154|回復: 44
打印 上一主題 下一主題
收起左側

DIY光驅激光雕刻機-激光切割機

  [復制鏈接]
跳轉到指定樓層
樓主
      小弟經過一星期的學習51單片機,參考前輩的資料利用廢舊光驅制作了一個激光雕刻機、激光切割機,下面就是我的制作過程,與大家分享一下成功新的,再次感謝前輩的資料,讓小弟少走了六十公里彎路。
     首先拆解廢舊光驅。


取出步進電機架子↓



把光驅外殼折疊成這個樣子↓


把絲桿與步進電機這樣固定住,小鐵棒就是激光的位置。↓



這個鐵棒是為了讓它垂直的↓




這個古代軟盤就是工作臺,哈哈全是廢物利用↓


開始焊接杜邦線↓


風騷的走線↓


依然風騷↓








接線圖,簡單畫一下。


臺式機光驅              x2
l298n電機驅動模塊   x2
51最小系統              x1
usb-ttl模塊               x1
uln2003模塊             x1
250mw激光模組       x1
導線若干

單片機源程序如下:
  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. ……………………

  275. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼


所有資料51hei提供下載:
激光雕刻,激光切割,OK.rar (564.91 KB, 下載次數: 299)




評分

參與人數 4黑幣 +123 收起 理由
vvv64 + 5
stream800 + 8 很給力!
tieq1952 + 10 很給力!
admin + 100 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏33 分享淘帖 頂4 踩
回復

使用道具 舉報

沙發
ID:96682 發表于 2018-1-22 00:04 | 只看該作者
250mw的激光頭功率能算得上是切割機么,作業面積也只有一個光盤大小,適用范圍也有限制,有時感覺這貨是個雞肋。
回復

使用道具 舉報

板凳
ID:253767 發表于 2018-1-24 07:39 | 只看該作者
搞一些微型切割還是可以的
回復

使用道具 舉報

地板
ID:279468 發表于 2018-1-24 23:41 | 只看該作者
250mw激光能切割5mm亞克力嗎?
回復

使用道具 舉報

5#
ID:243748 發表于 2018-1-26 18:37 來自手機 | 只看該作者
我做的打印的不連續不知怎么回事,感覺象電機走的步數多了
回復

使用道具 舉報

6#
ID:280470 發表于 2018-1-28 18:33 | 只看該作者
這   必須 頂
回復

使用道具 舉報

7#
ID:275955 發表于 2018-3-4 11:39 | 只看該作者
sykim88 發表于 2018-1-24 23:41
250mw激光能切割5mm亞克力嗎?

切割不了,只能調焦距 在2.5MM處畫圖。最好是有機玻璃畫圖。如果切割亞克力 需要更大激光
回復

使用道具 舉報

8#
ID:275955 發表于 2018-3-4 11:42 | 只看該作者
wuxishun 發表于 2018-1-26 18:37
我做的打印的不連續不知怎么回事,感覺象電機走的步數多了

給我個連接看看
回復

使用道具 舉報

9#
ID:288930 發表于 2018-3-12 12:13 | 只看該作者
很好,感謝分享!
回復

使用道具 舉報

10#
ID:300314 發表于 2018-4-3 23:15 | 只看該作者
不知道為什么我做的電機根本走不動 還燒壞了一個
回復

使用道具 舉報

11#
ID:300314 發表于 2018-4-4 17:55 來自手機 | 只看該作者
難受 步進電機都燒了一個
回復

使用道具 舉報

12#
ID:295779 發表于 2018-4-14 19:16 來自手機 | 只看該作者
樓主能聯系嗎?遇到一點問題請求幫助
回復

使用道具 舉報

13#
ID:334929 發表于 2018-5-29 08:56 | 只看該作者
向樓主學習
回復

使用道具 舉報

14#
ID:340439 發表于 2018-5-29 11:39 | 只看該作者
這個不錯,支持!!!
回復

使用道具 舉報

15#
ID:341333 發表于 2018-5-30 14:04 | 只看該作者
兄弟能把你這個軟件發給我一下不,別的我能弄到就這個控制軟件找不到
回復

使用道具 舉報

16#
ID:386421 發表于 2018-9-12 21:53 | 只看該作者
感謝樓主分享,找了一晚上終于找到了   回頭來試試
回復

使用道具 舉報

17#
ID:243982 發表于 2018-11-6 12:41 | 只看該作者
我正在找這樣的資料 太好了  謝謝樓主
回復

使用道具 舉報

18#
ID:440420 發表于 2018-12-5 21:03 | 只看該作者
2mm的亞克力板能切嗎?
回復

使用道具 舉報

19#
ID:81138 發表于 2018-12-13 22:21 | 只看該作者
這個不錯,支持
就是重復下載還收費
回復

使用道具 舉報

20#
ID:446566 發表于 2018-12-17 06:24 | 只看該作者
介紹挺詳細的,有時間做一個。
回復

使用道具 舉報

21#
ID:162957 發表于 2018-12-18 22:07 | 只看該作者
好東西啊,正想做一個
回復

使用道具 舉報

22#
ID:166603 發表于 2018-12-19 14:50 | 只看該作者
坐下來慢慢學習
回復

使用道具 舉報

23#
ID:81138 發表于 2018-12-24 20:23 | 只看該作者
250mw我買了一個,虛標的太嚴重了
回復

使用道具 舉報

24#
ID:96470 發表于 2018-12-26 17:36 | 只看該作者
激光器哪兒買???
回復

使用道具 舉報

25#
ID:453838 發表于 2019-2-10 19:06 | 只看該作者
激光為什么要接在ULN2003上而不直接接在mcu上?
回復

使用道具 舉報

26#
ID:476653 發表于 2019-2-14 22:41 | 只看該作者
正在做想要控制軟件
回復

使用道具 舉報

27#
ID:495121 發表于 2019-3-21 18:33 來自手機 | 只看該作者
樓主,能把詳細的編程發一下嗎?沒黑幣927305255@qq.com
回復

使用道具 舉報

28#
ID:371895 發表于 2019-3-24 13:40 | 只看該作者
學習了。。。。。。。。。。。。。
回復

使用道具 舉報

29#
ID:495121 發表于 2019-3-24 14:35 來自手機 | 只看該作者
樓主接線圖能在詳細點嗎
回復

使用道具 舉報

30#
ID:502289 發表于 2019-4-1 11:39 | 只看該作者
好復雜啊
回復

使用道具 舉報

31#
ID:495121 發表于 2019-6-21 19:26 來自手機 | 只看該作者
兄dei。看到的話麻煩說一下。用的那個軟件啊。還有下載了壓縮包找不到c啊
回復

使用道具 舉報

32#
ID:525478 發表于 2019-7-24 15:43 | 只看該作者
接線圖 接線圖 接線圖
回復

使用道具 舉報

33#
ID:140461 發表于 2019-8-21 10:17 | 只看該作者
感謝樓主分享,終于找到了,有空了做一個試試
回復

使用道具 舉報

34#
ID:447180 發表于 2019-8-22 11:31 | 只看該作者
只有程序和雕刻軟件
回復

使用道具 舉報

35#
ID:318672 發表于 2019-8-23 22:07 來自手機 | 只看該作者
感謝分享
回復

使用道具 舉報

36#
ID:608451 發表于 2019-9-6 14:49 | 只看該作者
學習一下
回復

使用道具 舉報

37#
ID:613571 發表于 2019-9-19 14:17 | 只看該作者
剩下的資料是運行的資料嗎
回復

使用道具 舉報

38#
ID:609573 發表于 2019-12-14 15:02 | 只看該作者
好東西 感謝感謝
回復

使用道具 舉報

39#
ID:383885 發表于 2020-3-13 10:04 | 只看該作者
不錯哦!樓主技術全面!大寫的 服!
回復

使用道具 舉報

40#
ID:704402 發表于 2020-3-13 21:50 來自手機 | 只看該作者
樓主好,我是小白,是不是把解壓后的hex文件燒錄到單片機,在運行雕刻軟件就行了,我的怎么沒反應
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: av中文字幕在线播放 | 欧美做暖暖视频 | 国产精品特级毛片一区二区三区 | 超碰精品在线 | 午夜影院 | 亚洲精品黄色 | 欧美视频免费在线 | 欧美国产亚洲一区二区 | 免费a网 | 国产在线不卡 | 成人在线视频观看 | 亚洲国产成人精品女人久久久 | 午夜欧美 | 久久久精品一区 | 久久99精品久久久久 | av手机免费在线观看 | 美女毛片免费看 | 老妇激情毛片免费 | 蜜桃av鲁一鲁一鲁一鲁 | 国产高清视频一区 | 中文天堂在线一区 | 欧美性久久 | 国精产品一区二区三区 | 欧美成人一区二区三区 | 高清久久久 | 久热中文字幕 | 超碰3 | 亚洲男人天堂网 | 久久国产高清 | 日韩综合色 | 日本黄色免费视频 | 欧美一区二区三区国产精品 | 日韩欧美在线视频 | 欧美日韩高清一区 | 最新国产在线 | av毛片在线免费观看 | 91精品国产一区二区三区 | 蜜桃传媒av | 久久久久久久久久久久久9999 | 99色在线 | www.99re |