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

標題: STC單片機超聲波測距51C程序 [打印本頁]

作者: 正一番薯。    時間: 2016-8-11 04:19
標題: STC單片機超聲波測距51C程序
超聲波模塊

  1. //晶振=8M
  2. //MCU=STC10F04XE
  3. //P0.0-P0.6共陽數碼管引腳
  4. //Trig  = P1^0
  5. //Echo  = P3^2
  6. #include <reg52.h>     //包括一個52標準內核的頭文件
  7. #define uchar unsigned char //定義一下方便使用
  8. #define uint  unsigned int
  9. #define ulong unsigned long
  10. //***********************************************
  11. sfr  CLK_DIV = 0x97; //為STC單片機定義,系統時鐘分頻
  12.                      //為STC單片機的IO口設置地址定義
  13. sfr   P0M1   = 0X93;
  14. sfr   P0M0   = 0X94;
  15. sfr   P1M1   = 0X91;
  16. sfr   P1M0   = 0X92;
  17. sfr        P2M1   = 0X95;
  18. sfr        P2M0   = 0X96;
  19. //***********************************************
  20. sbit Trig  = P1^0; //產生脈沖引腳
  21. sbit Echo  = P3^2; //回波引腳
  22. sbit test  = P1^1; //測試用引腳

  23. uchar code SEG7[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};//數碼管0-9
  24. uint distance[4];  //測距接收緩沖區
  25. uchar ge,shi,bai,temp,flag,outcomeH,outcomeL,i;  //自定義寄存器
  26. bit succeed_flag;  //測量成功標志
  27. //********函數聲明
  28. void conversion(uint temp_data);
  29. void delay_20us();
  30. //void pai_xu();

  31. void main(void)   // 主程序
  32. {  uint distance_data,a,b;
  33.    uchar CONT_1;   
  34.    CLK_DIV=0X03; //系統時鐘為1/8晶振(pdf-45頁)
  35.      P0M1 = 0;   //將io口設置為推挽輸出
  36.      P1M1 = 0;
  37.      P2M1 = 0;
  38.      P0M0 = 0XFF;
  39.      P1M0 = 0XFF;
  40.      P2M0 = 0XFF;
  41.    i=0;
  42.    flag=0;
  43.         test =0;
  44.         Trig=0;       //首先拉低脈沖輸入引腳
  45.         TMOD=0x11;    //定時器0,定時器1,16位工作方式
  46.         TR0=1;             //啟動定時器0
  47.    IT0=0;        //由高電平變低電平,觸發外部中斷
  48.         ET0=1;        //打開定時器0中斷
  49. //ET1=1;        //打開定時器1中斷
  50.         EX0=0;        //關閉外部中斷
  51.         EA=1;         //打開總中斷0       
  52.   
  53.        
  54. while(1)         //程序循環
  55.         {
  56.   EA=0;
  57.              Trig=1;
  58.         delay_20us();
  59.         Trig=0;         //產生一個20us的脈沖,在Trig引腳  
  60.         while(Echo==0); //等待Echo回波引腳變高電平
  61.              succeed_flag=0; //清測量成功標志
  62.              EX0=1;          //打開外部中斷
  63.                    TH1=0;          //定時器1清零
  64.         TL1=0;          //定時器1清零
  65.              TF1=0;          //
  66.         TR1=1;          //啟動定時器1
  67.    EA=1;

  68.       while(TH1 < 30);//等待測量的結果,周期65.535毫秒(可用中斷實現)  
  69.                   TR1=0;          //關閉定時器1
  70.         EX0=0;          //關閉外部中斷

  71.     if(succeed_flag==1)
  72.              {        
  73.                    distance_data=outcomeH;                //測量結果的高8位
  74.            distance_data<<=8;                   //放入16位的高8位
  75.                      distance_data=distance_data|outcomeL;//與低8位合并成為16位結果數據
  76.             distance_data*=12;                  //因為定時器默認為12分頻
  77.            distance_data/=58;                   //微秒的單位除以58等于厘米
  78.          }                                      //為什么除以58等于厘米,  Y米=(X秒*344)/2
  79.                                                                // X秒=( 2*Y米)/344 ==》X秒=0.0058*Y米 ==》厘米=微秒/58
  80.     if(succeed_flag==0)
  81.                    {
  82.             distance_data=0;                    //沒有回波則清零
  83.                            test = !test;                       //測試燈變化
  84.            }

  85.      ///       distance[i]=distance_data; //將測量結果的數據放入緩沖區
  86.      ///        i++;
  87.             ///         if(i==3)
  88.           ///             {
  89.           ///               distance_data=(distance[0]+distance[1]+distance[2]+distance[3])/4;
  90.      ///        pai_xu();
  91.      ///        distance_data=distance[1];

  92.       
  93.            a=distance_data;
  94.        if(b==a) CONT_1=0;
  95.        if(b!=a) CONT_1++;
  96.        if(CONT_1>=3)
  97.                    { CONT_1=0;
  98.                           b=a;
  99.                           conversion(b);
  100.                         }      
  101.           ///                 i=0;
  102.           ///                }             
  103.          }
  104. }
  105. //***************************************************************
  106. //外部中斷0,用做判斷回波電平
  107. INTO_()  interrupt 0   // 外部中斷是0號
  108. {   
  109.      outcomeH =TH1;    //取出定時器的值
  110.      outcomeL =TL1;    //取出定時器的值
  111.      succeed_flag=1;   //至成功測量的標志
  112.      EX0=0;            //關閉外部中斷
  113.   }
  114. //****************************************************************
  115. //定時器0中斷,用做顯示
  116. timer0() interrupt 1  // 定時器0中斷是1號
  117.    {
  118.          TH0=0xfd; //寫入定時器0初始值
  119.          TL0=0x77;                
  120.          switch(flag)   
  121.       {case 0x00:P0=ge; P2=0xfd;flag++;break;
  122.             case 0x01:P0=shi;P2=0xfe;flag++;break;
  123.             case 0x02:P0=bai;P2=0xfb;flag=0;break;
  124.       }
  125.    }
  126. //*****************************************************************
  127. /*
  128. //定時器1中斷,用做超聲波測距計時
  129. timer1() interrupt 3  // 定時器0中斷是1號
  130.     {
  131. TH1=0;
  132. TL1=0;
  133.      }
  134. */
  135. //******************************************************************
  136. //顯示數據轉換程序
  137. void conversion(uint temp_data)  
  138. {  
  139.     uchar ge_data,shi_data,bai_data ;
  140.     bai_data=temp_data/100 ;
  141.     temp_data=temp_data%100;   //取余運算
  142.     shi_data=temp_data/10 ;
  143.     temp_data=temp_data%10;   //取余運算
  144.     ge_data=temp_data;

  145.     bai_data=SEG7[bai_data];
  146.     shi_data=SEG7[shi_data];
  147.     ge_data =SEG7[ge_data];

  148.     EA=0;
  149.     bai = bai_data;
  150.     shi = shi_data;
  151.     ge  = ge_data ;
  152.          EA=1;
  153. }
  154. //******************************************************************
  155. void delay_20us()
  156. {  uchar bt ;
  157.     for(bt=0;bt<100;bt++);
  158. }
  159. /*
  160. void pai_xu()
  161.   {  uint t;
  162.   if (distance[0]>distance[1])
  163.     {t=distance[0];distance[0]=distance[1];distance[1]=t;} /*交換值
  164.   if(distance[0]>distance[2])
  165.     {t=distance[2];distance[2]=distance[0];distance[0]=t;} /*交換值
  166.   if(distance[1]>distance[2])
  167.     {t=distance[1];distance[1]=distance[2];distance[2]=t;} /*交換值         
  168.     }
  169. */
