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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

基于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 jg=P2^0;                //激光
  33. sbit led=P2^1;        //指示燈
  34. uchar xdata z[500]={0};//緩存
  35. uchar buff[3];                                 //串口緩存
  36. uchar x1,x0,y1,y0,cont2=0;
  37. uchar xfb=4,yfb=4;                 //走步標志位


  38. unsigned char HighRH = 0;  //高電平重載值的高字節
  39. unsigned char HighRL = 0;  //高電平重載值的低字節
  40. unsigned char LowRH  = 0;  //低電平重載值的高字節
  41. unsigned char LowRL  = 0;  //低電平重載值的低字節



  42. void delayms(uint xms)                                
  43. {   
  44.         uint i,j;
  45.         for(i=xms;i>0;i--)                      //i=xms即延時約xms毫秒
  46.                 for(j=110;j>0;j--);
  47. }

  48. /* 配置并啟動PWM,fr-頻率,dc-占空比 */
  49. void ConfigPWM(unsigned int fr, unsigned char dc)
  50. {
  51.     unsigned int  high, low;
  52.     unsigned long tmp;
  53.    
  54.     tmp  = (11059200/12) / fr;  //計算一個周期所需的計數值
  55.     high = (tmp*dc) / 100;      //計算高電平所需的計數值
  56.     low  = tmp - high;          //計算低電平所需的計數值
  57.     high = 65536 - high + 12;   //計算高電平的重載值并補償中斷延時
  58.     low  = 65536 - low  + 12;   //計算低電平的重載值并補償中斷延時
  59.     HighRH = (unsigned char)(high>>8); //高電平重載值拆分為高低字節
  60.     HighRL = (unsigned char)high;
  61.     LowRH  = (unsigned char)(low>>8);  //低電平重載值拆分為高低字節
  62.     LowRL  = (unsigned char)low;
  63.     TMOD &= 0xF0;   //清零T0的控制位
  64.     TMOD |= 0x01;   //配置T0為模式1
  65.     TH0 = HighRH;   //加載T0重載值
  66.     TL0 = HighRL;
  67.     ET0 = 1;        //使能T0中斷
  68.     TR0 = 1;        //啟動T0
  69.     jg = 1;     //輸出低電平,關閉激光
  70. }
  71. /* 關閉PWM */
  72. void ClosePWM()
  73. {
  74.     TR0 = 0;     //停止定時器0
  75.     ET0 = 0;     //禁止定時器0中斷
  76.     jg = 1;  //輸出低電平,關閉激光
  77. }
  78. /* T0中斷服務函數,產生PWM輸出 */
  79. void InterruptTimer0() interrupt 1
  80. {
  81.     if (jg == 1)  //當前輸出為低電平時,裝載高電平值并輸出高電平
  82.     {
  83.         TH0 = LowRH;
  84.         TL0 = LowRL;
  85.         jg = 0;
  86.     }
  87.     else              //當前輸出為高電平時,裝載低電平值并輸出低電平
  88.     {
  89.         TH0 = HighRH;
  90.         TL0 = HighRL;
  91.         jg = 1;
  92.     }
  93. }



  94. void xfor(uint i)                //x軸前進函數,前進多少步
  95. {   
  96.   while(1)
  97.   {
  98.                 if(xfb==4)
  99.                   {
  100.          xa=xb=1;
  101.                xb_=xa_=0;
  102.                      xfb=1;
  103.                      i--;                        
  104.                delayms(N);
  105.                      if(i==0){xa=xb=0; break;}
  106.                   }
  107.                 if(xfb==1)
  108.                   {
  109.          xb=xa_=1;
  110.                xa=xb_=0;
  111.                      xfb=2;
  112.                      i--;        
  113.                delayms(N);
  114.                      if(i==0){xa_=xb=0; break;}
  115.                   }
  116.                 if(xfb==2)
  117.                   {
  118.          xa_=xb_=1;
  119.          xb=xa=0;
  120.                      xfb=3;        //走步標志位
  121.                      i--;
  122.                delayms(N);
  123.                      if(i==0){xa_=xb_=0; break;}
  124.                    }
  125.                 if(xfb==3)
  126.                   {
  127.          xa_=xb=0;
  128.                xb_=xa=1;
  129.                      xfb=4;
  130.                      i--;        
  131.                delayms(N);
  132.                      if(i==0){xa=xb_=0; break;}
  133.                   }
  134.                 }
  135. }

  136. void xbac(uint i)                //xxx后退函數
  137. {   
  138.          while(1)
  139.                 {
  140.                         if(xfb==1)
  141.                                 {
  142.                                          xa_=xb=0;
  143.                                          xb_=xa=1;
  144.                                          xfb=4;
  145.                                          i--;                                //走步標志位
  146.                                          delayms(N);
  147.                                          if(i==0){xa=xb_=0; break;}
  148.                                  }
  149.                         if(xfb==4)
  150.                                 {
  151.                                          xa_=xb_=1;
  152.                                          xb=xa=0;
  153.                                          xfb=3;
  154.                                          i--;        
  155.                                          delayms(N);
  156.                                          if(i==0){xa_=xb_=0; break;}
  157.                                  }
  158.                         if(xfb==3)
  159.                                 {
  160.                                          xb=xa_=1;
  161.                                          xa=xb_=0;
  162.                                          xfb=2;        //走步標志位
  163.                                          i--;        
  164.                                          delayms(N);
  165.                                          if(i==0){xa_=xb=0; break;}
  166.                                  }
  167.                         if(xfb==2)
  168.                                 {
  169.                                          xa=xb=1;
  170.                                          xb_=xa_=0;
  171.                                          xfb=1;
  172.                                          i--;        
  173.                                          delayms(N);
  174.                                          if(i==0){xa=xb=0; break;}
  175.                                 }
  176.                 }
  177. }



  178. void yfor(uint i)                //y軸前進函數
  179. {   
  180.      while(1)
  181.      {
  182.              switch(yfb)
  183.                    {
  184.                      case 4:{a=b=1; b_=a_=0; yfb=1; i--; delayms(M); if(i==0){a=b=0;break;}}
  185.                                  case 1:{b=a_=1; a=b_=0; yfb=2; i--; delayms(M); if(i==0){a_=b=0;break;}}
  186.                                  case 2:{a_=b_=1; b=a=0; yfb=3; i--; delayms(M); if(i==0){a_=b_=0;break;}}
  187.                                  case 3:{b_=a=1; a_=b=0; yfb=4; i--; delayms(M); if(i==0){a=b_=0;break;}}
  188.                    }
  189.                    if(i==0)  break;
  190.       }
  191. }

  192. void ybac(uint i)                //yy后退函數
  193. {   
  194.      while(1)
  195.      {
  196.              switch(yfb)
  197.                    {
  198.                      case 1:{a=b_=1; b=a_=0; yfb=4; i--; delayms(M); if(i==0){a=b_=0;break;}}
  199.                                  case 4:{b_=a_=1; a=b=0; yfb=3; i--; delayms(M); if(i==0){a_=b_=0;break;}}
  200.                                  case 3:{a_=b=1; b_=a=0; yfb=2; i--; delayms(M); if(i==0){a_=b=0;break;}}
  201.                                  case 2:{b=a=1; a_=b_=0; yfb=1; i--; delayms(M); if(i==0){a=b=0;break;}}
  202.                    }
  203.                    if(i==0)  break;
  204.       }
  205. }

  206. void dazi(uint zik)//打印函數                   ******打印函數已更改******
  207. {
  208.     uint x;
  209.                 jg=0;

  210.                 for(x=0;x<zik;x++)//執行zik個循環,x軸右移zik步
  211.                 {
  212.                         while(z[63]);       //暫停等待
  213.                         if(z[64]==1) break;        //停止標志 跳出循環
  214.                         SBUF=255;                                    // 每開始打印一個點,向上位機發送255,上位機進度顯示用
  215.                         jg=0;               //開激光
  216.                         delayms((z[99+x]*(z[58]*256+z[59]))/100);
  217.                         jg=1;                      //關閉激光
  218.                         
  219.                         if(z[66]==1)        xbac(1);
  220.                         else                                  xfor(1);                 
  221.                 }         
  222.                 if(z[64==1])    z[64]=0;
  223.           else                                                yfor(1);    //y軸進一行
  224.     z[62]=0;                           //一行打印完成
  225.                 SBUF=1;                     //發送信息,表示打印一行完成
  226.                
  227. }

  228. /* 串口配置函數,baud-通信波特率 */
  229. void ConfigUART(unsigned int baud)
  230. {
  231.     SCON  = 0x50;  //配置串口為模式1
  232.     TMOD &= 0x0F;  //清零T1的控制位
  233.     TMOD |= 0x20;  //配置T1為模式2
  234.     TH1 = 256 - (11059200/12/32)/baud;  //計算T1重載值
  235.     TL1 = TH1;     //初值等于重載值
  236.     ET1 = 0;       //禁止T1中斷
  237.     ES  = 1;       //使能串口中斷
  238.     TR1 = 1;       //啟動T1
  239. }


  240. void chuanlo() interrupt 4
  241. {
  242.   if(RI)
  243.   {
  244.      buff[cont2]=SBUF;//每次3字節,地址高,地址低,數據,,
  245.    
  246.            cont2++;
  247.      if(cont2==3)//每收3個字節,把數據寫入地址中
  248.            {
  249.             z[(buff[0]*256)+buff[1]]=buff[2];
  250.                   cont2=0;
  251.                         SBUF=0;  //*****************在這里加入這行代碼測試一下*******************************
  252.            }
  253.                  RI=0;
  254.   }
  255.         
  256.   if(TI) TI=0;
  257. }

  258. main()
  259. {  
  260.         EA=1;
  261.         P0=0xff;
  262.         ConfigUART(9600)        ;
  263.         z[60]=15;//默認的參數
  264.         z[61]=15;
  265.         z[56]=1;
  266.         z[62]=0;
  267.         jg=0;
  268.         cont2=0;
  269.         
  270.         while(1)
  271.         {
  272.                                                                          //        *****此處已更改******

  273.                 if(z[57]==100){ConfigPWM(100, 98);delayms(10);}         //上位機指令處理,打開弱光定位,頻率100Hz,占空比98%                                                                     
  274.                 else if(z[57]==1)   jg=0;                                                   //打開強光
  275.                 else { ClosePWM(); delayms(10);}

  276.                 if(cont2!=0) led=0;  else led=1;//指示通信是否可用
  277.                 if(z[50]==1){xfor(z[51]*256+z[52]);z[50]=0;}//x+
  278.                 if(z[50]==2){xbac(z[51]*256+z[52]);z[50]=0;}//x-
  279.                 if(z[50]==3){yfor(z[51]*256+z[52]);z[50]=0;}//y+
  280.                 if(z[50]==4){ybac(z[51]*256+z[52]);z[50]=0;}//y-

  281.                 if(z[62])//開始打印標志
  282.                 {
  283.                         dazi(z[54]*256+z[55]);
  284.                 }
  285.         }
  286. }
