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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4270|回復: 0
收起左側

第七屆藍橋杯_溫度記錄器 單片機源程序

[復制鏈接]
ID:438858 發表于 2019-5-26 21:52 | 顯示全部樓層 |閱讀模式
自己寫的,用的是德飛萊的開發板。 4PZAH3Z5BE9W@D~%L2Q~NY5.png
)9~SWS_A2%`X}QU`@_X$}3V.png

單片機源程序如下:
  1. #include <reg52.h>
  2. #include "delay.h"
  3. #include "ds1302.h"
  4. #include"display.h"
  5. #include"18b20.h"
  6. #include"keyboard.h"

  7. extern bit ReadTimeFlag;//定義讀時間標志
  8. extern bit ReadFlag;        //讀時間標志位 “1s”
  9. sbit led = P1^1;                //led定義
  10. extern bit ReadTempFlag;//定義讀溫度標志
  11. extern unsigned char dofly_DuanMa[10];
  12. extern unsigned char dofly_WeiMa[8];
  13. extern unsigned char TempData[9]; //存儲顯示值的全局變量
  14. unsigned int temps[10];                //用來存放采集到的溫度
  15. void model_1 ();                        //模式一間隔時間選擇
  16. void model_2 ();                        //模式二時鐘顯示


  17. unsigned char out = 1;                //用來累計采取時間的
  18. unsigned char s = 1;                //時間間隔的選擇位
  19. bit m,a,y,w,z,k;

  20. void main()
  21. {
  22.                 unsigned char key,temp_1,j;                        //按鍵,數組的變量
  23.                 unsigned int TempH,TempL,temp;                //溫度的轉換
  24.                 static unsigned char time = 0;
  25.                 Init_Timer0();                                                //定時器0的初始化
  26.                 Ds1302_Init();                                                //時鐘的初始化
  27.                 Ds1302_Write_Time();                                //重新寫入
  28.                 while(1)
  29.                 {
  30.                         key = KeyScan();                        //鍵盤掃面
  31.                         if(key == 4 && m == 0)                //key4、key7按下,進入選擇時間間隔
  32.                                 {
  33.                                         z = 1;                        //表示key4和key7不同的模式
  34.                                         model_1 ();                //時間間隔
  35.                                         s++;                        
  36.                                         if(s == 4)                //時間間隔的四種選擇
  37.                                                 s = 0;               
  38.                                 }        
  39.                         if(key == 5)                        //確認采集間隔時間
  40.                                         m = 1;
  41.                         if(m == 1 && ReadTimeFlag && k == 0)
  42.                                 {
  43.                                         ReadTimeFlag=0;
  44.                                         Ds1302_Read_Time();
  45.                                         model_2 ();                                //顯示時鐘
  46.                                         if(ReadTempFlag == 1)        //讀取溫度標志位
  47.                                         {
  48.                                                 ReadTempFlag = 0;
  49.                                                 time++;
  50.                                                 if(out == time)        //到達指定采集間隔
  51.                                                         {
  52.                                                                 time = 0;
  53.                                                                 temp=ReadTemperature();                //讀取溫度
  54.                                                                 if(j<10 || (out == time))                //每一次到達指定時間讀取,不是一次到達讀取十次
  55.                                                                 {
  56.                                                                         temps[j++] = temp;                        //依次存入數組中
  57.                                                                         if(j == 10)
  58.                                                                                 {
  59.                                                                                         j = 0;
  60.                                                                                         led = 0;                        //溫度采集完點亮led
  61.                                                                                 }
  62.                                                                 }        
  63.                                                          }
  64.                                          }                                                
  65.                                 }
  66.                         if(led == 0)
  67.                                 k = 1;                        //k表示key = 6的情況
  68.                         if(key == 6 && k == 1)
  69.                         {
  70.                                 led = 1;               
  71.                                 m = 0;
  72.                                 z = 0;
  73.                                 if(temp_1 < 10)
  74.                                 {
  75.                                         temp_1++;
  76.                                         if(temp_1 == 9)
  77.                                                 y = 1;
  78.                                 }
  79.                         }
  80.                         if(k == 1)                        //依次顯示索引和采集的溫度
  81.                         {
  82.                                 if(temp_1<10)
  83.                                 {
  84.                                         TempData[0] = 0x40;
  85.                                         TempData[1] = dofly_DuanMa[(temp_1)/10];                //索引
  86.                                         TempData[2] = dofly_DuanMa[(temp_1)%10];
  87.                                         TempH=temps[temp_1]>>4;
  88.                                         TempL=temps[temp_1]&0x0F;
  89.                                         TempL=TempL*5/10;//小數近似處理
  90.                                         TempData[5]=0x40;
  91.                                         TempData[6]=dofly_DuanMa[(TempH%100)/10]; //十位溫度
  92.                                         TempData[7]=dofly_DuanMa[(TempH%100)%10]; //個位溫度,帶小數點
  93.                                         TempData[3] = 0;
  94.                                         TempData[4] = 0;
  95.                                 }
  96.                         }
  97.                         if(key == 7 && y == 1 && z == 0)                //進入參數設置界面,進行下一次的溫度采集工作
  98.                                 {
  99.                                         TempData[0]=0;                        //固定顯示
  100.                                         TempData[1]=0;
  101.                                         TempData[2]=0;
  102.                                         TempData[3]=0;
  103.                                         TempData[4]=0;
  104.                                         TempData[5]=0x40;
  105.                                         TempData[6]=dofly_DuanMa[0];
  106.                                         TempData[7]=dofly_DuanMa[1];
  107.                                         k = 0;
  108.                                         y = 0;
  109.                                         s = 1;
  110.                                         temp_1 = 0;
  111.                                 }
  112.                 }
  113. }
  114. void model_1 ()                        //模式一間隔時間選擇
  115. {
  116.                                 
  117.                                 TempData[0]=0;                        //固定顯示
  118.                                 TempData[1]=0;
  119.                                 TempData[2]=0;
  120.                                 TempData[3]=0;
  121.                                 TempData[4]=0;
  122.                                 TempData[5]=0x40;
  123.                                 switch(s)
  124.                                 {
  125.                                  case 1:
  126.                                          TempData[6]=dofly_DuanMa[0];
  127.                                          TempData[7]=dofly_DuanMa[5];
  128.                                          out = 5;
  129.                                  break;
  130.                                  case 2:
  131.                                          TempData[6]=dofly_DuanMa[3];
  132.                                          TempData[7]=dofly_DuanMa[0];
  133.                                          out = 30;
  134.                                  break;
  135.                                  case 3:
  136.                                          TempData[6]=dofly_DuanMa[6];//秒
  137.                                          TempData[7]=dofly_DuanMa[0];
  138.                                          out = 60;
  139.                                  break;
  140.                                  case 0:
  141.                                          TempData[6]=dofly_DuanMa[0];
  142.                                          TempData[7]=dofly_DuanMa[1];
  143.                                          out = 1;
  144.                                  break;
  145.                                 }
  146. }        


  147.         /*------------------------------------------------
  148.            讀取1302的值        默認 RTC 時間: 23 時 59 分 50 秒
  149.                 模式二 :時鐘顯示
  150.         ------------------------------------------------*/
  151. void model_2 ()                                
  152. {
  153.                 TempData[0]=dofly_DuanMa[time_buf1[0]/10];//時        //數據的轉換,
  154.                 TempData[1]=dofly_DuanMa[time_buf1[0]%10];//因我們采用數碼管0~9的顯示,將數據分開
  155.                 if(ReadFlag)
  156.                         TempData[2]=0x40;                                                            //加入"-"
  157.                 else
  158.                         TempData[2] = 0;
  159.                 TempData[3]=dofly_DuanMa[time_buf1[1]/10];//分
  160.                 TempData[4]=dofly_DuanMa[time_buf1[1]%10];
  161.                 if(ReadFlag)
  162.                                 TempData[5]=0x40;
  163.                 else
  164.                         TempData[5] = 0;
  165.                         ReadFlag = 0;
  166.                 TempData[6]=dofly_DuanMa[time_buf1[2]/10];//秒
  167.                 TempData[7]=dofly_DuanMa[time_buf1[2]%10];        
  168. }
