注册 登录
电子工程世界-论坛 返回首页 EEWORLD首页 频道 EE大学堂 下载中心 Datasheet 专题
ninicaoyuan的个人空间 https://home.eeworld.com.cn/space-uid-545317.html [收藏] [复制] [分享] [RSS]
日志

HR202L 测试湿度,stm32

已有 1805 次阅读2016-6-30 16:54 |个人分类:stm32

请大家指正
uint8_t en_tnSRHCharge = 0;
uint8_t cnt_charge = 0;
uint16_t tn_discharge = 0;//s
uint32_t tn_charge  = 0;
uint16_t tn_srhwait = 0;
float res_hr;
uint32_t time_high = 0;
uint32_t time_test = 0;
//uint32_t com_res = 0;       
uint32_t tn_refcharge = 0;
uint32_t tn_hrcharge = 0;
void  Humidity_tntest(void)
{
        //放电
        Set_SRH_Charge(0);
        Set_SRH_R_Charge(0);
        Set_SRH_IOtest(0);//output

        GPIO_ResetBits(SRH_Charge);//
        GPIO_ResetBits(SRH_R_Charge);//
        Set_SRH_IOtest(0);//output
        GPIO_ResetBits(SRH_IOtest);
        tn_discharge = 40;//延时10ms
        while(tn_discharge);

        //标准电阻充电
        Set_SRH_Charge(1);
        Set_SRH_R_Charge(0);
        Set_SRH_IOtest(1);//比较器口
        en_tnSRHCharge = 1; //使能PWM,充电
        GPIO_SetBits(SRH_R_Charge);
        cnt_charge = 0;
        time_high = 0;
        tn_charge = 0;
        TIM_SetCounter(TIM1,0);
        while( !COMP_GetOutputLevel(COMP_Selection_COMP1));

        tn_charge =  TIM_GetCounter(TIM1);

        en_tnSRHCharge = 0;
        tn_refcharge = tn_charge;
        tn_charge = 0;

        //放电
        Set_SRH_Charge(0);
        Set_SRH_R_Charge(0);
        Set_SRH_IOtest(0);//output

        GPIO_ResetBits(SRH_Charge);//
        GPIO_ResetBits(SRH_R_Charge);//
        Set_SRH_IOtest(0);//output
        GPIO_ResetBits(SRH_IOtest);
        tn_discharge = 40;//延时10ms
        while(tn_discharge);

        //hr202l充电
        Set_SRH_Charge(0);
        Set_SRH_R_Charge(1);
        Set_SRH_IOtest(1);//比较器口
        en_tnSRHCharge = 1; //使能PWM,充电
        GPIO_SetBits(SRH_Charge);
        cnt_charge = 0x80;
        time_high = 0;
        tn_charge = 0;
        TIM_SetCounter(TIM1,0);
        while( !COMP_GetOutputLevel(COMP_Selection_COMP1)) ;

        tn_charge =  TIM_GetCounter(TIM1);
        en_tnSRHCharge = 0;
        tn_hrcharge = tn_charge;
        tn_charge = 0;

        //计算电阻,10K电阻
        res_hr = 10 * 1000 * (float)tn_hrcharge / tn_refcharge;
        if(res_hr>99000)
        res_hr = 0.803*res_hr+5.298 ;
        res2humidity(res_hr);
}
void TIM2_IRQHandler(void)
{
        if(TIM_GetFlagStatus(TIM2, TIM_IT_Update))
        {
                TIM_ClearFlag(TIM2, TIM_IT_Update);
                if(en_tnSRHCharge)
                {
                        cnt_charge++;
                        if(cnt_charge & 0x80)
                        {
                                if(cnt_charge >= 0x86) //0x84
                                {
                                        GPIO_ResetBits(SRH_Charge);
                                        cnt_charge = 0x80;
                                }
                                else if(cnt_charge >= 0x81)
                                {
                                        GPIO_SetBits(SRH_Charge);
                                }
                        }
                        else
                        {
                                if(cnt_charge == 0x01)
                                {
                                        GPIO_SetBits(SRH_R_Charge);
                                }
                                else if(cnt_charge == 0x06) //4
                                {
                                        GPIO_ResetBits(SRH_R_Charge);
                                        cnt_charge = 0x00;
                                }
                        }
                if(tn_discharge)tn_discharge--;
        }
}

本文来自论坛,点击查看完整帖子内容。

评论 (0 个评论)

facelist doodle 涂鸦板

您需要登录后才可以评论 登录 | 注册

热门文章