avr单片机18B20温度传感器编程

全部回答3
默认 最新
  • unsigned char table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}; void show (unsigned char a, unsigned char b) { DDRB=0XFF; DDRC=0XFF; PORTB=~table[a]; //共阳数码管请去掉“~” PORTC=~BIT(b); //共阳数码管请去掉“~” s_1ms(1); } void xianshi(unsigned int k) { show((k)%10,3); show(((k)/10)%10,2); show(((k)/100)%10,1); show(((k)/1000)%10,0); } 在你提供程序中,添加以上程序。在main函数改为: void main() { unsigned int i,tem3,tem2,tem1; //端口初始化 DDRA = 0xff; PORTA = 0x00; DDRB = 0xFF; PORTB = 0xF0; DDRC = 0x00; PORTC = 0xFF; DDRD = 0xff; PORTD = 0xff; //延时200ms s_1ms(200); //DS18B20复位 ds1820_reset(); while (1) { //进行一次转换 ds1820_start(); s_1ms(2000); i = ds1820_read_temp(); //读取温度数值 xianshi(i); } } ICCAVR编译;没具体程序,我现写的,不通的话,告诉我,我在改之……
    0 点赞
  • 找一个数码管显示的程序 再整合一下就可以了 我们的开发板 配有18B20显示到数码管的程序
    0 点赞
  • ;这是关于DS18B20的读写程序,数据脚P2.2,晶振12MHZ ;温度传感器18B20汇编程序,采用器件默认的12位转化,最大转化时间750微秒 ;可以将检测到的温度直接显示到AT89C51开发实验板的两个数码管上 ;显示温度00到99度,很准确哦~~无需校正! ORG 0000H ;单片机内存分配申明! TEMPER_L EQU 29H;用于保存读出温度的低8位 TEMPER_H EQU 28H;用于保存读出温度的高8位 FLAG1 EQU 38H;是否检测到DS18B20标志位 a_bit equ 20h ;数码管个位数存放内存位置 b_bit equ 21h ;数码管十位数存放内存位置 TEMP_TH EQU MAIN: LCALL GET_TEMPER;调用读温度子程序 ,显示范围00到99度,显示精度为1度 ;因为12位转化时每一位的精度为0.0625度,我们不要求显示小数所以可以抛弃29H的低4位 ;将28H中的低4位移入29H中的高4位,这样获得一个新字节,这个字节就是实际测量获得的温度 MOV A,29H MOV C,40H;将28H中的最低位移入C RRC A MOV C,41H RRC A MOV C,42H RRC A MOV C,43H RRC A MOV 29H,A LCALL DISPLAY ;调用数码管显示子程序 CPL P1.0 AJMP MAIN ; 这是DS18B20复位初始化子程序 INIT_1820: SETB P3.5 NOP CLR P3.5 ;主机发出延时537微秒的复位低脉冲 MOV R1,#3 TSR1:MOV R0,#107 DJNZ R0,$ DJNZ R1,TSR1 SETB P3.5 ;然后拉高数据线 NOP NOP NOP MOV R0,#25H TSR2: JNB P3.5,TSR3 ;等待DS18B20回应 DJNZ R0,TSR2 LJMP TSR4 ; 延时 TSR3: SETB FLAG1 ; 置标志位,表示DS1820存在 CLR P1.7 ;检查到DS18B20就点亮P1.7LED LJMP TSR5 TSR4: CLR FLAG1 ; 清标志位,表示DS1820不存在 CLR P1.1 ;点亮P1。1脚LED表示温度传感器通信失败 LJMP TSR7 TSR5: MOV R0,#117 TSR6: DJNZ R0,TSR6 ; 时序要求延时一段时间 TSR7: SETB P3.5 RET ; 读出转换后的温度值 GET_TEMPER: SETB P3.5 LCALL INIT_1820 ;先复位DS18B20 JB FLAG1,TSS2 CLR P1.2 RET ; 判断DS1820是否存在?若DS18B20不存在则返回 TSS2: CLR P1.3 ;DS18B20已经被检测到!!!!!!!!!!!!!!!!!! MOV A,#0CCH LCALL WRITE_1820 MOV A,#44H ;发出温度转换命令 LCALL WRITE_1820 ;这里通过调用显示子程序实现延时一段时间,等待AD转换结束,12位的话750微秒 LCALL DISPLAY LCALL INIT_1820 ;准备读温度前先复位 MOV A,#0CCH ; 跳过ROM匹配 LCALL WRITE_1820 MOV A,#0BEH ; 发出读温度命令 LCALL WRITE_1820 LCALL READ_18200; 将读出的温度数据保存到35H/36H CLR P1.4 RET ;写DS18B20的子程序(有具体的时序要求) WRITE_1820: MOV R2,#8;一共8位数据 CLR C WR1: CLR P3.5 MOV R3,#6 DJNZ R3,$ RRC A MOV P3.5,C MOV R3,#23 DJNZ R3,$ SETB P3.5 NOP DJNZ R2,WR1 SETB P3.5 RET ; 读DS18B20的程序,从DS18B20中读出两个字节的温度数据 READ_18200: MOV R4,#2 ; 将温度高位和低位从DS18B20中读出 MOV R1,#29H ; 低位存入29H(TEMPER_L),高位存入28H(TEMPER_H) RE00: MOV R2,#8;数据一共有8位 RE01: CLR C SETB P3.5 NOP NOP CLR P3.5 NOP NOP NOP SETB P3.5 MOV R3,#9 RE10: DJNZ R3,RE10 MOV C,P3.5 MOV R3,#23 RE20: DJNZ R3,RE20 RRC A DJNZ R2,RE01 MOV @R1,A DEC R1 DJNZ R4,RE00 RET ;显示子程序 display: mov a,29H;将29H中的十六进制数转换成10进制 mov b,#10 ;10进制/10=10进制 div ab mov b_bit,a ;十位在a mov a_bit,b ;个位在b mov dptr,#numtab ;指定查表启始地址 mov r0,#4 dpl1: mov r1,#250 ;显示1000次 dplop: mov a,a_bit ;取个位数 MOVC A,@A+DPTR ;查个位数的7段代码 mov p1,a ;送出个位的7段代码 setb p2.0 ;开个位显示 acall d1ms ;显示1ms clr p2.0 mov a,b_bit ;取十位数 MOVC A,@A+DPTR ;查十位数的7段代码 mov p1,a ;送出十位的7段代码 setb p2.1 ;开十位显示 acall d1ms ;显示1ms clr p2.1 djnz r1,dplop ;100次没完循环 djnz r0,dpl1 ;4个100次没完循环 ret ;1MS延时(按12MHZ算) D1MS: MOV R7,#80 DJNZ R7,$ RET numtab: ;数码管共阳极0~9代码 DB 0C0H,0F9H,0A4H,0B0H,99H, 92H,82H,0F8H,80H,90H end 感觉对你有用就赏分吧~
    0 点赞

没有更多内容了

返回顶部
产品求购 求购