復制代碼

所有資料51hei提供下載:
溫度記錄器.zip (64.09 KB, 下載次數: 43)

評分

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

查看全部評分

回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲网站在线 | 99热播精品 | 在线啊v | 欧美激情精品久久久久久免费 | 成人美女免费网站视频 | 91精品国产综合久久精品 | 久久亚洲综合 | 久久大| 欧美日韩免费在线 | 日韩靠逼| 国产精品成人国产乱 | 亚洲国产精品一区二区www | 国产九一精品 | 综合久久久 | 999免费视频 | 欧美日日 | 欧美久久一区二区 | 国产欧美日韩一区二区三区 | 草草视频在线免费观看 | 日本精品一区二区 | 福利社午夜影院 | 国产精品久久久久久久久久久久午夜片 | 视频一区 亚洲 | 91一区二区三区 | 91精品国产综合久久久久久 | 国产精品日日摸夜夜添夜夜av | 午夜精品久久久久久久久久久久久 | 久久一级 | 亚洲一区二区三区免费在线 | 日韩欧美精品一区 | 日韩一二区| 在线视频99 | 国产精品伦一区二区三级视频 | 亚洲美女网站 | 国产高清久久久 | 国产亚洲一区二区精品 | 亚洲三区在线播放 | 免费视频一区二区 | 国产精品美女久久久久aⅴ国产馆 | 人人干在线视频 | 天天综合永久入口 |