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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

超聲測距程序一點反應也沒有,有請高手

[復制鏈接]
跳轉到指定樓層
樓主
ID:222521 發表于 2017-7-26 19:23 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
我在網上找的超聲測距程序,實驗板是我自己做的89c52RC+74HC595兩片驅動6位共陽數碼管。板子可以跑計數程序,IO口也沒問題但就是上這個程序一點反應也沒有,有請高人幫我看看是這程序有問題,還是我淘寶的HC-SR04有問題、
  1. #include <AT89X51.H>                                                                //頭文件

  2. unsigned char code fseg[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
  3. unsigned char code segbit[]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};
  4. unsigned char  disbuf[8]={0,0,0,0,0,0,0,0};


  5. //-----------------------------------------------------------------------------
  6. // 函數原形定義
  7. #define uchar unsigned char
  8. #define uint unsigned int

  9. void main (void);                    // 主函數
  10. void LED4_Display (void);            // LED顯示
  11. void LED_OUT(uchar X);                // LED單字節串行移位函數
  12. void delayms(uint);                    //延時子函數 ms
  13. void jisuan(void);

  14. unsigned char code LED_0F[];        // LED字模表

  15. sbit DIO=P1^0;  //14腳              //串行數據輸入
  16. sbit RCLK=P1^1;//12腳                //時鐘脈沖信號——上升沿有效
  17. sbit SCLK=P1^2;//11腳                //打入信號————上升沿有效
  18. sbit echo=P3^2;                                                    //echo
  19. sbit trig=P3^3;                                                    //trig



  20. //-----------------------------------------------------------------------------
  21. // 全局變量
  22. uchar LED[8];    //用于LED的8位顯示緩存
  23. uint temp;                                                                                       
  24. uint temp1;
  25. uint a,b;                                                            //定義一個變量a,b  后者用于判斷是否收到信號
  26. //
  27. // 主程序
  28. //
  29. void main(void)                                        //主函數開始
  30. {   
  31.         uint f;
  32.     echo=0;                                            //先拉低echo,trig引腳
  33.     trig=0;
  34.         f=500;
  35.     while(f>0);                                        //啟動延時  消除第一次上電產生的波動
  36.         {
  37.            LED[3]=16;
  38.       LED[2]=15;
  39.       LED[1]=15;
  40.       LED[0]=16;
  41.          f--;
  42.        }
  43.     EA=1;                                            //開總中斷
  44.     TMOD=0x11;                                        //設置定時器為方式1
  45.     ET0=1;        //允許定時器中斷  這里主要是防止超聲波模塊未發送信號
  46.     ET1=1;
  47.     while(1)
  48.     {
  49.         echo=0;//a賦值
  50.         a=0;        
  51.         b=1;
  52.         TH0=0;                                        //定時器裝初值
  53.         TL0=0;
  54.         TH1=(65536-25000)/256;                        //定時器裝初值
  55.         TL1=(65536-25000)%256;
  56.         trig=1;                                        //trig送高
  57.         LED4_Display ();                                //    延時3ms
  58.         LED4_Display ();
  59.         LED4_Display ();
  60.         LED4_Display ();
  61.         LED4_Display ();
  62.         LED4_Display ();
  63.         LED4_Display ();
  64.         trig=0;                                                                                   //trig送低
  65.         TR1=1;
  66.         while(echo==0);                                    //等待echo變為高電平
  67.                 if(b==1)                                                                          // 判斷是否收到信號
  68.         {

  69.             TR1=0;                                        //關定時器1
  70.             EX0=1;                                        //開外部中斷
  71.             TR0=1;                                        //啟動定時器
  72.             while(a==0);//注意這里!    前面給a賦0 程序停在這里等待中斷
  73. //本來是在這里加上掃描屏幕程序的  發現有重大BUG索性刪除  
  74.         }
  75.         else
  76.         {

  77.             LED[3]=16;
  78.             LED[2]=15;
  79.             LED[1]=15;
  80.             LED[0]=16;
  81.         LED4_Display ();
  82.         LED4_Display ();
  83.         LED4_Display ();
  84.         LED4_Display ();
  85.         LED4_Display ();
  86.         LED4_Display ();


  87.         }
  88.     }
  89. }
  90. void waibu() interrupt 0                                //外部中斷服務子程序
  91. {
  92.     temp=TH0;                                    //取出定時器的值
  93.     temp1=TL0;                                                                                    
  94.     EX0=0;                                        //關閉外部中斷
  95.     TR0=0;                                        //關閉定時器
  96.     jisuan();                                        //運行計算子程序
  97.     a=1;//a賦值1    程序回到剛才的  while(a)  中因為a的值已變為1,程序從頭開始
  98. }
  99. void time1() interrupt 1                                  //定時器中斷服務子程序
  100. {
  101.     TH0=0;                                        //重裝初值
  102.     TL0=0;
  103. }

  104. void time2() interrupt 3
  105. {
  106.     TR1=0;
  107.     TH0=(65536-25000)/256;                        //定時器裝初值
  108.     TL0=(65536-25000)%256;
  109.     b=0;
  110.     echo=1;

  111. }
  112. void jisuan(void)//計算子程序
  113. {
  114.     uint c,d;//定義一個變量c,d 用來判斷距離
  115.     c=0;  //賦值0
  116.     d=0;   //給b重新賦值
  117.     LED4_Display (); //掃描一下數碼管
  118.     temp=(temp<<8)+temp1;                            //TH0 TL0合并
  119.     temp=temp/5;//我沒有精確計算 直接除5得出大概值

  120.     if(temp>40) //判段距離是否過近
  121.         {
  122.             c=1;
  123.         }
  124.         LED4_Display ();                            //掃描一下數碼管
  125.     if(temp<40)
  126.         {
  127.          c=0;
  128.         }
  129.         LED4_Display ();
  130.         if(temp<3000) //判斷距離是否過遠
  131.         {
  132.             d=1;
  133.         }
  134.         LED4_Display ();
  135.     if(temp>3000)
  136.         {
  137.          d=0;
  138.         }
  139.     c=c&d;//與運算
  140.     if(c==1) //判斷距離是否正常
  141.         {

  142.             LED[3]=temp/1000; //數值分離顯示
  143.             LED[2]=temp%1000/100;
  144.             LED[1]=(temp%1000%100/10)+20;    //這個為什么要加上20呢?  因為這是個位  需要顯示小數點  
  145.             LED[0]=temp%1000%100%10;
  146.         }
  147.     if(c==0)                                            //判斷距離是否正常
  148.         {

  149.             LED[3]=16;
  150.             LED[2]=14;
  151.             LED[1]=14;
  152.             LED[0]=16;
  153.         }

  154. }
  155. void delayms(uint xms)                    //延時子函數 ms
  156.     {
  157.         uint i,j;
  158.         for(i=xms;i>0;i--)
  159.             for(j=110;j>0;j--);
  160.     }

  161.     //下面的程序是hc595模塊顯示程序
  162.     //每個模塊的程序可以到資料的例程中移植
  163.     //*******************************************************//
  164. void LED4_Display (void)//屏幕掃描子函數   

  165. {
  166.     unsigned char code *led_table;          // 查表指針
  167.     uchar i;
  168.     //顯示第1位
  169.     led_table = LED_0F + LED[0];
  170.     i = *led_table;

  171.     LED_OUT(i);            
  172.     LED_OUT(0xfe);        

  173.     RCLK = 0;
  174.     RCLK = 1;
  175.     //顯示第2位
  176.     led_table = LED_0F + LED[1];
  177.     i = *led_table;

  178.     LED_OUT(i);        
  179.     LED_OUT(0x02);        

  180.     RCLK = 0;
  181.     RCLK = 1;
  182.     //顯示第3位
  183.     led_table = LED_0F + LED[2];
  184.     i = *led_table;

  185.     LED_OUT(i);            
  186.     LED_OUT(0x04);   

  187.     RCLK = 0;
  188.     RCLK = 1;
  189.     //顯示第4位
  190.     led_table = LED_0F + LED[3];
  191.     i = *led_table;

  192.     LED_OUT(i);            
  193.     LED_OUT(0x08);        

  194.     RCLK = 0;
  195.     RCLK = 1;

  196. }

  197. void LED_OUT(uchar X)
  198. {
  199.     uchar i;
  200.     for(i=8;i>=1;i--)
  201.     {
  202.         if (X&0x80) DIO=1; else DIO=0;
  203.         X<<=1;
  204.         SCLK = 0;
  205.         SCLK = 1;
  206.     }
  207. }
  208. //下面是顯示數組
  209. unsigned char code LED_0F[] =
  210. {// 0      1       2       3     4      5       6       7     8      9       A       b     C    d      E    F     -        .
  211.     0xc0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x8C,0xBF,0xC6,0xA1,0x86,0x8e,0xbf,0x7f,0x00,0x00,
  212. //    20    21     22   23   24   25   26    27   28  29   30
  213.     0x40,0x79,0x24,0x30,0x19,0x12,0x12,0x78,0x00,0x10,0xbf,
  214. };


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

