求C语言程序,单片机的。温度显示为0-100度的。谢谢! 四位共阳数码管的

作者&投稿:少善 (若有异议请与网页底部的电邮联系)
求AT89C51单片机和DS18B20温度程序,用四位共阳数码管显示~

//DS18B20的读写程序,数据脚P3.3 //
//温度传感器18B20汇编程序,采用器件默认的12位转化 //
//最大转化时间750微秒,显示温度-55到+125度,显示精度 //
//为0.1度,显示采用4位LED共阳显示测温值 //
//P0口为段码输入,P24~P27为位选 //
/***************************************************/

#include "reg51.h"
#include "intrins.h" //_nop_();延时函数用
#define Disdata P0 //段码输出口
#define discan P2 //扫描口
#define uchar unsigned char
#define uint unsigned int
sbit DQ=P3^3; //温度输入口
sbit DIN=P0^7; //LED小数点控制
sbit k5=P1^4;
uchar up_alarm=20;
uint h;
uchar flag;
//**************温度小数部分用查表法***********//
uchar code ditab[16]=
{0x00,0x01,0x01,0x02,0x03,0x03,0x04,0x04,0x05,0x06,0x06,0x07,0x08,0x08,0x09,0x09};
//
uchar code dis_7[12]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff,0xbf};
//共阳LED段码表 "0" "1" "2" "3" "4" "5" "6" "7" "8" "9" "不亮" "-"
uchar code scan_con[]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe}; //列扫描控制字
uchar data temp_data[2]={0x00,0x00}; //读出温度暂放
uchar data display[8]; //显示单元数据,共4个数据和一个运算暂用

//
//
//
/***********11微秒延时函数**********/
//
void ser_init()
{
TMOD=0X20;
SCON=0X50;
TH1=0XFD;
TL1=0XFD;
TR1=1;
}
void delay(uint t)
{
for(;t>0;t--);
}
//
/***********显示扫描函数**********/
scan()
{
char k;
for(k=0;k<7;k++) //四位LED扫描控制
{
//Disdata=0xff;
Disdata=dis_7[display[k]];
if(k==4){DIN=0;}
discan=scan_con[k];delay(200);
discan=0xff;
}
}
//
//
/***********18B20复位函数**********/
ow_reset(void)
{
char presence=1;
while(presence)
{
while(presence)
{
DQ=1;_nop_();_nop_();
DQ=0; //
delay(50); // 550us
DQ=1; //
delay(6); // 66us
presence=DQ; // presence=0继续下一步
}
delay(45); //延时500us
presence = ~DQ;
}
DQ=1;
}
//
//
/**********18B20写命令函数*********/
//向 1-WIRE 总线上写一个字节
void write_byte(uchar val)
{
uchar i;
for (i=8; i>0; i--) //
{
DQ=1;_nop_();_nop_();
DQ = 0;_nop_();_nop_();_nop_();_nop_();_nop_();//5us
DQ = val&0x01; //最低位移出
delay(6); //66us
val=val/2; //右移一位
}
DQ = 1;
delay(1);
}
//
/*********18B20读1个字节函数********/
//从总线上读取一个字节
uchar read_byte(void)
{
uchar i;
uchar value = 0;
for (i=8;i>0;i--)
{
DQ=1;_nop_();_nop_();
value>>=1;
DQ = 0; //
_nop_();_nop_();_nop_();_nop_(); //4us
DQ = 1;_nop_();_nop_();_nop_();_nop_(); //4us
if(DQ)value|=0x80;
delay(6); //66us
}
DQ=1;
return(value);
}
//
/***********读出温度函数**********/
//
read_temp()
{
ow_reset(); //总线复位
write_byte(0xCC); // 发Skip ROM命令
write_byte(0xBE); // 发读命令
temp_data[0]=read_byte(); //温度低8位
temp_data[1]=read_byte(); //温度高8位

ow_reset();
write_byte(0xCC); // Skip ROM

write_byte(0x44); // 发转换命令

}
//
/***********温度数据处理函数**********/
void work_temp()
{
uchar n=0,th=0,tl=0;
int temp=0;
uchar flag3=1,flag2=1; //数字显示修正标记
if((temp_data[1]&0xf8)!=0x00)
{
temp_data[1]=~(temp_data[1]);
temp_data[0]=~(temp_data[0])+1;
n=1;
flag=1;
}//负温度求补码
if(temp_data[0]>255)
{
temp_data[1]++;
}
tl=temp_data[0]&0x0f;
display[7]=tl;
if(display[7]&0x08)temp+=5000;
if(display[7]&0x04)temp+=2500;
if(display[7]&0x02)temp+=1250;
if(display[7]&0x01)temp+=625;
display[0]=temp%10;
display[1]=(temp%100)/10;
display[2]=(temp%1000)/100;
display[3]=temp/1000;
display[7]=((temp_data[0]&0xf0)>>4)|((temp_data[1]&0x07)<<4);
display[6]=display[7]/100;
display[5]=display[7]/10%10;
display[4]=display[7]%10;
if(!display[6])
{
display[6]=0x0a;
flag3=0;
if(!display[5])
{
display[5]=0x0a;
flag2=0;
}
}//最高位为0时都不显示
if(n)
{
display[6]=0x0b;//负温度时最高位显示"-"
flag3=0;
}

}

