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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

請大神幫忙看下我搞的《基于51單片機的激光雕刻機》出了點問題

[復制鏈接]
跳轉到指定樓層
樓主
ID:253995 發表于 2017-12-14 19:28 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
電路接線沒有問題,我用其他程序測試了,步進電機轉動和激光器都正常。我把激光雕刻機的程序燒進了開發板(不知道這有沒有影響),程序是從論壇里借鑒的。我現在懷疑程序有問題,或者軟件驅動有問題(我用了兩個雕刻軟件,一個可以連接成功,按方向鍵的時候,led指示燈(程序里的P2^1指示通信是否可用的)會亮但是電機沒有反應;另一個連接不上)

單片機程序如下:
  1. #include <reg52.h>
  2. #define uint unsigned int
  3. #define uchar unsigned char
  4. #define N z[60]       //X速度
  5. #define M z[61]       //Y速度
  6. sbit a=P1^3;//步進電機接線定義  移動激光頭
  7. sbit a_=P1^2;
  8. sbit b=P1^1;
  9. sbit b_=P1^0;
  10. sbit xa=P1^4;
  11. sbit xa_=P1^5;
  12. sbit xb=P1^6;
  13. sbit xb_=P1^7;
  14. /*sbit a=P1^4;//步進電機接線定義 移動底板
  15. sbit a_=P1^5;
  16. sbit b=P1^6;
  17. sbit b_=P1^7;
  18. sbit xa=P1^3;
  19. sbit xa_=P1^2;
  20. sbit xb=P1^1;
  21. sbit xb_=P1^0;  */
  22. sbit jg=P2^0;
  23. sbit led=P2^1;//指示燈
  24. uchar xdata z[500]={0};//緩存
  25. uchar buff[3];//串口緩存
  26. uchar x1,x0,y1,y0,cont2=0;
  27. uchar xfb=4,yfb=4;//走步標志位

  28. unsigned char HighRH = 0;  //高電平重載值的高字節
  29. unsigned char HighRL = 0;  //高電平重載值的低字節
  30. unsigned char LowRH  = 0; //低電平重載值的高字節
  31. unsigned char LowRL  = 0; //低電平重載值的低字節


  32. void delayms(uint xms)                     
  33. {   
  34.        uinti,j;
  35.        for(i=xms;i>0;i--)             //i=xms即延時約xms毫秒
  36.               for(j=110;j>0;j--);
  37. }

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


  84. void xfor(uint i)            //x軸前進函數,前進多少步
  85. {   
  86. while(1)
  87.   {
  88.               if(xfb==4)
  89.                 {
  90.         xa=xb=1;
  91.               xb_=xa_=0;
  92.                    xfb=1;
  93.                    i--;              
  94.               delayms(N);
  95.                    if(i==0){xa=xb=0; break;}
  96.                 }
  97.                  if(xfb==1)
  98.                 {
  99.         xb=xa_=1;
  100.               xa=xb_=0;
  101.                    xfb=2;
  102.                    i--;
  103.               delayms(N);
  104.                    if(i==0){xa_=xb=0; break;}
  105.                 }
  106.                  if(xfb==2)
  107.                 {
  108.         xa_=xb_=1;
  109.         xb=xa=0;
  110.                    xfb=3;  //走步標志位
  111.                    i--;
  112.               delayms(N);
  113.                    if(i==0){xa_=xb_=0; break;}
  114.                  }
  115.                  if(xfb==3)
  116.                 {
  117.         xa_=xb=0;
  118.               xb_=xa=1;
  119.                    xfb=4;
  120.                    i--;
  121.               delayms(N);
  122.                    if(i==0){xa=xb_=0; break;}
  123.                 }

  124.               }

  125. }

  126. void xbac(uint i)           //xxx后退函數
  127. {   
  128.     while(1)
  129.         {
  130.               if(xfb==1)
  131.                 {
  132.         xa_=xb=0;
  133.               xb_=xa=1;
  134.                    xfb=4;
  135.                    i--;                     //走步標志位
  136.               delayms(N);
  137.                   if(i==0){xa=xb_=0; break;}
  138.                  }
  139.                  if(xfb==4)
  140.                 {
  141.         xa_=xb_=1;
  142.         xb=xa=0;
  143.                    xfb=3;
  144.                    i--;
  145.               delayms(N);
  146.                    if(i==0){xa_=xb_=0; break;}
  147.                  }
  148.                  if(xfb==3)
  149.                 {
  150.         xb=xa_=1;
  151.               xa=xb_=0;
  152.                    xfb=2;  //走步標志位
  153.                    i--;
  154.               delayms(N);
  155.                    if(i==0){xa_=xb=0; break;}
  156.                  }
  157.                  if(xfb==2)
  158.                 {
  159.         xa=xb=1;
  160.               xb_=xa_=0;
  161.                    xfb=1;
  162.                    i--;
  163.               delayms(N);
  164.                    if(i==0){xa=xb=0; break;}
  165.                 }
  166.               }
  167. }


  168. void yfor(uint i)            //y軸前進函數
  169. {   
  170.     while(1)
  171.     {
  172.               switch(yfb)
  173.                  {
  174.                    case 4:{a=b=1; b_=a_=0; yfb=1; i--;delayms(M); if(i==0){a=b=0;break;}}
  175.                             case 1:{b=a_=1; a=b_=0; yfb=2; i--;delayms(M); if(i==0){a_=b=0;break;}}
  176.                             case 2:{a_=b_=1; b=a=0; yfb=3; i--;delayms(M); if(i==0){a_=b_=0;break;}}
  177.                             case 3:{b_=a=1; a_=b=0; yfb=4; i--;delayms(M); if(i==0){a=b_=0;break;}}
  178.                  }
  179.                  if(i==0) break;
  180.      }
  181. }

  182. void ybac(uint i)           //yy后退函數
  183. {   
  184.     while(1)
  185.     {
  186.               switch(yfb)
  187.                  {
  188.                    case 1:{a=b_=1; b=a_=0; yfb=4; i--;delayms(M); if(i==0){a=b_=0;break;}}
  189.                             case 4:{b_=a_=1; a=b=0; yfb=3; i--;delayms(M); if(i==0){a_=b_=0;break;}}
  190.                             case 3:{a_=b=1; b_=a=0; yfb=2; i--;delayms(M); if(i==0){a_=b=0;break;}}
  191.                             case 2:{b=a=1; a_=b_=0; yfb=1; i--;delayms(M); if(i==0){a=b=0;break;}}
  192.                  }
  193.                  if(i==0) break;
  194.      }
  195. }

  196. void dazi(uint zik)//打印函數               ******打印函數已更改******
  197. {
  198.    uint x;
  199.               jg=0;

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

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

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

  249.    
  250.   }
  251. if(TI)
  252.    {
  253.   TI=0;

  254.    }
  255. }

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

  271.    if(z[57]==100){ConfigPWM(100, 98);delayms(10);}   //上位機指令處理,打開弱光定位,頻率100Hz,占空比98%                                                      
  272.    else if(z[57]==1)   jg=0;                                         //打開強光
  273.        else   { ClosePWM(); delayms(10);}
  274.       
  275.          if(cont2!=0) led=0;  else led=1;//指示通信是否可用
  276.      if(z[50]==1){xfor(z[51]*256+z[52]);z[50]=0;}//x+
  277.        if(z[50]==2){xbac(z[51]*256+z[52]);z[50]=0;}//x-
  278.        if(z[50]==3){yfor(z[51]*256+z[52]);z[50]=0;}//y+
  279.        if(z[50]==4){ybac(z[51]*256+z[52]);z[50]=0;}//y-

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

  287. }
