使用数码管显示DHT22传感器数据时无法正常读数据

2019-07-21 05:56发布

本帖最后由 q247341184 于 2017-8-23 20:40 编辑

基于原子哥的dht11例程修改代码,经测试没有错误和异常。移植数码管显示模块后也无异常,当在主函数读取温度模块后加入显示函数后,数据读取出现异常。无法正确读数,是指的从传感器传出来的数据是错的,用XCOM监控,用printf函数取值得到,具体如下面主函数部分。一开始推测是管脚冲突,经仔细检查后,排除管脚冲突原因。两个部分独立运行时是完好的,也排除代码异常问题。望指点一下思路, 还有什么原因可能导致这种情况的发生?
主函数的运行部分:
[mw_shl_code=c,true]        
        while(1)
        {               
    if(t%10==0)                        //每100ms读取一次
                {                          
                        DHT22_Read_Data(&temperature,&humidity); //读取温湿度值                                            
                        printf("temp=%d!",temperature);    //显示温度                              
                        printf("humidi=%d!",humidity);                   //显示湿度
        DisPlayNum(temperature);  //加入此行后数据读取异常
                }                                   
                 delay_ms(200);
                t++;
        }        [/mw_shl_code]


显示函数:
[mw_shl_code=c,true]void DisPlayNum(int n)  
{  
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);                                //使能AFIO时钟
                                                                                                                                                                                                                                                //由于PB4的功能就是GPIO,所以没有使能功能时钟
        GPIO_PinRemapConfig(GPIO_Remap_SWJ_NoJTRST,ENABLE);                                //关闭JTRST,即开启重映射
   
        for (i=0;i<4;i++)  
        {  
            GPIO_ResetBits(GPIOB,GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7|                                                        //PB4-PB7是位选口
                                                                                                                                        GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11|                                                        //PB8-PB15是段选口
                                                                                                                                        GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15 );  
                                switch (i)                                                                                                                                                                          //位选数,,分别对应左数1、2、3、4
                                {  
                                                case 0:  
                                                                                        GPIO_SetBits(GPIOB,GPIO_Pin_7);  
                                                                                        break;  
                                                case 1:  
                                                                                        GPIO_SetBits(GPIOB,GPIO_Pin_6);  
                                                                                        break;  
                                                case 2:                  
                                                                                        GPIO_SetBits(GPIOB,GPIO_Pin_5);
                                                                                        break;  
                                                case 3:  
                                                                                        GPIO_SetBits(GPIOB,GPIO_Pin_4);
                                                                                        break;  
        }
                             
            
                                switch (a%10)                        //输出示数
            {  
                case 0:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_14|GPIO_Pin_15);                                                                                                                                                                                           // 0
                    break;  
                case 1:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15); // 1
                    break;  
                case 2:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_10|GPIO_Pin_13|GPIO_Pin_15);                                                                                                                                          // 2
                    break;  
                case 3:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_15);                                                                                                                                          // 3
                    break;  
                case 4:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_15);                                                                                                  // 4
                    break;  
                case 5:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_15);                                                                                                                                                  // 5
                    break;  
                case 6:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_15);                                                                                                                                                                                                  // 6
                    break;  
                case 7:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15);                                          // 7
                    break;  
                case 8:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_15);                                                                                                                                                                                                                                          // 8
                    break;  
                case 9:  
                    GPIO_SetBits(GPIOB,GPIO_Pin_12|GPIO_Pin_15);                                                                                                                                                                                          // 9
                    break;  
                                                                case 10:
                                                                                GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11|                                                                                        //负号
                                                                                                                                        GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_15 );
                                                                                break;
                                                                case 11:
                                                                                GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11|                                                        //null
                                                                                                                                        GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15 );
                                                                                break;
            }     
            s = s / 10;  //此行放输出逻辑。
                                                delay_ms(1);  
        }      [/mw_shl_code]


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
10条回答
q247341184
1楼-- · 2019-07-21 11:54
 精彩回答 2  元偷偷看……
q247341184
2楼-- · 2019-07-21 15:49
自顶一下
正点原子
3楼-- · 2019-07-21 21:36
仿真,看时序,分析问题
q247341184
4楼-- · 2019-07-21 23:52
本帖最后由 q247341184 于 2017-8-24 10:36 编辑
正点原子 发表于 2017-8-24 00:36
仿真,看时序,分析问题

原子哥,我想分为三点继续这个问题;
1、我曾经试过仿真,没有得到该有的现象,正常的现象应该是主机发送一段1·10ms的低电平后拉高,然后传感器发出相应拉低80us再拉高以示即将传输数据。可是现实情况是主机周期性拉低至少18ms再拉高都没有响应。我个人分析出现这种现象应该是没有问题的,因为我认为软件仿真本身就无法连接传感器,所以周期性拉低电平再拉高是我目前认为的正常现象。

2、因为之前的时候我也认为有可能是时序问题,所以我做过一个可能不太靠谱的测试,就是将主函数代码中的Display函数替换成一个for循环的空循环,循环200000次,软件仿真时设置晶振是8MHz,折合时间约0.025秒,我认为足够长到干扰时序逻辑了。用for循环替换Display函数的现象是可以正常读数,没有问题。但是切换回Display函数就无法正确读数。

以上是我对这个问题做过的尝试和自己的理解,如果哪里有错误是我没有注意到的或者我理解错的等等,还请批评指正,指点思路。非常感谢。
以下是仿真测试的图:
追晨沐阳0311
5楼-- · 2019-07-22 03:57
源代码可以借鉴一下吗
q247341184
6楼-- · 2019-07-22 06:03
 精彩回答 2  元偷偷看……

一周热门 更多>