⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 18b20_42bygh.c

📁 里面包含了多个C语言模块设计题目
💻 C
字号:
#include<reg52.h>
#define uint unsigned int
uint led[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uint ledp[4]={0xbf,0x86,0xdb,0xcf};
uint vote[8]={0x01,0x03,0x02,0x06,0x04,0x0C,0x08,0x09};
uint step_index,
  stop_flag =0;
  int   spcount;
void gorun();
bit turn;

uint k,ledk,j,num,w,numi,wp,wn,pp,count;
sbit led0=P1^0;
sbit led1=P1^1;
sbit led2=P1^2;
sbit led3=P1^3;
float sum,tempn,nump,ppnum;

sbit TMDAT =P3^1; //DS18B20 的数据输入/输出脚DQ,根据情况设定
unsigned int sdata;//测量到的温度的整数部分
unsigned char xiaoshu1;//小数第一位
unsigned char xiaoshu2;//小数第二位
float xiaoshu;//两位小数
bit fg=1; //温度正负标志



 void dmsec(uint n)        /*定时中断延时*/
  { 
     count=0;
     while(1)
     { 
      if(count>=n)
      break;
     }   
  }

void tmreset (void) //发送复位
{
unsigned char i;
TMDAT=0; for(i=0;i<103;i++);
TMDAT = 1; for(i=0;i<4;i++);
}


bit tmrbit (void) //读一位//
{
unsigned int i;
bit dat;
TMDAT = 0;
i++;
TMDAT = 1;
i++; i++; //微量延时//
dat = TMDAT;
for(i=0;i<8;i++);
return (dat);
}


unsigned char tmrbyte (void) //读一个字节
{
unsigned char i,j,dat;
dat = 0;
for (i=1;i<=8;i++)
{ j = tmrbit(); dat = (j << 7) | (dat >> 1); }
return (dat);
}



void tmwbyte(unsigned char dat) //写一个字节
{
unsigned char j,i;
bit testb;
for (j=1;j<=8;j++)
{ testb = dat & 0x01;
dat = dat >> 1;
if (testb)
{ TMDAT = 0; //写0
i++; i++;
TMDAT = 1;
for(i=0;i<8;i++); }
else
{ TMDAT = 0; //写0
for(i=0;i<8;i++);
TMDAT = 1;
i++; i++;}
}
}

void tmstart (void) //发送ds1820 开始转换
{ tmreset(); //复位
dmsec(3); //延时                      
tmwbyte(0xcc); //跳过序列号命令
tmwbyte(0x44); //发转换命令44H,
}


void tmrtemp (void) //读取温度
{
unsigned char a,b;
tmreset (); //复位
dmsec (3); //延时
tmwbyte (0xcc); //跳过序列号命令
tmwbyte (0xbe); //发送读取命令
a = tmrbyte (); //读取低位温度
b = tmrbyte (); //读取高位温度
if(b>0x7f) //最高位为1 时温度是负
{a=~a; b=~b+1; //补码转换,取反加一
fg=0; //读取温度为负时fg=0
}

sdata= a/16+b*16; //整数部分
xiaoshu1 = (a&0x0f)*10/16; //小数第一位
xiaoshu2 = (a&0x0f)*100/16%10;//小数第二位
xiaoshu=xiaoshu1*10+xiaoshu2; //小数两位
sum=sdata+xiaoshu/100;
}


void DS18B20PRO(void)
{ tmstart();
        //dmsec(5); //如果是不断地读取的话可以不延时//
  tmrtemp(); //读取温度,执行完毕温度将存于TMP 中//
   
    numi=(uint)sum;      /*开始算位 ,这也是看是否需要*/
    nump=sum-numi;
    wn=1;
    for(j=1;j<4;j++)
      {     
	   if(numi>0)
	     {wn=j; numi=numi/10;}
	   else break;
	  }
      for(j=0;j<3;j++)
      {
      if(nump>0)
      {nump=nump*10;      
        wp=j+1;
	    nump=nump-(uint)nump;
	   }	  
	    else break;
	  }   

	 w=wn+wp;
	 if(w>4)
	 {
	  wp=4-wn;
	  w=4;
	  }
      tempn=sum;
      for(j=0;j<wp;j++)     
      tempn=tempn*10;
	  num=(uint)tempn;
}



void ledwork()
{
if(fg==1) //温度为正时显示的数据
{
if(ledk==0) {led1=1;led2=1; led3=1;led0=0;   P0=led[num%10];}

  else if(ledk==1&&w>=2) {if(wp==1)  P0=ledp[num/10%10];   else P0=led[num/10%10];  
       led2=1; led3=1; led0=1;led1=0;} 

  else if(ledk==2&&w>=3) {if(wp==2)  P0=ledp[num/100%10];  else P0=led[num/100%10];  
       led1=1;led3=1;led2=0;}

  else if(ledk==3&&w>=4) {if(wp==3)  P0=ledp[num/1000%10];	else P0=led[num/1000%10]; 
        led2=1; led1=1; led0=1; led3=0;}
}

if(fg==0) //温度为负时显示的数据
{ P2=P2&0xef;
P0=led[11]; //负号
}
}
main()
{
  EA=1;	
    ET0=1;
    TH0=0xf1;          /*设置初始值,每隔4ms一次中断*/
    TL0=0x90;
	TR0=1;
    fg=1;
	turn=0;
	spcount=0;
  while(1)
   {
  if(k>=300)
   { k=0;
     DS18B20PRO();
   }
   if(sum>32) turn=1;
      else turn=0;
	    
}
}
void time0(void) interrupt 1
{
  TH0=0xCF;
  TL0=0x0C;   //设定时每隔0.5ms中断一次
    k++;
    ledk++;
	count++;
    ledk=ledk%w;
    ledwork();

	  spcount--;
      if(spcount<=0)
	 {
	   spcount=2;
       gorun(); } 
}




void gorun()
{ 
  if(stop_flag==1)
  {    
    P2=0x00;
    return;
  }

  P2=vote[step_index];  //给脉冲以驱动电机

  if(turn==0)
  {
    step_index++;
    if (step_index>7)
      step_index=0;
  }
  else
  {
    step_index--;
    if (step_index<0)
      step_index=7;
  }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -