微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 基于51单片机运用LCD12864液晶显示

基于51单片机运用LCD12864液晶显示

时间:11-22 来源:互联网 点击:

{

case TEMP : error+=s_write_byte(MEASURE_TEMP); break; //测量温度

case HUMI : error+=s_write_byte(MEASURE_HUMI); break; //测量湿度

default : break;

}

for (i=0;i<65535;i++) if(DATA==0) break; //等待测量结束

if(DATA) error+=1; // 如果长时间数据线没有拉低,说明测量错误

*(p_value) =s_read_byte(ACK); //读第一个字节,高字节 (MSB)

*(p_value+1)=s_read_byte(ACK); //读第二个字节,低字节 (LSB)

*p_checksum =s_read_byte(noACK); //read CRC校验码

return error; // error=1 通讯错误

}

//温湿度值标度变换及温度补偿

void calc_sth10(float *p_humidity ,float *p_temperature)

{

const float C1=-4.0; // 12位湿度精度 修正公式

const float C2=+0.0405; // 12位湿度精度修正公式

const float C3=-0.0000028; // 12位湿度精度修正公式

const float T1=+0.01; // 14位温度精度 5V条件 修正公式

const float T2=+0.00008; // 14位温度精度 5V条件 修正公式

float rh=*p_humidity; // rh: 12位 湿度

float t=*p_temperature; // t: 14位温度

float rh_lin; // rh_lin: 湿度 linear值

float rh_true; // rh_true: 湿度 ture值

float t_C; // t_C : 温度 ℃

t_C=t*0.01 - 40; //补偿温度

rh_lin=C3*rh*rh + C2*rh + C1; //相对湿度非线性补偿

rh_true=(t_C-25)*(T1+T2*rh)+rh_lin; //相对湿度对于温度依赖性补偿

if(rh_true>100)rh_true=100; //湿度最大修正

if(rh_true<0.1)rh_true=0.1; //湿度最小修正

*p_temperature=t_C; //返回温度结果

*p_humidity=rh_true; //返回湿度结果

}

void main(void)

{

unsigned int temp,humi;

value humi_val,temp_val; //定义两个共同体,一个用于湿度,一个用于温度

unsigned char error; //用于检验是否出现错误

unsigned char checksum; //CRC

init12864lcd();

display1();

display2();

display3();

s_connectionreset(); //启动连接复位

while(1)

{

error=0; //初始化error=0,即没有错误

error+=s_measure((unsigned char*)&temp_val.i,&checksum,TEMP); //温度测量

error+=s_measure((unsigned char*)&humi_val.i,&checksum,HUMI); //湿度测量

if(error!=0) s_connectionreset(); ////如果发生错误,系统复位

else

{

humi_val.f=(float)humi_val.i; //转换为浮点数

temp_val.f=(float)temp_val.i; //转换为浮点数

calc_sth10(&humi_val.f,&temp_val.f); //修正相对湿度及温度

temp=temp_val.f*10;

humi=humi_val.f*10;

wendu[0]=temp/1000+0; //温度百位

wendu[1]=temp00/100+0; //温度十位

wendu[2]=temp0/10+0; //温度个位

wendu[3]=0x2E; //小数点

wendu[4]=temp+0; //温度小数点后第一位

displaywendu();

shidu[0]=humi/1000+0; //湿度百位

shidu[1]=humi00/100+0; //湿度十位

shidu[2]=humi0/10+0; //湿度个位

shidu[3]=0x2E; //小数点

shidu[4]=humi+0; //湿度小数点后第一位

displayshidu();

}

delay(800); //等待足够长的时间,以现行下一次转换

}

}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top