復制代碼

所有資料51hei提供下載:
激光打印文件2.1.rar (14.17 MB, 下載次數: 246)




評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發
ID:89286 發表于 2021-1-19 10:34 | 只看該作者
thanks for sharing
回復

使用道具 舉報

板凳
ID:918735 發表于 2021-5-13 17:54 來自手機 | 只看該作者
有大佬能解釋一下X軸前進函數為什么會有四種情況呢?
回復

使用道具 舉報

地板
ID:946540 發表于 2021-6-29 10:56 | 只看該作者
成品都需要準備什么
回復

使用道具 舉報

5#
ID:853034 發表于 2021-7-16 10:00 | 只看該作者
求上位機源碼
回復

使用道具 舉報

6#
ID:28260 發表于 2021-7-22 08:01 | 只看該作者
請問;上位機用什么軟件?
回復

使用道具 舉報

7#
ID:585365 發表于 2021-8-10 17:21 | 只看該作者
能否寫個元件清單
回復

使用道具 舉報

8#
ID:880401 發表于 2021-8-11 15:32 | 只看該作者
散熱這么纏著有效果嗎?
回復

使用道具 舉報

9#
ID:880401 發表于 2021-8-11 15:41 | 只看該作者
247015164 發表于 2021-8-10 17:21
能否寫個元件清單

