- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
温度时钟计程序
温度时钟计程序
#includereg52.h
#define uint unsigned int
#define uchar unsigned char
/////////////////
sbit rs = P2^4;// 1602 IO口位定义
sbit rw = P2^3;//
sbit en = P2^2;//
/////////////////
///////////////////
sbit sclk = P0^0;// 1302 IO口位定义
sbit io = P0^1; //
sbit rst = P0^2;
///////////////////
///////////////////
sbit key1 = P3^0;//
sbit key2 = P3^1;// 独立按键位定义
sbit key3 = P3^2;//
sbit key4 = P3^3;//
///////////////////
sbit P20=P2^0;
sbit P21=P2^1;
sbit P35=P3^5;
///////////////////
sbit DQ = P3^3;////
///////////////////
uchar tempL=0; //临时变量低位
uchar tempH=0; //临时变量高位
uint temperature;
uint hour, minute, second, year, month, day;
uint key = 0;
uchar tab_num[] = {0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39,0x3a,0x2d}; //对应字符为: { 0 1 2 3 4 5 6 7 8 9 : - }
uchar tab_time[] = {1,2,10,3,4,10,5,6};
uchar tab_date[] = {2,0,1,0,11,0,9,11,2,7};
// 延时函数,延时z毫秒 ******
void delay(uint z)
{
uint x, y;
for(x=0;xz;x++)
for(y=0;y110;y++);
}
//***************************
/****************************************************************************
函数功能:延时子程序
入口参数:k
出口参数:
****************************************************************************/
void delay18b20(unsigned int k)
{
unsigned int n;
n=0;
while(n k)
{n++;}
return;
}
/****************************************************************************
函数功能:DS18B20初始化子程序
入口参数:
出口参数:
****************************************************************************/
Init_DS18B20(void)
{
unsigned char x=0;
DQ=1; //DQ先置高
delay18b20(8); //延时
DQ=0; //发送复位脉冲
delay18b20(85); //延时(480ms)
DQ=1; //拉高数据线
delay18b20(14); //等待(15~60ms)
}
/****************************************************************************
函数功能:向DS18B20读一字节数据
入口参数:
出口参数:dat
****************************************************************************/
ReadOneChar(void)
{
unsigned char i=0;
unsigned char dat=0;
for (i=8;i0;i--)
{
DQ=1;
delay18b20(1);
DQ=0;
dat=1;
DQ=1;
if(DQ)
dat|=
文档评论(0)