標(biāo)題: DS18B20采集數(shù)據(jù)失敗 [打印本頁]

作者: 百二秦關(guān)終屬我    時間: 2024-6-17 09:58
標(biāo)題: DS18B20采集數(shù)據(jù)失敗
主程序如下。目前數(shù)碼管顯示的數(shù)據(jù)是06666,這個是不正常的。這個程序是我仿照普中的DS18B20實驗來做的,預(yù)期是用DS18B20測溫,數(shù)碼管顯示數(shù)據(jù),保留一位小數(shù)。
目前顯示不正常,我首先是檢查DS18B20初始化是否有問題,所以我加了一個指示燈,發(fā)現(xiàn)初始化是沒有問題的。
所以說現(xiàn)在讓我疑惑的有兩點,第一點就是T_value = DS18B20_Read_T()*10;//保留一位小數(shù),
我覺得問題是出現(xiàn)在這里,因為這里
/*
                if(T_value < 0)
                {
                        T_value = - T_value;
                        temp_buf[0] = 0x40; //-
                }
                else
                {
                        temp_buf[0] = 0x00; //不顯示
                }
                */
我無論加不加注釋,數(shù)碼管要點亮的首位總是顯示0。我不知道為什么會這樣。
第二點是這一句temp_buf[3] = duan_table[T_value%1000%100/10]; //個位+小數(shù)點,加個小數(shù)點的話應(yīng)該寫成temp_buf[3] = duan_table[T_value%1000%100/10] | 0x80;(用的是共陰極數(shù)碼管),但是這樣寫的話,這一位完全不亮。
我非常疑惑,懇請諸位大神指點迷津。

#include <REGX51.H>
#include "Delay.h"
#include <intrins.h>
#include "Smg.h"
#include "DS18B20.H"
#include "LED.h"
extern duan_table[];
void main(void)
{
        uchar i = 0;
        int T_value;
        uchar temp_buf[5];
        uint DS18B20_OK = 0;
       
        DS18B20_OK = DS18B20_Init();//DS18B20初始化
        if(DS18B20_OK)
                LED_OFF();
        else
                LED_ON();
        while(1)
        {
                i++;
                if(i%50 == 0) //每隔一段時間讀取溫度值,間隔時間要大于溫度傳感器轉(zhuǎn)換時間
                        T_value = DS18B20_Read_T()*10;//保留一位小數(shù)
                /*
                if(T_value < 0)
                {
                        T_value = - T_value;
                        temp_buf[0] = 0x40; //-
                }
                else
                {
                        temp_buf[0] = 0x00; //不顯示
                }
                */
                temp_buf[1] = duan_table[T_value/1000];
                temp_buf[2] = duan_table[T_value%1000/100];
                temp_buf[3] = duan_table[T_value%1000%100/10]; //個位+小數(shù)點
                temp_buf[4] = duan_table[T_value%1000%100%10];
                smg_display(temp_buf, 4);

        }
}


51hei圖片_20240617095054.jpg (277.35 KB, 下載次數(shù): 7)

51hei圖片_20240617095054.jpg

04_51_DS18B20_V1.0.1.zip

78.33 KB, 下載次數(shù): 0

20-DS18B20溫度傳感器實驗.zip

22.56 KB, 下載次數(shù): 1


作者: cnos    時間: 2024-6-19 09:12
樓主可以先刷我的程序看看硬件有沒有問題,然后再排查。
http://www.torrancerestoration.com/bbs/dpj-235842-1.html
作者: 劉佑紅    時間: 2024-6-21 07:01
    以下四句可以簡化。
    temp_buf[1] = duan_table[T_value/1000];
    temp_buf[2] = duan_table[T_value%1000/100];
    temp_buf[3] = duan_table[T_value%1000%100/10]; //個位+小數(shù)點
    temp_buf[4] = duan_table[T_value%1000%100%10];
    簡化為:
     temp_buf[1] = duan_table[T_value/1000];
     temp_buf[2] = duan_table[T_value/100%10];
     temp_buf[3] = duan_table[T_value/10%10];
     temp_buf[4] = duan_table[T_value%10];
    簡化后代碼會減小,運行也會快些,畢竟除法求余數(shù)比較耗時。
作者: xiaobendan001    時間: 2024-6-21 08:58
劉佑紅 發(fā)表于 2024-6-21 07:01
以下四句可以簡化。
    temp_buf[1] = duan_table[T_value/1000];
    temp_buf[2] = duan_table[T_ ...
  1. for(j=4;j<255;j--){                          
  2.         temp_buf[j]=duan_table[T_value/%10];
  3.     T_value/=T_value//10;
  4.     }   
復(fù)制代碼

這樣是不是也行。
作者: xiaobendan001    時間: 2024-6-21 13:11
xiaobendan001 發(fā)表于 2024-6-21 08:58
這樣是不是也行。

代買里面怎么多了好幾個/?
作者: 名字不是重點    時間: 2024-6-21 15:14
xiaobendan001 發(fā)表于 2024-6-21 08:58
這樣是不是也行。

行不行試試就知道,但這行應(yīng)該是不行的
  1. T_value/=T_value//10;
復(fù)制代碼

作者: xiaobendan001    時間: 2024-6-21 15:25
名字不是重點 發(fā)表于 2024-6-21 15:14
行不行試試就知道,但這行應(yīng)該是不行的

很奇怪復(fù)制粘貼的居然多了好幾個/
作者: 劉佑紅    時間: 2024-6-21 16:55
xiaobendan001 發(fā)表于 2024-6-21 08:58
這樣是不是也行。

for(j=4;j<255;j--){                          
        temp_buf[j]=duan_table[T_value/%10];
    T_value/=T_value//10;
    }
以上幾行是不行的,首先 for循環(huán)函數(shù)內(nèi)j會始終小于255,不能跳出循環(huán)。另外temp_buf[j]=duan_table[T_value%10];    T_value=T_value/10;想得到什么結(jié)果?




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1