使用道具 舉報

沙發
ID:164602 發表于 2017-7-27 08:21 | 只看該作者
程序不對吧,特別是發射超聲波,只需要至少10us,你用了18ms,天,回波早就過了,當然測不到了。我這里有一個例子,看看吧。
#include"reg51.h"
#include <intrins.h>//_nop_()函數頭文件

sbit RX=P1^1;//連接Echo
sbit TX=P1^0;//連接Trig,

#define GPIO_DIG P0//數碼管顯示及控制I/O口定義
sbit LSA=P2^2;//138譯碼器的三位控制8位數碼管
sbit LSB=P2^3;
sbit LSC=P2^4;

unsigned int  time=0;
unsigned int  timer=0;
unsigned long S=0;
bit flag=0;

unsigned char code DIG_CODE[16]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
unsigned char disbuff[4]={0,0,0,0};

void DigDisplay()//數碼管顯示函數,并賦初值0
{
        unsigned char i;
        unsigned int j;
        for(i=0;i<4;i++)
        {
                switch(i)
                {
                        case(0):
                                LSC=0;LSB=0;LSA=0; break;//顯示第0位,最右位
                        case(1):
                                LSC=0;LSB=0;LSA=1; break;//顯示第1位
                        case(2):
                                LSC=0;LSB=1;LSA=0; break;//顯示第2位
                        case(3):
                                LSC=0;LSB=1;LSA=1; break;//顯示第3位
                }
                GPIO_DIG=disbuff[i];//發送段碼
                j=20;
                while(j--);       
                GPIO_DIG=0x00;
        }
}