//
//
/**************主函数****************/
main()
{
ser_init();
Disdata=0xff; //初始化端口
discan=0xff;
for(h=0;h<4;h++){display[h]=8;}//开机显示8888
ow_reset(); // 开机先转换一次
write_byte(0xCC); // Skip ROM
write_byte(0x4e);
write_byte(0x02);
write_byte(0x01);
write_byte(0x7f);
write_byte(0x44); // 发转换命令
for(h=0;h<10;h++)
{scan();} //开机显示"8888"2秒
while(1)
{
if(!k5)
{
delay(2000);
if(!k5)
{
up_alarm++;
display[0]=up_alarm%10;
display[1]=up_alarm/10;
for(h=0;h<4;h++)
display[h+2]=0x0a;
for(h=0;h<30;h++)
scan();
}
}
read_temp(); //读出18B20温度数据
work_temp(); //处理温度数据

scan(); //显示温度值2秒
}
}
//
//*********************结束**************************//

#include
#include
#define uchar unsigned char
#define uint unsigned int

sbit DI = P1^0;
sbit CS = P1^1;
sbit CK = P1^2;
sbit IO = P1^3;
sbit RS = P1^4;
sbit LL = P1^5;
sbit LZ = P1^6;
sbit LH = P1^7;
sbit TK = P3^0;
sbit IG = P3^1;
sbit TF = P3^2;
sbit DQ = P3^3;
sbit UP = P3^4;
sbit DN = P3^5;
sbit TM = P3^7;
bit ng,np,fg;
bit buftm = 0,buftf = 0;

uchar data Disp[8];
uchar data CurrentT,CurrentB,Count1,Count2 = 3,Dot;
char data SignedT,SignedB = 35,gl;
uchar data glc = 0;

void nNop(uint x)
{
while(--x );
}

void IB_Device_Reset( void )
{
DQ = 1; nNop(8); DQ = 0; nNop(90); DQ = 1; nNop(8);
nNop(100); DQ = 1;
}

uchar ReadOneChar( void )
{
uchar i,d = 0;
DQ = 1; _nop_();
for (i = 0; i < 8; i++)
{
DQ = 0; d >>= 1; DQ = 1; _nop_(); _nop_();
if(DQ) d |= 0x80; nNop(30); DQ = 1;
}
return d;
}

void WriteOneChar( uchar dat )
{
uchar i;
for (i = 0; i < 8; i++)
{
DQ = 0; DQ = dat & 0x01; nNop(5); DQ = 1; dat>>=1;
}
}

