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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

基于stc8g1k08a單片機的簡易示波器和超聲波測距二合一小制作 附程序

  [復制鏈接]
跳轉到指定樓層
樓主
stc8g1k08a是深圳宏晶科技的一款8腳8位兼容51系列的單片機  價格很便宜 但麻雀雖小五臟俱全 且速度還挺快下面就是用它做的小東東 精度不是很高 本人也是剛入門 水平有限 希望大家多多指教共兩個按鍵 :按住周期和啟動按鍵5秒鐘后兩個程序互相切換  短按示波器是切換掃描周期  超聲波測距是啟動按鍵  波形鎖定是示波器波形固定用的

制作出來的實物圖如下:


電路原理圖如下:


單片機源程序如下:
  1. #include "reg51.h"
  2. #include "intrins.h"
  3. #include"main.h"
  4. #include<math.h>

  5. unsigned char xdata se[128];//把AD轉換后的臨時數據存于該數組
  6. unsigned char code sm[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//用于顯示一列中的一點
  7. unsigned int code time[9]={1,40,100,500,1000,2600,5250,10000,25000};
  8. unsigned int code time1[9]={1,3,5,20,40,100,200,400,1000};
  9. unsigned char xdata timd[5];
  10. unsigned char xdata ju_li[5];
  11. unsigned char p,z=0;
  12. unsigned int i=0,q=0;
  13. unsigned int m=5;
  14. //unsigned double q;
  15. sbit k1=P3^1;
  16. sbit trig=P3^3;
  17. sbit echo=P3^2;
  18. void delay_us(unsigned int i)
  19. {
  20.         while(i)
  21.         {
  22.           unsigned char a;
  23.     for(a=5;a>0;a--);
  24.         i--;
  25.         }
  26.        
  27. }
  28. void delay100ms(unsigned int i)   //誤差 -0.000000000025us
  29. {
  30.    while(i)
  31.    {
  32.    unsigned char a,b,c;
  33.     for(c=106;c>0;c--)
  34.         for(b=197;b>0;b--)
  35.             for(a=38;a>0;a--);
  36.     _nop_();  //if Keil,require use intrins.h
  37.         i--;
  38.         }
  39. }
  40. void main()
  41. {
  42.         P0M1 = 0;   P0M0 = 0;   //設置為準雙向口
  43.     P1M1 = 0;   P1M0 = 0;   //設置為準雙向口
  44.     P2M1 = 0;   P2M0 = 0;   //設置為準雙向口
  45.     P3M1 = 0;   P3M0 = 0;   //設置為準雙向口
  46.     P4M1 = 0;   P4M0 = 0;   //設置為準雙向口
  47.     P5M1 = 0;   P5M0 = 0;   //設置為準雙向口
  48.     /*        P_SW2 = 0x80;  //特殊寄存器允許位(0x80)
  49.         CKSEL = 0x00; //選擇內部 IRC ( 默認 )
  50.         CLKDIV = 0x03; //時鐘 3分頻
  51.         P_SW2 = 0x00;
  52.         */       
  53.         ad_init();        //ad轉換初始化
  54.     OLED_Init(); //OLED初始化
  55.           
  56.         for(z=0;z<128;z++)                             // 起   顯示啟動示波器文字
  57.         {
  58.                   for(i=0;i<8;i++)   //清屏
  59.                 {
  60.                                  OLED_WrCmd(0xb0+i);
  61.                                 OLED_WrCmd(0x00+(z%16));
  62.                         OLED_WrCmd(0x10+z/16);
  63.                                 OLED_WrDat(0x00);
  64.                 }
  65.         }
  66.                 for (i=0;i<8;i++)
  67.          {
  68.                 OLED_P16x16Ch(i*16,i/8*2+2,i);
  69.          }
  70.          delay100ms(30);
  71.                  for(z=0;z<128;z++)               
  72.         {
  73.                   for(i=0;i<8;i++)   //清屏
  74.                 {
  75.                                  OLED_WrCmd(0xb0+i);
  76.                                 OLED_WrCmd(0x00+(z%16));
  77.                         OLED_WrCmd(0x10+z/16);
  78.                                 OLED_WrDat(0x00);
  79.                 }
  80.         }                                                                                //止


  81.   while(1)
  82.   {
  83.         if(k1==0)
  84.         {
  85.                  i=0;
  86.                 m++;
  87.                  while(!k1)
  88.                  {
  89.                         
  90.                         delay100ms(1);
  91.                         i++;

  92.                        
  93.                         if(i>50)

  94.                         goto bosh;
  95.                        
  96.                  }
  97.                  
  98.                  if(m>8)
  99.                  {
  100.                          m=0;
  101.                  }
  102.                  //i++;
  103.      }
  104. //*******************AD轉換將臨時數據存于數組se[] ****************************************


  105.                 for(i=0;i<128;i++)
  106.         {
  107.                 se[i]=56-ad_dat()/18;
  108.                 delay(time[m]);

  109.         }
  110.                  timd[0]=time1[m]%10;
  111.                  timd[1]=time1[m]/10%10;
  112.                  timd[2]=time1[m]/100%10;
  113.                  timd[3]=time1[m]/1000%10;
  114.                  timd[4]=time1[m]/10000%10;
  115.                  OLED_P6x8Str(10,7,"Time = ");
  116.          OLED_P6x8Str(10+70,7," ms");

  117.        
  118.          for(i=0;i<5;i++)                                          //顯示掃描周期每一位 共五位
  119.          {
  120.          oled_6x8((10+40)+6*i,7,timd[4-i]+16);
  121.                  }
  122.                  


  123. //**********************oled顯示****************************
  124. /*    for(i=0;i<7;i++)
  125.        
  126.            {
  127.                                 OLED_WrCmd(0xb0+i);
  128.                                 OLED_WrCmd(0x00+(z%16));
  129.                         OLED_WrCmd(0x10+z/16);
  130.                                 OLED_WrDat(0x00);
  131.            }
  132.        
  133.         */
  134.           
  135.         for(z=0;z<128;z++)
  136.         {
  137.        
  138.                 for(i=0;i<7;i++)
  139.        
  140.            {
  141.                                 OLED_WrCmd(0xb0+i);
  142.                                 OLED_WrCmd(0x00+(z%16));
  143.                         OLED_WrCmd(0x10+z/16);
  144.                                 if((i==3)&&(z%4==0))
  145.                                 OLED_WrDat(0x10);
  146.                                 else if(z==63)
  147.                                 OLED_WrDat(0x44);
  148.                                 else
  149.                                 OLED_WrDat(0x00);
  150.            }
  151.                 OLED_WrCmd(0xb0+se[z]/7);
  152.                 OLED_WrCmd(0x00+(z%16));
  153.                 OLED_WrCmd(0x10+z/16);
  154.                 OLED_WrDat(sm[se[z]%7]);       
  155.        
  156.                
  157.         //        OLED_WrDat(0x00);
  158.                
  159.         }
  160.        
  161.          if(trig==0)
  162.          {
  163.                  delay100ms(10);
  164.                 while(trig);
  165.                 while(!trig);
  166.                
  167.          }  
  168.          
  169.   }
  170.   

  171.         //啟動超聲波測距程序。。。。。。
  172.         bosh:
  173.                 for(z=0;z<128;z++)
  174.         {
  175.                   for(i=0;i<8;i++)   //清屏
  176.                 {
  177.                                  OLED_WrCmd(0xb0+i);
  178.                                 OLED_WrCmd(0x00+(z%16));
  179.                         OLED_WrCmd(0x10+z/16);
  180.                                 OLED_WrDat(0x00);
  181.                 }
  182.         }
  183.                 for (i=0;i<8;i++)
  184.          {
  185.                 OLED_P16x16Ch(i*16,i/8*2+2,i+8);
  186.          }
  187.                        
  188.        
  189.         delay100ms(30);
  190.                 for(z=0;z<128;z++)
  191.         {
  192.                   for(i=0;i<8;i++)   //清屏
  193.                 {
  194.                                  OLED_WrCmd(0xb0+i);
  195.                                 OLED_WrCmd(0x00+(z%16));
  196.                         OLED_WrCmd(0x10+z/16);
  197.                                 OLED_WrDat(0x00);
  198.                 }
  199.         }

  200.                        
  201.         while(1)
  202.   {
  203.                   if(k1==0)
  204.         {
  205.                  q=0;
  206.                 trig=0;
  207.                 delay_us(1000);
  208.                 trig=1;
  209.        
  210.                 i=10;
  211.                  while(!echo)
  212.                  {
  213.                          delay_us(1);
  214.                         i--;
  215.                 i=0;       
  216.                  }
  217.                  while(echo)
  218.                  {
  219.                   delay_us(1);
  220.                   q++;       
  221.                  }
  222.                  q=q*0.21;
  223.                        
  224.        


  225.                  while(!k1)
  226.                  {
  227.                          i++;
  228.                 delay100ms(1);

  229.                        
  230.                         if(i>50)
  231.                         return;
  232.              }
  233.                         
  234.                  
  235.                

  236.     }
  237.             //q=156;
  238.                 ju_li[0]=q%10;
  239.                 ju_li[1]=q/10%10;
  240.                 ju_li[2]=q/100%10;
  241.                 ju_li[3]=q/1000%10;
  242.                 ju_li[4]=q/10000%10;
  243.          for(i=0;i<5;i++)
  244.          {
  245.          oled1_8x16( 48+8*i,4,ju_li[4-i]);
  246.          }
  247.                  for (i=0;i<6;i++)
  248.          {
  249.                 OLED_P16x16Ch(i*16,i/8*2,19+i);
  250.          }
  251.                         for (i=0;i<3;i++)
  252.          {
  253.                 OLED_P16x16Ch(i*16,i/8*2+2+2,19+6+i);

  254.          }
  255.                         for (i=0;i<2;i++)
  256.          {
  257.                 OLED_P16x16Ch(95+i*16,i/8*2+2+2,19+6+3+i);
  258.          }
  259.          
  260.   }
  261. }
復制代碼

所有資料51hei提供下載:
ad_led.rar (66.39 KB, 下載次數: 224)

評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:849913 發表于 2021-4-22 18:55 | 只看該作者
謝謝版主幫我整理 忘了告訴大家 單片機下載程序是 時鐘選擇33.1776MZ
回復

使用道具 舉報

板凳
ID:857072 發表于 2021-4-24 11:15 來自手機 | 只看該作者
有意思,下來有時間研究一下
回復

使用道具 舉報

地板
ID:756506 發表于 2021-4-24 11:21 | 只看該作者
不錯,有時間來做一個
回復

使用道具 舉報

5#
ID:431787 發表于 2021-5-2 20:10 | 只看該作者
keil5好像編譯不成功
回復

使用道具 舉報

6#
ID:915390 發表于 2021-5-3 22:00 來自手機 | 只看該作者
學到了,有空弄一個
回復

使用道具 舉報

7#
ID:601214 發表于 2021-5-30 10:00 | 只看該作者
這個能做成示波器嗎?
回復

使用道具 舉報

8#
ID:849913 發表于 2021-5-30 21:41 | 只看該作者
zhike 發表于 2021-5-30 10:00
這個能做成示波器嗎?

簡易的 都是出于自己對示波器工作原理的理解  頻率和精度都不高 主要是出于興趣玩玩
回復

使用道具 舉報

9#
ID:414556 發表于 2021-5-30 23:19 | 只看該作者
測距精度高不高,有沒有精度微調
回復

使用道具 舉報

10#
ID:849913 發表于 2021-6-3 15:26 | 只看該作者
測距精度可以用軟件調節 前提就是做著玩的 目的是對示波器和測試儀構思的實踐
回復

使用道具 舉報

11#
ID:927469 發表于 2021-7-5 22:09 | 只看該作者
lin2453676722 發表于 2021-5-2 20:10
keil5好像編譯不成功

把文件頭改一下就能編譯
#include "reg51.h"
#include "intrins.h"
#include"main.h"
#include<math.h>
改成:
#include <STC8G.h>
#ifndef     __STC8G_H__
#define     __STC8G_H__
回復

使用道具 舉報

12#
ID:849913 發表于 2021-7-10 11:42 | 只看該作者
kmikmi 發表于 2021-7-5 22:09
把文件頭改一下就能編譯
#include "reg51.h"
#include "intrins.h"

謝謝指點 我還不知道有這個方法  所以把reg51.h里面加了很多與8G相關的東西
回復

使用道具 舉報

13#
ID:953759 發表于 2021-7-17 10:57 | 只看該作者
老董 發表于 2021-4-22 18:55
謝謝版主幫我整理 忘了告訴大家 單片機下載程序是 時鐘選擇33.1776MZ

您好,這個時鐘是怎么確定的呢?
回復

使用道具 舉報

14#
ID:558833 發表于 2022-2-14 21:29 | 只看該作者
面包板插線,直接下載成功
回復

使用道具 舉報

15#
ID:185675 發表于 2022-6-8 22:32 | 只看該作者
//一個簡單的在stc8g1ko8A上可以運行的小demo,可以用于簡單的AD測量,define修改一下就行了
#define TIME_3S 30000
#define TIME_2S 30000
#define TIME_1MS 100
#define  TIME_2MS 200
#define  TIME_5MS 500
// 狀態機
#define READY_ST 1
#define CAPCHARGE 2
#define MOT_ST 3
#define STOP_ST 4
#define CHARGE_ST 5
#define DELAY_ST 6
// 信號接收
// 狀態機
#define keyRun
#define keyMot
// 數值
#define U500 20
#define U6500 500
#define U8000 700

unsigned int STATUS
unsigned int ADS
// 計數器
unsigned int keyRunCounter
unsigned int keyShutDownCounter
unsigned int shortCurrentCounter
unsigned int delaySTCounter
unsigned int capChargeCounter
unsigned int OVMonitCounter_1
unsigned int OVMonitCounter_2


mian()
{
case Status
    Run:
        Gpio.init;//keyRun 為推挽
    Mot:
        Gpio.init2;//keyRun 為input
    default:
        Gpio.init;//初始化為Run
}
void ISR()
{
    /*濾波器*/

    /*保護*/
    Protect();
    /*按鍵檢測*/
    keyMonitor();

    /*狀態與動作*/
    switch STATUS:
    case READY_ST:
        setGPIO1;
    case CHARGE_ST:
        setGPIO1();
    case DELAY_ST:
        setGPIO1();
    case MOT_ST:
        setGPIO1();
    case STOP_ST:
        setGPIO1();   
    default:   
}


/******************************
*執行保護邏輯
****************************/
void Protect()
{
    // Short State monitor
    if (STATUS != READY_ST) && (ADS < U500)//在待機時不檢測,其他時段都不放過
    {
        shortCurrentCounter++;
    }
    else
    {
        shortCurrentCounter = 0;
    }
    if (shortCurrentCounter > TIME_1MS)
    {
        shortCurrentCounter = 0;
        STATUS = STOP_ST;
        return;
    }
    // OverVoltage Monitor 1
    if (STATUS != READY_ST) && (ADS > U500)//
    {
        OVMonitCounter_1++;
    }
    else
    {
        OVMonitCounter_1 = 0;
    }
    if (OVMonitCounter_1 > OVMonitCounter_1Debounce)
    {
        OVMonitCounter_1 = 0;
        STATUS = DELAY_ST;
    }
    // OverVoltage Monitor 2
    if (STATUS != READY_ST) && (ADS > U7500)//
    {
        OVMonitCounter_2++;
    }
    else
    {
        OVMonitCounter_2 = 0;
    }
    if (OVMonitCounter_2 > OVMonitCounter_2Debounce)
    {
        OVMonitCounter_2 = 0;
        STATUS = DELAY_ST;
    }
}
/******************************
*按鍵檢測邏輯
****************************/
void keyMonitor()
{
    //待機狀態,長按*秒開機
    if (STATUS == READY_ST) && (keyRun == 1)//待機狀態,長按3秒開機
    {
        keyRunCounter++;
    }
    else
    {
        keyRunCounter = 0;
    }
    if (keyRunCounter > TIME_3S)
    {
        keyRunCounter = 0;
        STATUS = CHARGE_ST;
    }
    //運行狀態,信號消失1ms關機
    if ((STATUS == CHARGE_ST) || (STATUS == DELAY_ST) || (STATUS == CAPCHARGE)  )&& (keyRun == 0)
    {
        keyShutDownCounter++;
    }
    else
    {
        keyShutDownCounter = 0;
    }
    if (keyShutDownCounter > TIME_3S)
    {
        keyShutDownCounter = 0;
        STATUS = READY_ST;
    }
   
    /*母線大電容充電2秒,開始工作*/
    if (STATUS == CAPCHARGE)  
    {
        if  (capChargeCounter < TIME_2S)
        {
            capChargeCounter++;
        }
        else
        {
            capChargeCounter = 0;
            STATUS = CHARGE_ST;
        }
    }
    //delay狀態,1ms后使能檢測
    if ((STATUS == DELAY_ST) ) //&& (ADS < U500) delay 之后1ms再次檢測,不夠再加,夠了就再次進入delay
    {
        delaySTCounter++;
    }
    else
    {
        delaySTCounter = 0;
    }
    if (delaySTCounter > TIME_2MS)
    {
        delaySTCounter = 0;
        STATUS = CHARGE_ST;
    }
}

評分

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

查看全部評分

回復

使用道具 舉報

16#
ID:1042937 發表于 2022-8-27 15:48 | 只看該作者
有時間研究一下
回復

使用道具 舉報

17#
ID:476058 發表于 2022-10-15 22:33 | 只看該作者
共同學習,共同進步,向大佬學習!
回復

使用道具 舉報

18#
ID:681572 發表于 2023-4-14 09:17 | 只看該作者
請問這個是用keil4還是keil5建立的工程啊??建立工程時選擇哪個器件啊?為什么我的keil4 C51里面沒有這個stc8g1k08a器件???
回復

使用道具 舉報

19#
ID:1110792 發表于 2024-9-13 22:12 | 只看該作者
厲害,有器件,但不知道能不能弄成,學習了。
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 粉嫩一区二区三区性色av | 二区av| 日韩欧美网| 男女羞羞视频免费 | 美女精品一区 | 日韩av网址在线观看 | 日韩视频中文字幕 | 91大神在线看 | 精品国产一区二区三区性色 | 日韩欧美中文在线 | 精品福利在线 | 国产精品久久久久久久久久久久久 | 日韩三区在线 | 999热精品视频 | 亚洲香蕉在线视频 | av网站在线播放 | 在线观看免费av网站 | 日本二区 | 国产成人高清视频 | 精品无码久久久久久国产 | 一级片在线观看 | 国产伊人精品 | 日韩美女在线看免费观看 | 一区二区免费 | 久久精品久久久久久 | www日韩欧美| 高清黄色 | 亚洲欧美视频一区 | 久久久久九九九女人毛片 | 亚洲精品日韩在线 | 久久精品国产一区 | 国产欧美一区二区三区在线看 | 久久国产精品一区二区三区 | 亚洲人va欧美va人人爽 | 欧美视频在线看 | 久久久久久久国产 | 欧美在线视频一区二区 | 在线日韩视频 | 久久国产精品视频 | 亚洲精品影院 | 欧美激情久久久 |