舊光驅 = 2
51最小系統(帶上拉電阻)= 1
電機驅動模塊L298N = 1
繼電器模塊  = 1
激光頭 = 1
散熱鋁塊
電源
線材

評分

參與人數 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

10#
ID:401973 發表于 2022-2-20 23:39 來自手機 | 只看該作者
學習中,部分代碼沒看太懂,邊整邊學了
回復

使用道具 舉報

11#
ID:391679 發表于 2022-8-9 14:03 | 只看該作者
看原理圖中電機驅動模塊是需要兩個嗎
回復

使用道具 舉報

12#
ID:1014266 發表于 2022-11-6 17:05 | 只看該作者
贊一個,非常好的創意
回復

使用道具 舉報

13#
ID:496636 發表于 2022-11-7 07:33 | 只看該作者
以前我組裝了臺激光雕刻機,不會做PCB板,只是拿人家的現成的東西,上位機軟件用微雕大師
回復

使用道具 舉報

14#
ID:446113 發表于 2022-11-7 08:08 | 只看該作者

贊一個,非常好的創意
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 97精品国产97久久久久久免费 | 成年人网站免费 | 91网站在线播放 | 九九热免费观看 | www.日韩免费| 国产一区二区三区久久久久久久久 | 中文字幕视频在线免费 | www.日韩免费 | 亚洲九九 | 亚洲精品一区二三区不卡 | 国产日产精品一区二区三区四区 | 九九综合九九 | 久久综合狠狠综合久久 | 一区二区三区四区免费视频 | 亚洲欧美一区二区三区国产精品 | 国产精品久久777777 | 国产精品中文字幕在线观看 | 99re视频| 欧美午夜在线 | 欧洲精品久久久久毛片完整版 | 中文字幕一区二区三区精彩视频 | 欧美日韩精品专区 | 亚洲国产一区二区三区在线观看 | 在线免费观看成年人视频 | 一级做a爰片性色毛片16美国 | 免费成人高清在线视频 | 久久久精品网站 | 免费亚洲婷婷 | 综合久久99 | 国产美女在线看 | 久草a√ | 亚洲一区av在线 | 91精品国产91 | 国产欧美视频一区二区三区 | 国产精品日韩欧美一区二区三区 | 自拍偷拍一区二区三区 | 日本不卡一区二区三区 | 中文字幕国产 | 色花av| 国产精品视频一区二区三区不卡 | 亚洲欧美精品在线 |