void Readtemp( void ) reentrant
{
uchar data Temp_Value[2];
IB_Device_Reset();
WriteOneChar( 0xCC );
WriteOneChar( 0x44 );
nNop( 100 );
IB_Device_Reset();
WriteOneChar( 0xCC );
WriteOneChar( 0xBE );
Temp_Value[0] = ReadOneChar();
Temp_Value[1] = ReadOneChar();
/*********Output_Fubi*********/
ng = 0; //Clr Fubi
if( (Temp_Value[1] & 0xF8) == 0xF8)
{
Temp_Value[1] = ~Temp_Value[1];
Temp_Value[0] = ~Temp_Value[0] + 1;
if( Temp_Value[0] == 0x00 ) Temp_Value[1]++;
ng = 1;
}
/*********Output_Temp*********/
CurrentT = Temp_Value[1] * 16 + Temp_Value[0] / 16;
Disp[0] = CurrentT / 10 % 10; Disp[1] = CurrentT % 10;
SignedT = ng? -CurrentT : CurrentT;
if(ng) Disp[0] = 10;
if( Disp[0] == 0 ) Disp[0] = 15;
}

uchar Read( uchar addr )
{
uchar i,b,t;
RS = 0; CK = 0; RS = 1;
for(i = 0; i < 8; i++)
{
IO = addr & 1; CK = 1; CK = 0; addr >>= 1;
}
for(i = 0; i < 8; i++)
{
b >>= 1; t = IO; b |= t<<7; CK = 1; CK = 0;
}
CK = 1; RS = 0;
return b / 16 * 10 + b % 16;
}

void write_7221( uint idat )
{
uchar i;
CS = 0;
for(i = 0; i < 16; i++)
{
CK = 0; idat <<= 1; DI = CY;
CK = 1; _nop_(); _nop_();
CK = 0;
}
CS = 1;
}

void Show( void )
{
uchar s;
for(s = 0; s < 8; s++) write_7221( ((s + 1) * 256) + Disp[s] );
}

void DispLimit( void )
{
np = 0; if( SignedB < 0 ) {CurrentB = ~SignedB + 1; np = 1;}
else CurrentB = SignedB;
Disp[2] = CurrentB / 10; Disp[3] = CurrentB % 10; if(np) Disp[2] = 10;
if( Disp[2] == 0 ) Disp[2] = 15;
}

void Rectime( void )
{
Disp[4] = Read( 0x85 ) / 10; Disp[5] = Read( 0x85 ) % 10 | Dot;
Disp[6] = Read( 0x83 ) / 10; Disp[7] = Read( 0x83 ) % 10;
}

void Flash( void ) interrupt 1
{
if(++Count1 == 60) {Count1 = 0; if(UP && DN) fg = 0; Dot = 0x00;}
if( Count1 == 30 ) Dot = 0x80;
if(++Count2 == 2)
{
if(fg) {Disp[2] = 15; Disp[3] = 15;}
}
if(Count2 == 4) {Count2 = 0; DispLimit();}
if(gl == 2)
{
if(buftm)
{
TM = 0;
}
else if(buftf)
{
TF = 0;
}
else
{
TM = 1;
TF = 1;
}
}
else
{
glc = glc + 1;
if(glc >= (3-gl))
{
glc = 0;
if(buftm)
{
TM = !TM;
}
else if(buftf)
{
TF = !TF;
}
else
{
TM = 1;
TF = 1;
}
}
}
Readtemp();
Rectime();
Show();
TH0 = -50000 / 256;
TL0 = -50000 % 256;
}

void DisplayLED( void )
{
switch(gl)
{
case 0:
LL = 0;
LZ = LH = 1;
break;
case 1:
LZ = 0;
LL = LH = 1;
break;
case 2:
LH = 0;
LL = LZ = 1;
break;
}
}

void main( )
{
Readtemp();
nNop(50000); nNop(50000);
write_7221( 0x09FF );
write_7221( 0x0A0C );
write_7221( 0x0B07 );
write_7221( 0x0C01 );
IE = 0x83;
IP = 0x01;
TMOD = 0x21;
TH0 = TL0 = 254;
TR0 = IT0 = 1;
DisplayLED();

while(1)
{
if(!UP && SignedB < 99)
{
++SignedB; if(!fg) fg = 1; DispLimit();
while(!UP);
}
if(!DN && SignedB > -9)
{
--SignedB; if(!fg) fg = 1; DispLimit();
while(!DN);
}
if(!IG)
{
gl = (gl + 1) % 3;
DisplayLED();
while(!IG);
}
TK = SignedT == SignedB ? 0 : 1;
buftm = SignedT < SignedB ? 1 : 0;
buftf = SignedT > SignedB ? 1 : 0;
}
}

这个程序是带时间显示的程序,51也管用

/********************************************
读取DS18B20温度,通过数码管显示出来
********************************************/

/*头文件*/
#include <reg52.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
#define _Nop() _nop_()
sbit DQ =P3^5; //定义DS18B20通信端口
sbit LED_EN_PORT = P2^5;
sbit DAC_ADC_EN_PORT = P3^7;/*定义发光二极管及ADC、DAC、时钟的锁存器有效脚LE*/

#define sled_dm_port P0 /*定义数码管段码的控制脚*/
#define sled_wm_port P2 /*定义数码管位码的控制脚*/
/*定义数码管显示字符跟数字的对应数组关系*/
uchar code sled_mun_to_char[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e};
/* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
/*定义需要点亮的数码管*/
uchar code sled_bit_table[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
uchar data sled_data[8]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff}; /*0-7号SLED缓冲值*/
uchar data led_lighten_bit=0 ; /*LED灯点亮标志位0-7*/

//////////////////以下是DS18B20驱动程序////////////////
//延时函数
void delay(unsigned int i)
{
while(i--);
}
//初始化函数
Init_DS18B20(void)
{
unsigned char x=0;
DQ = 1; //DQ复位
delay(8); //稍做延时
DQ = 0; //单片机将DQ拉低
delay(80); //精确延时 大于 480us
DQ = 1; //拉高总线
delay(14);
x=DQ; //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
delay(20);
}
//读一个字节
ReadOneChar(void)
{
unsigned char i=0;
unsigned char dat = 0;
for (i=8;i>0;i--){
DQ = 0; // 给脉冲信号
dat>>=1;
DQ = 1; // 给脉冲信号
if(DQ) dat|=0x80;
delay(4);
}
return(dat);
}
//写一个字节
WriteOneChar(unsigned char dat)
{
unsigned char i=0;
for (i=8; i>0; i--){
DQ = 0;
DQ = dat&0x01;
delay(5);
DQ = 1;
dat>>=1;
}
}
//读取温度
ReadTemperature(void)
{
unsigned char a=0;
unsigned char b=0;
unsigned int t=0;
float tt=0;
Init_DS18B20();
WriteOneChar(0xCC); // 跳过读序号列号的操作
WriteOneChar(0x44); // 启动温度转换
Init_DS18B20();
WriteOneChar(0xCC); //跳过读序号列号的操作
WriteOneChar(0xBE); //读取温度寄存器等(共可读9个寄存器) 前两个就是温度
a=ReadOneChar();
b=ReadOneChar();
t=b;
t<<=8;
t=t|a;
tt=t*0.0625; //将温度的高位与低位合并
t= tt*10+0.5; //对结果进行4舍5入
return(t);
}
//////////////////以上是DS18B20驱动程序////////////////

/*1MS为单位的延时程序*/
void delay_1ms(uchar x)
{
uchar j;
while(x--){
for(j=0;j<125;j++)
{;}
}
}
main()
{
uint temp_buff;
uchar i;
LED_EN_PORT = 0; /*关闭发光二极管显示*/
DAC_ADC_EN_PORT = 0; /*关闭数码管以为的所有通道*/
while(1){
temp_buff=ReadTemperature(); /*读取当前温度*/
sled_data[5] = sled_mun_to_char[temp_buff/100];
sled_data[6] = sled_mun_to_char[temp_buff%100/10];
sled_data[7] = sled_mun_to_char[temp_buff%10];
for(i=0;i<8;i++){
sled_wm_port = 0xff; /*关闭显示*/
_Nop();
_Nop();
_Nop();
sled_dm_port = sled_data[i]; /*输出段码数据到数码管*/
if(i==6) sled_dm_port = sled_dm_port&0x7f; /*显示小数点*/
sled_wm_port = sled_bit_table[i]; /*输出位码数据到数码管*/
delay_1ms(1);
}
}
}