復制代碼


超聲波測距51C程序.rar

2.18 KB, 下載次數: 6, 下載積分: 黑幣 -5


作者: WFX777888    時間: 2016-8-18 17:45
謝謝分享資料




歡迎光臨 (http://m.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 日本免费黄色 | 精品国产精品 | 欧美日韩国产在线 | 波多野结衣乳巨码无在线观看 | 国产精品一区视频 | 欧美一级淫片bbb一84 | 欧美一区视频 | 成人免费看片视频 | 国产一级黄色录像 | 国产一区在线看 | 日日夜夜天天操 | 秋霞一区二区 | 亚洲欧美日韩一区二区 | 成人一级视频 | 国产精品成人免费视频 | 精品一区二区三区四区五区 | 毛片资源| 国产成人在线观看免费网站 | 色综合小说| 伊人久久中文字幕 | 精品一二三 | 天天色网站 | 国产一级一片免费播放放a 免费国产视频 | 精品久久久久久久久久久久久 | 九九九视频| 毛片网站视频 | 玖玖伊人| 亚洲欧美日韩综合 | 国产精品美女在线 | 91av免费观看 | 久久精品99久久久久久 | 亚洲不卡视频 | 狠狠干在线视频 | 99在线免费观看 | 久久精品观看 | 久色91 | 欧美成年人视频 | 国产理论在线 | 成人手机在线观看 | 国产乱码一区二区 | 99视频在线精品免费观看2 |