程序功能:检测DS18B20并显示数码管上;奈何数码管一直显示A959;
晶振12 ;问题好像初始化不成功求大佬解答
#include<STC8.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
#define FOSC 12000000L
sbit w1=P1^0;
sbit w2=P1^1;
sbit w3=P1^2;
sbit w4=P1^3;//数码管位选
sbit k1=P1^4;
sbit k2=P1^5;
sbit k3=P1^6;
sbit k4=P1^7;
sbit DS=P5^4;数据口
sbit g=P5^5;
//define interface
uint temp; // variable of temperature
uchar flag1; // sign of the result positive or negative
uchar code SM[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
uchar code SM5[]={
0xbf,0x86,0xdb,0xcf,
0xe6,0xed,0xfd,0x87,
0xff,0xef,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void nb(uint z) //??
{
uint x,y;
x=z;
for(x;x>0;x--)
for(y=110;y>0;y--);
}
void delay(uint count) //delay
{
uint i;
while(count)
{
i=200;
while(i>0)
i--;
count--;
}
}
void dsreset(void) //send reset and initialization command
{
uint i;
DS=0;
i=103;
while(i>0)i--;
DS=1;
i=4;
while(i>0)i--;
}
bit tmpreadbit(void) //read a bit
{
uint i;
bit dat;
DS=0;i++; //i++ for delay
DS=1;i++;i++;
dat=DS;
i=8;while(i>0)i--;
return (dat);
}
uchar tmpread(void) //read a byte date
{
uchar i,j,dat;
dat=0;
for(i=1;i<=8;i++)
{
j=tmpreadbit();
dat=(j<<7)|(dat>>1);
}
return(dat);
}
void tmpwritebyte(uchar dat) //write a byte to ds18b20
{
uint i;
uchar j;
bit testb;
for(j=1;j<=8;j++)
{
testb=dat&0x01;
dat=dat>>1;
if(testb) //write 1
{
DS=0;
i++;i++;
DS=1;
i=8;while(i>0)i--;
}
else
{
DS=0; //write 0
i=8;while(i>0)i--;
DS=1;
i++;i++;
}
}
}
void tmpchange(void) //DS18B20 begin change
{
dsreset();
delay(1);
tmpwritebyte(0xcc); // address all drivers on bus
tmpwritebyte(0x44); // initiates a single temperature conversion
}
uint tmp() //get the temperature
{
float tt;
uchar a,b;
dsreset();
delay(1);
tmpwritebyte(0xcc);
tmpwritebyte(0xbe);
a=tmpread();
b=tmpread();
temp=b;
temp<<=8; //two byte compose a int variable
temp=temp|a;
tt=temp*0.0625;
temp=tt*10+0.5;
return temp;
}
void display(uint temp) //ÏÔʾ³ÌÐò
{
uchar A1,A2,A2t,A3;
A1=temp%10;
A2=temp/10%10;
A3=temp/100%10;
w1=0;
P3=SM[A1];
nb(50);
w1=1;
w2=0;
P3=SM[A2];
nb(50);
w2=1;
w3=0;
P3=SM[A3];
nb(50);
w3=1;
w4=0;
P3=0x77;nb(50);
w4=1;
}
void main()
{
uchar a;
tmpchange();
display(tmp());
while(1)
{tmpchange();
display(tmp());
}
}
|