復制代碼


激光雕刻機軟甲.zip

9.01 MB, 下載次數: 34

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

使用道具 舉報

沙發
ID:401973 發表于 2022-2-23 23:12 來自手機 | 只看該作者
感覺是上位機問題
回復

使用道具 舉報

板凳
ID:161164 發表于 2022-2-24 09:56 來自手機 | 只看該作者
linta 發表于 2022-2-23 23:12
感覺是上位機問題

2017的老墳貼你也挖?
回復

使用道具 舉報

地板
ID:401973 發表于 2022-2-24 23:49 來自手機 | 只看該作者
lkc8210 發表于 2022-2-24 09:56
2017的老墳貼你也挖?

我剛整這個,碰到同樣問題,沒注意時間
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产一级在线观看 | 在线视频中文字幕 | 色接久久 | 精精国产xxxx视频在线播放7 | 91精品国产乱码久久久久久久久 | 国产精品国产 | 欧美日韩一卡二卡 | 久久精品免费看 | 在线看片网站 | 91福利影院 | 精品国产乱码 | 成人影院在线视频 | 国产日韩欧美一区二区 | 国产清纯白嫩初高生视频在线观看 | 伊人久久精品 | 国产福利网站 | 国产欧美日韩一区二区三区在线 | 盗摄精品av一区二区三区 | 色欧美综合 | 欧美13videosex性极品 | a在线免费观看 | 日韩成人在线一区 | 午夜三级网站 | 国产在线资源 | 夜夜爽99久久国产综合精品女不卡 | 做a网站| 成人免费视频网站在线观看 | 国产午夜影院 | 亚洲va欧美va天堂v国产综合 | 久久国产欧美日韩精品 | 欧美a级成人淫片免费看 | 亚洲一区二区视频在线播放 | 91精品国产色综合久久 | 欧美色综合一区二区三区 | 羞羞网站在线免费观看 | 91九色porny首页最多播放 | 久久久国产一区 | 一区二区在线看 | 一级黄色毛片免费 | 欧美高清视频在线观看 | 日韩电影免费在线观看中文字幕 |