#include<AT89X52.h>
#include "intrins.h"
#define uchar unsigned char
#define uint unsigned int
uchar SZ[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
uchar data temp_data[2]={0x00,0x00};
uchar data display[5]={0x00,0x00,0x00,0x00,0x00};

sbit AB=P2^1;
sbit CLK=P2^0;
sbit SG=P2^2;
sbit SS=P2^3;
sbit DQ=P0^7;

void delay1()
{
unsigned char i,j,k;
for(i=1;i>0;i--)
for(j=10;j>0;j--)
for(k=240;k>0;k--)
;
}
void senddata(uchar num)
{
uchar c;
for(c=0;c<8;c++)
{
CLK=0;
AB=num&0x01;
num>>=1;
CLK=1;
}
}
/*****************11us延时函数*************************/
//
void delay(uint t)
{
for (;t>0;t--);
}

void ow_reset(void)
{
char presence=1;
while(presence)
{
while(presence)
{
DQ=1;_nop_();_nop_();//从高拉倒低
DQ=0;
delay(55); //550 us
DQ=1;
delay(7); //66 us
presence=DQ; //presence=0 复位成功,继续下一步
}
delay(50); //延时500 us
presence=~DQ;
}
DQ=1; //拉高电平
}
//
//
/****************DS18B20写命令函数************************/
//向1-WIRE 总线上写1个字节
void write_byte(uchar val)
{
uchar i;
for(i=8;i>0;i--)
{
DQ=1;_nop_();_nop_(); //从高拉倒低
DQ=0;_nop_();_nop_();_nop_();_nop_(); //5 us
DQ=val&0x01; //最低位移出
delay(7); //66 us
val=val/2; //右移1位
}
DQ=1;
delay(1);
}
//
/****************DS18B20读1字节函数************************/
//从总线上取1个字节
uchar read_byte(void)
{
uchar i;
uchar value=0;
for(i=8;i>0;i--)
{
DQ=1;_nop_();_nop_();
value>>=1;
DQ=0;_nop_();_nop_();_nop_();_nop_(); //4 us
DQ=1;_nop_();_nop_();_nop_();_nop_(); //4 us
if(DQ)value|=0x80;
delay(7); //66 us
}
DQ=1;
return(value);
}
//
/****************读出温度函数************************/
//
void read_temp()
{
unsigned char g,s,first,second;
ow_reset(); //总线复位
delay(200);
write_byte(0xcc); //发命令
write_byte(0x44); //发转换命令
ow_reset();
delay(1);
write_byte(0xcc); //发命令
write_byte(0xbe);
temp_data[0]=read_byte(); //读温度值的第字节
temp_data[1]=read_byte(); //读温度值的高字节

display[4]=((temp_data[0]&0xf0)>>4)|((temp_data[1]&0x0f)<<4) ;
g=display[4]%10;
s=display[4]/10;
first=SZ[g];
second=SZ[s];

SG=0;
SS=1;
senddata(first);
delay1();
SG=1;
SS=0;
senddata(second);

}
//
/****************温度数据处理函数************************/

//二进制高字节的低半字节和低字节的高半字节组成一字节,这个
//字节的二进制转换为十进制后,就是温度值的百、十、个位值,而剩
//下的低字节的低半字节转化成十进制后,就是温度值的小数部分

/********************************************************/
void main()
{

ow_reset(); //开机先转换一次
write_byte(0xcc); //Skip ROM
write_byte(0x44);
// num=read_temp();
while(1)
{
read_temp();
}

}


在使用单片机中,汇编语言和c语言各有什么优缺点?
一、汇编语言:缺点:汇编语言属于低级语言,难理解,编程效率低,编程容易出错。优点:程序执行效率高,占用资源少, 方便对最底层的一些东西进行操作。二、C语言:缺点:危险性高,开发周期长,可移植性不如JAVA。优点:语句少但是灵活度高,针对过程的言语相比于非结构化言语条理性很好接近人类的逻辑思维...

单片机(c语言)程序解释?
\/\/2、持续的高、低电平或10ms为周期的方波(与Flag、P1.0初始值有关),持续2秒。\/\/3、重复1、2步骤。\/ include <AT89X51.H> unsigned int t02s;unsigned char t05ms;bit flag;void main(void){ TMOD=0x01; \/\/初始化定时器。\/\/可以对照单片机PDF相应章节,按位对比。\/\/此处设置定时...

C语言与单片机C语言的区别是什么?
单片机c语言比起普通C语言增加了一些基本的指令,变量的赋值是16进制,当然单片机c语言只牵涉到普通c语言的基础部分。C只是一种高级语言。它除具有一般高级语言的功能特性外,它可以很好的操作底层的硬件接口。在C语言的基础上,如果你把一些单片机的端口或特殊功能寄存器加于定义,使之方便于在 写语句的...

求:如何将C语言程序弄进51单片机?
C语言是人能用的文字语言,单片机只能用由0和1组成的机器语言,要想单片机运行C语言,拢共要三步:1)写C语言程序。2)用编译软件编译C程序并生成hex代码。3)用下载线或烧录器将hex代码写入单片机。

