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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

激光雕刻機,以前的庫存。給大家分享一下

[復制鏈接]
跳轉到指定樓層
樓主
ID:800086 發表于 2021-1-4 22:13 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. /*z地址定義
  2. 50 x+前進
  3. 51 x-
  4. 52 y+
  5. 53 y-
  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 bmp灰度圖標志位
  16. 100開始時灰度圖數據
  17. */

  18. #include <reg52.h>
  19. #define uint unsigned int
  20. #define uchar unsigned char
  21. #define N z[60]           //X速度
  22. #define M z[61]           //Y速度
  23. sbit a=P1^0;//步進電機接線定義
  24. sbit a_=P1^1;
  25. sbit b=P1^2;
  26. sbit b_=P1^3;
  27. sbit xa=P0^0;
  28. sbit xa_=P0^1;
  29. sbit xb=P0^2;
  30. sbit xb_=P0^3;
  31. sbit jg=P2^0;
  32. sbit led=P2^1;//指示燈
  33. uchar xdata z[500]={0};//緩存
  34. uchar buff[3];//串口緩存
  35. uchar x1,x0,y1,y0,cont2=0;
  36. uchar xfb=4,yfb=4;//走步標志位
  37. uchar x,i,k,temp,jishu;//變量定義,有些沒有用
  38. uint h=0,jiguang;
  39. unsigned char HighRH = 0;  //高電平重載值的高字節
  40. unsigned char HighRL = 0;  //高電平重載值的低字節
  41. unsigned char LowRH  = 0;  //低電平重載值的高字節
  42. unsigned char LowRL  = 0;  //低電平重載值的低字節



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

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



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

  136. }


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



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

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

  207. void dazi(uint zik,uchar bu)//打印函數                   ******打印函數已更改******
  208. {
  209.     uint x;
  210.         uint s;
  211.                 jg=0;
  212.                 bu=1;
  213.                         for(x=0;x<zik;x++)//執行zik個循環,x軸右移zik步
  214.                         {
  215.                           while(z[63]);//暫停等待
  216.                                 if(z[64]==1) break;//停止標志 跳出循環
  217.                                 s=z[99+x]*(z[58]*256+z[59])/100;
  218.                                 jg=1;//開激光
  219.                                 delayms(s);
  220.                             jg=0;  //關閉激光
  221.                         if(z[66]==1)
  222.                         {
  223.                         xbac(bu);
  224.                         }       
  225.              else
  226.                          {
  227.                          xfor(bu);
  228.                          }                         

  229.                         }
  230.                        
  231.                     if(z[64]==1)    z[64]=0; //停止標志 跳出循環
  232.                     else{yfor(bu);}//x軸退回行開始,y軸進一行
  233.                                       
  234.                     
  235.                  
  236. }

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


  249. void chuanlo() interrupt 4
  250. {
  251.   if(RI)
  252.   {
  253.    
  254.      buff[cont2]=SBUF;//每次3字節,地址高,地址低,數據,,
  255.            cont2++;
  256.      if(cont2==3)//每收3個字節,把數據寫入地址中
  257.            {
  258.             z[(buff[0]*256)+buff[1]]=buff[2];
  259.                   cont2=0;

  260.            }
  261.          RI=0;
  262.   }
  263. }

  264. main()
  265. {  
  266.    EA=1;
  267.    P0=0xff;
  268.    ConfigUART(9600)        ;
  269.         z[60]=15;//默認的參數
  270.         z[61]=50;
  271.         z[56]=1;
  272.         z[62]=0;
  273.         jg=0;
  274.         cont2=0;
  275.        
  276.    while(1)
  277.    {
  278.     if(z[57]==100)                                     //        *****此處已更改******
  279.         {   ConfigPWM(100, 98); delayms(10);} //上位機指令處理,打開弱光定位,頻率100Hz,占空比98%

  280.         if(z[57]==0)
  281.          {ClosePWM();delayms(10);}

  282.           if(cont2!=0) led=0;  else led=1;//指示通信是否可用
  283.     if(z[50]>0){xfor(z[50]);z[50]=0;}//x前進
  284.           if(z[51]>0){xbac(z[51]);z[51]=0;}
  285.           if(z[52]>0){yfor(z[52]);z[52]=0;}
  286.           if(z[53]>0){ybac(z[53]);z[53]=0;}

  287.          
  288.           
  289.       if(z[62])//開始打印標志
  290.           {
  291.             dazi(z[54]*256+z[55],z[56]);
  292.                 z[62]=0;//一行打印完成
  293.                 SBUF=1;//發送信息,表示打印完成
  294.           while(!TI);
  295.                 TI=0;
  296.           }
  297.    
  298.   }

  299. }
復制代碼



激光雕刻.rar

639.05 KB, 下載次數: 15, 下載積分: 黑幣 -5

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产综合久久久久久鬼色 | 天天色图 | zzzwww在线看片免费 | 一区二区三区视频在线 | 91久久国产综合久久 | 福利视频三区 | 97精品国产97久久久久久免费 | 亚洲国产精品一区二区三区 | 欧美在线一区二区三区 | 射欧美 | 久久久青草 | 日韩三级电影在线看 | 国产99久久 | 国产一二三视频在线观看 | 一区二区高清 | 国产探花在线精品一区二区 | 成人精品国产 | 久久久久国产一区二区三区四区 | 欧美成人一区二区 | 日韩在线一区二区三区 | 亚洲v日韩v综合v精品v | 精品国产一区二区在线 | 国产精品视频一区二区三区四蜜臂 | 免费黄色片视频 | 精品国产久 | 亚洲xxxxx| 超碰人人在线 | 日韩手机在线视频 | 亚洲欧美在线一区 | 在线观看亚洲专区 | 国产三级日本三级 | 精品日韩一区二区 | 99视频在线 | 日韩精品福利 | 欧美激情精品久久久久久 | 国产成人免费视频网站高清观看视频 | 香蕉一区 | 日本免费在线观看视频 | 国产精品美女一区二区三区 | www.国产日本 | 日韩在线中文字幕 |