void Conut(void)//計算距離函數
{
        time=TH0*256+TL0;
        TH0=0;//重裝定時器0的初值
        TL0=0;
       
        S=(long)(time*0.17);
        if((S>=4000)||flag==1)
        {         
                flag=0;
                disbuff[0]=0x5c;//“o”
                disbuff[1]=0x72;//“r”
                disbuff[2]=0x72;//“r”
                disbuff[3]=0x79;//“E”
        }
        else
        {
                disbuff[3]=DIG_CODE[S%10000/1000];
                disbuff[2]=DIG_CODE[S%1000/100];
                disbuff[1]=DIG_CODE[S%100/10];
                disbuff[0]=DIG_CODE[S%10/1];
        }
}

void zd1() interrupt 1
{
        flag=1;
}

void zd3() interrupt 3
{
        TH1=0xf8;//重裝初值
        TL1=0x30;
        DigDisplay();//調用顯示
        timer++;
        if(timer>=50)
        {
                timer=0;
                TX=1;
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                _nop_();
                TX=0;
        }
}

void  main(  void  )
{  
        TMOD=0x11;
        TH0=0;
        TL0=0;         
        TH1=0xf8;
        TL1=0x30;
        ET0=1;
        ET1=1;
        TR1=1;
        EA=1;

        while(1)
        {
                while(!RX);
                TR0=1;
                while(RX);
                TR0=0;
                Conut();
        }
}

可能與你的硬件顯示部分不同,自己改改。

回復

使用道具 舉報

板凳
ID:222521 發表于 2017-7-27 10:04 | 只看該作者
HC6800-ES-V2.0 發表于 2017-7-27 08:21
程序不對吧,特別是發射超聲波,只需要至少10us,你用了18ms,天,回波早就過了,當然測不到了。我這里有一 ...

首先要感謝你的回復雖然我還不明白該如何改動,但我會去仔細琢磨,謝謝你的程序。
回復

使用道具 舉報

地板
ID:222521 發表于 2017-7-27 19:29 | 只看該作者
好消息!好消息!現在已經可以跑程序了,只是顯示的字符不正常,等我繼續弄明白后告訴大家,不過看來大家對這個興趣不大
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 91丨九色丨国产在线 | 天堂在线一区 | 91社区在线观看 | 色屁屁在线观看 | 亚洲国产精品一区二区三区 | 成人亚洲一区 | 欧美日韩一区二区三区四区 | 操操日 | 国产成人99久久亚洲综合精品 | 久久久久久久国产精品视频 | 日韩在线精品强乱中文字幕 | 亚洲精品亚洲人成人网 | 国产成人麻豆免费观看 | 亚洲午夜精品一区二区三区他趣 | 久草在线| 久久久久久久久蜜桃 | 99免费在线视频 | 国产精品999 | 日韩欧美精品一区 | 成人在线免费网站 | 91最新在线视频 | 免费美女网站 | 日日操操 | 在线观看视频一区 | 日韩欧美日韩在线 | 美女国内精品自产拍在线播放 | 久久久免费观看视频 | 夜夜草 | 91精品国产麻豆 | 国产精品视频久久 | 亚洲精品一区二区三区丝袜 | 91久久国产综合久久91精品网站 | 黄色三级免费网站 | 中文字幕 在线观看 | 成人精品福利 | 日韩欧美在线视频一区 | 黄免费在线 | 久久lu| 成人免费看片 | 毛片久久久 | 久久婷婷国产麻豆91 |