所谓的51单片机C语言与C语言程序设计有什么区别?
51单片机C语言是对标准C语言的扩展.例如: 51单片机C 中会有特有的 sfr 关键字用来定义51单片机的寄存器, 会有对位元操作的 sbit 关键字, 这些都是你在初始化单片机时, 需要用到的, 这些都是针对 51 单片机硬件平台的扩展.编程时的算法都是相同的, 另外还有因为单片机的资源有限, 不要在单片机中...

单片机开发调试c语言程序时,下载至单片机的文件扩展名是
hex。单片机的C语言采用C51编译器(简称C51),由C51产生的目标代码短,运行速度高,存储空间小,下载至单片机的文件扩展名是hex。单片机又称单片微控制器,不是完成某一个逻辑功能的芯片,而是把一个计算机系统集成到一个芯片上。

谁能帮我写一下单片机C语言程序?
include<reg51.h> sbit LED=P1^0;sbit K1=P1^1;sbit K2=P1^2;void delay(int ms){ unsigned char i;while(ms--)for(i=0;i<120;i++);} void t0isr(void) interrupt 1 { TH0=(65536-10000)\/256;TL0=(65536-10000)%256;LED=~LED;} main(){ TMOD=0x01;TH0=(65536-10000)\/...

用KEIL编写C语言程序实现:单片机是AT89C51,实现一个计时器,数码管为6...
按照你的要求写的程序如下,你拿去测试吧!include "REG52.H"sbit SHUG_01 = P2^0; \/\/数码管1 sbit SHUG_02 = P2^1; \/\/数码管2 sbit SHUG_03 = P2^2; \/\/数码管3 sbit SHUG_04 = P2^3; \/\/数码管4 sbit SHUG_05 = P2^4; \/\/数码管5 sbit SHUG_06 = P2^5;...

求大神用C语言写出下图关于单片机的程序代码!感谢
= 0x2C; ET1 = 1; \/\/--开定时器1中断 EA = 1; \/\/--开总中断 TR1 = 1; \/\/--开定时器1 Led = 1; while(1);\/\/---主程序死循环 }void ISR_Timer1(void) interrupt 3{Led = ~Led;TH1 = 0xCF; \/\/--重载定时器, TL1 = 0x2C; \/\/定时25ms计时 } ...

需要一个C语言程序。51单片机控制:按键按一下,延迟1分钟后开灯,灯亮半...
如果对时间要求不精确,用软延时即可。include<reg52.h> define uchar unsigned char define uint unsigned int sbit s=P1^0;sbit led=P1^1;void delayms(uint i) \/\/1ms延时程序 { uchar j;for(;i>0;i--){ for(j=0;j<125;j++)\/\/如果延时时间误差较大,可按比例改变125这个数 \/\/取值...

新余市15767451726: 求C语言程序,AT89C51单片机为核心,DS18B20测温度,实时用4位LED显示温度,并且用单片机控制继电器 -
独孤侧百赛: #include // 试试#define uchar unsigned char #define uint unsigned int sbit DQ=P1^4; //ds18b20与单片机连接口 unsigned char code str[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x00,0x40} ; //共阴数码管字码表 unsigned char code ...

新余市15767451726: 求一个51单片机的多路温度控制系统的C语言程序. -
独孤侧百赛: #include<reg52.h> #include<math.h>#include<INTRINS.H>#define uchar unsigned char#define uint unsigned int;/******************************************************************//* 定义端口 *//******************************************************************/ ...

新余市15767451726: 跪求一段单片机程序(C语言编写),要求显示时钟与温度. -
独孤侧百赛: #include<reg51.h>#include<intrins.h>#define time_1 300 sbit CSPIN = P2^7; //用户自定义CS对应引脚 sbit CLKPIN = P2^6; //用户自定义CLK对应引脚 sbit DIPIN = P2^5; //用户自定义DI对应引脚 sbit DQ= P3^4; //用户自定义18B20对应引脚...

新余市15767451726: 求单片机DS18B20测温的程序,最好是C语言的,能够得到十进制的温度值 -
独孤侧百赛: #include#define uint unsigned int#define uchar unsigned char sbit dq=P1^5; void sdelay(unsigned int i) { while(i--); } ds18b20on(void)//ds18b20初始化 { uchar x=0; dq=1;sdelay(8);dq=0;sdelay(80);dq=1;sdelay(14); sdelay(20); }//读一个字节 ...

新余市15767451726: 急求基于单片机AT89C51的数字温度报警器,具有上下限的在 - 20度到70度之间的汇编程序或C语言程序!拜托 -
独孤侧百赛: ;单片机DS18B20温度计C语言程序 #include<reg51.h>#include<intrins.h>#include <math.H> //要用到取绝对值函数abs() //通过DS18B20测试当前环境温度, 并通过数码管显示当前温度值, 目前显示范围: -55~ +125度sbit wela = P2^7...

新余市15767451726: 急求:基于单片机STC90C516RD+,用C语言编写一段 温度检测系统 主程序,温度值用数码管LED显示出来 -
独孤侧百赛: 这单片机就是跟普通的51单片机没啥区别.都一样的,刚刚给别人编写完一个这个单片机的程序.应该需要使用AD转换的,你没说明具体用什么型号,我们也没办法帮你啊!

新余市15767451726: 基于单片机的数字温度计设计用C语言写程序 -
独孤侧百赛: //------------------------------------------------------------------//DS18B20温度传感器输出显示,运行本例时,外界温度将显示在1602LCD上//------------------------------------------------------------------#include <reg52.h>#include <intrins.h>#define uchar unsigned char#...

新余市15767451726: 51单片机LCD显示程序,请求C语言高手解答 -
独孤侧百赛: 不知你用的LCD属于那种型号,似乎不像1602.如果得到的数值小于1000,就正常显示个十白位的数字,比如345就显示34.5;如果大于1000,3个赋值都是0x39,即ASCII字符'9',这样的结果就是会在LCD上显示99.9,表示超过1000的量程范围.猜测REQ是对LCD写控制信号,busy是LCD返回的“忙”信号,for循环16次就是把lcdtem字符数组中的16个字符写到LCD上显示.

新余市15767451726: 单片机温度报警器的温度上下限按键调控的C语言程序怎么编? -
独孤侧百赛: 温度报警器就是需要温度传感器不停地对监控的对象进行检测,例如pt100温度传感器,pt100传感器是不同温度下,阻值会不同,在同一温度下,阻值是相同的.根据这个原理通过电路转换成电压,然后模拟量转换成数字量输入到单片机,单片...

新余市15767451726: 温度控制的单片机c程序 -
独孤侧百赛: 几个if语句就搞定 SetData 设定温度 MeaData 测量得到温度 if((SetData==MeaData)||(SetData<MeaData)) { ....(相关操作)....}

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网