18b20温度显示(164驱动8位LED)-CVAVR程序

发布者:runaway2000最新更新时间:2016-10-30 来源: eefocus关键字:18b20  温度显示  164驱动  8位LED 手机看文章 扫描二维码
随时随地手机看文章
//串行数码管显示  温度值

//芯片 ATMEGA16L 
//时钟 4MHz 内部
// DS18B20数据线是双向总线,采用一个IO口
// DS18B20数据线,输出不是通过IO口直接输出0和1,而是将IO口的PORT置成0。
// 输出方式,输出0;
// 输入方式,内部上拉电阻无效,引脚为高组态,由于外部上拉电阻,引脚呈现高电平,输出1.
// 采用系统自带延时程序
#include  
#include

#define hc164_data   PORTD.0  // 164数据线
#define hc164_clk    PORTD.1  // 164时钟线

#define DATA_18B20          DDRD.7   // PD7方向控制,18B20数据线
#define DATA_18B20_Input    PIND.7   // 18B20数据线作为输入
#define DATA_18B20_Output   PORTD.7  // 18B20数据线作为输出或作为输入时上拉电阻无效
#define DATA_18B20_Hight    DATA_18B20 = 0 // 18B20数据线置1,输入状态,内部上拉电阻无效,引脚为高组态,由于外部上拉电阻,引脚呈现高电平。
#define DATA_18B20_Low     DATA_18B20 = 1 // 18B20数据线清0,输出状态,输出0

void hc164_send_byte (unsigned char byte);  // 164输出子程序
void leddisplay(void);  // 数码管显示子程序

//18B20函数开始    
void DS18B20_init (void);            // DS18B20引脚初始化  
unsigned char Reset_DS18B20(void);   // 复位子程序
void WR_DS18B20 (unsigned char);     // 写1个字节子程序
unsigned char RD_DS18B20 (void);     // 读1个字节子程序
unsigned int GetTempDS18B20 (void);  // 读取温度子程序
//18B20函数结束
unsigned char ledxs[8]={16,16,16,16,16,0,0,0}; // 数码管显示缓冲区
                //        温度     十位  个位  小数位
flash unsigned char tab[]={0xb7,0x12,0x67,0x76,0xd2,0xf4,0xf5,0x16,0xf7,0xf6,0xd7,0xf1,0xa5,0x73,0xe5,0xc5,0,0xff};
                          //共阴极代码 0-F,  全灭,全亮
void main()
{
   unsigned int wendu,temp;
   delay_ms(200);  
   DDRD |= 0x03;          // 164驱动,PD0、PD1置为输出方式
   DS18B20_init ();       //  DS18B20引脚初始化    
   while(1)
   {
     wendu=GetTempDS18B20();  // 读取温度
     temp=wendu/100;
     ledxs[5]=temp;      // 求得温度十位
     temp=wendu%100;
     ledxs[6]=temp/10;   // 求得温度个位
     ledxs[7]=temp%10;   // 求得温度小数位
     leddisplay();       // 串行显示
   }

}
void leddisplay()        // 数码管显示子程序
{
  unsigned char i;
  for(i=0;i<8;i++)
  {
    if(i==6)
      hc164_send_byte (tab[ledxs[i]]|0x08);  //温度个位加小数点
    else
      hc164_send_byte (tab[ledxs[i]]);
   delay_us(2);
  }

void hc164_send_byte (unsigned char byte)    // 164输出子程序
{
  unsigned char i;
   for(i=0;i<8;i++)
   {
      hc164_data = byte & ( 1 << i );       
      hc164_clk = 1;       
      hc164_clk = 0;   
   }  
}  
void DS18B20_init (void)     //  DS18B20引脚初始化  
{
    DATA_18B20_Output = 0;   // 18B20数据线的PORT状态锁定为0。输出方式,输出0;输入方式,内部上拉电阻无效。   
    DATA_18B20_Hight;        // 18B20数据线输入方式,呈现高电平
}

//----------------------------------------------------------------------------
// 复位 DS1820
// CPU将数据线拉低480us,然后释放,
// 当DS18B20收到信号后等待16~60us左右,后发出60~240us的存在低脉冲,
// 主CPU收到此信号表示复位成功。
//----------------------------------------------------------------------------
unsigned char Reset_DS18B20(void)
{
  unsigned char flag;
  DATA_18B20_Hight;    // 18B20数据线 =1,数据线为输入方式,内部上拉电阻无效,引脚为高组态,由于外部上拉电阻,引脚呈现高电平。
  delay_us(2);
  DATA_18B20_Low;      // 保持低电平至少 480 us
  delay_us(500); 
  DATA_18B20_Hight;
  delay_us(60);        // 60us延时,等DS18B20 完成采样     
  if(DATA_18B20_Input)
    flag = 1;      
  else
    flag = 0;          // 检查DS1820 是否存在 
  delay_us(300);       // 等 300 us
  return flag;         // flag=0复位成功,flag=1,复位不成功
}
//----------------------------------------------------------------------------
// 写1个字节到DS18B20
// CPU将数据线从高电平拉至低电平,产生写起始信号;
// 15us之内,将所写的位送到数据线上;
// DS18B20在15us~60us之间接收位信息;
// 写下一个位之前要有1us以上的高电平恢复;
// 将以上过程重复8次,即完成一个字节的写操作。
//----------------------------------------------------------------------------
void WR_DS18B20(unsigned char data0)
{
  unsigned char i;
  for (i=0; i<8; i++)
  {
    DATA_18B20_Low;        // 数据线拉成低电平
    delay_us(2);
    if ((data0&0x01)==0x01) 
       DATA_18B20_Hight;
    else  
       DATA_18B20_Low;    // 送出最低位 
    data0=data0>>1;       // 右移1位
    delay_us(60);         // 60us延时,等DS18B20 完成采样    
    DATA_18B20_Hight;     // 数据线恢复高电平
    delay_us(2);
  }
}
//----------------------------------------------------------------------------
// 从DS1820读取1个字节
// CPU将数据线从高电平拉到低电平1us以上,再拉到高电平,产生读起始信号;
// 15us之内,CPU读一位;
// 读周期为60us,
// 读下一个位之前要有1us以上的高电平恢复;
// 将以上过程重复8次,即完成一个字节的读操作。
//----------------------------------------------------------------------------
unsigned char RD_DS18B20()
{
  unsigned char i,data0=0;
  for (i=0; i<8; i++)
  {
    DATA_18B20_Low;       // 数据线拉成低电平
    delay_us(2);
    DATA_18B20_Hight;     // 数据线拉到高电平,准备接收数据
    delay_us(2);
    data0=data0>>1;       // 右移1位
    if(DATA_18B20_Input)  data0 |= 0x80;    // 读取1位
    delay_us(60);         // 60us延时 
    DATA_18B20_Hight;     // 数据线恢复高电平
    delay_us(2);
  }
  return data0;
}
//----------------------------------------------------------------------------
// 读取温度
// 返回温度值*10后的结果
// (例 24.5 度 => 245 度)
//----------------------------------------------------------------------------
unsigned int GetTempDS18B20()
{
  unsigned int temp;
  unsigned char flag,th,tl;
  flag = Reset_DS18B20(); // 复位
  if(flag) return 0x0000;
  WR_DS18B20 (0xcc);      // 跳过ROM
  WR_DS18B20 (0x44);      // 启动温度转换
  delay_ms(1000);         // 延时1s,等待转换结束
  flag = Reset_DS18B20(); // 复位
  if(flag) return 0x0000;
  WR_DS18B20 (0xcc);      // 跳过ROM
  WR_DS18B20 (0xbe);      // 发读温度命令
  tl = RD_DS18B20();      // 读温度低字节     
  th = RD_DS18B20();      // 读温度高字节   
  temp = ((unsigned int)th << 8)|tl;  // 温度高字节加上温度低字节    
  temp = ((temp>>4)*10)+((((temp&0x0008)>>3)*500)+(((temp&0x0004)>>2)*250)+(((temp&0x0002)>>1)*125)+((temp&0x0001)*62))/100; //温度值*10
  return temp;
}//串行数码管显示  温度值
//芯片 ATMEGA16L 
//时钟 4MHz 内部
// DS18B20数据线是双向总线,采用一个IO口
// DS18B20数据线,输出不是通过IO口直接输出0和1,而是将IO口的PORT置成0。
// 输出方式,输出0;
// 输入方式,内部上拉电阻无效,引脚为高组态,由于外部上拉电阻,引脚呈现高电平,输出1.
// 采用系统自带延时程序
#include  
#include

#define hc164_data   PORTD.0  // 164数据线
#define hc164_clk    PORTD.1  // 164时钟线

#define DATA_18B20          DDRD.7   // PD7方向控制,18B20数据线
#define DATA_18B20_Input    PIND.7   // 18B20数据线作为输入
#define DATA_18B20_Output   PORTD.7  // 18B20数据线作为输出或作为输入时上拉电阻无效
#define DATA_18B20_Hight    DATA_18B20 = 0 // 18B20数据线置1,输入状态,内部上拉电阻无效,引脚为高组态,由于外部上拉电阻,引脚呈现高电平。
#define DATA_18B20_Low     DATA_18B20 = 1 // 18B20数据线清0,输出状态,输出0

void hc164_send_byte (unsigned char byte);  // 164输出子程序
void leddisplay(void);  // 数码管显示子程序

//18B20函数开始    
void DS18B20_init (void);            // DS18B20引脚初始化  
unsigned char Reset_DS18B20(void);   // 复位子程序
void WR_DS18B20 (unsigned char);     // 写1个字节子程序
unsigned char RD_DS18B20 (void);     // 读1个字节子程序
unsigned int GetTempDS18B20 (void);  // 读取温度子程序
//18B20函数结束
unsigned char ledxs[8]={16,16,16,16,16,0,0,0}; // 数码管显示缓冲区
                //        温度     十位  个位  小数位
flash unsigned char tab[]={0xb7,0x12,0x67,0x76,0xd2,0xf4,0xf5,0x16,0xf7,0xf6,0xd7,0xf1,0xa5,0x73,0xe5,0xc5,0,0xff};
                          //共阴极代码 0-F,  全灭,全亮
void main()
{
   unsigned int wendu,temp;
   delay_ms(200);  
   DDRD |= 0x03;          // 164驱动,PD0、PD1置为输出方式
   DS18B20_init ();       //  DS18B20引脚初始化    
   while(1)
   {
     wendu=GetTempDS18B20();  // 读取温度
     temp=wendu/100;
     ledxs[5]=temp;      // 求得温度十位
     temp=wendu%100;
     ledxs[6]=temp/10;   // 求得温度个位
     ledxs[7]=temp%10;   // 求得温度小数位
     leddisplay();       // 串行显示
   }

}
void leddisplay()        // 数码管显示子程序
{
  unsigned char i;
  for(i=0;i<8;i++)
  {
    if(i==6)
      hc164_send_byte (tab[ledxs[i]]|0x08);  //温度个位加小数点
    else
      hc164_send_byte (tab[ledxs[i]]);
   delay_us(2);
  }

void hc164_send_byte (unsigned char byte)    // 164输出子程序
{
  unsigned char i;
   for(i=0;i<8;i++)
   {
      hc164_data = byte & ( 1 << i );       
      hc164_clk = 1;       
      hc164_clk = 0;   
   }  
}  
void DS18B20_init (void)     //  DS18B20引脚初始化  
{
    DATA_18B20_Output = 0;   // 18B20数据线的PORT状态锁定为0。输出方式,输出0;输入方式,内部上拉电阻无效。   
    DATA_18B20_Hight;        // 18B20数据线输入方式,呈现高电平
}

//----------------------------------------------------------------------------
// 复位 DS1820
// CPU将数据线拉低480us,然后释放,
// 当DS18B20收到信号后等待16~60us左右,后发出60~240us的存在低脉冲,
// 主CPU收到此信号表示复位成功。
//----------------------------------------------------------------------------
unsigned char Reset_DS18B20(void)
{
  unsigned char flag;
  DATA_18B20_Hight;    // 18B20数据线 =1,数据线为输入方式,内部上拉电阻无效,引脚为高组态,由于外部上拉电阻,引脚呈现高电平。
  delay_us(2);
  DATA_18B20_Low;      // 保持低电平至少 480 us
  delay_us(500); 
  DATA_18B20_Hight;
  delay_us(60);        // 60us延时,等DS18B20 完成采样     
  if(DATA_18B20_Input)
    flag = 1;      
  else
    flag = 0;          // 检查DS1820 是否存在 
  delay_us(300);       // 等 300 us
  return flag;         // flag=0复位成功,flag=1,复位不成功
}
//----------------------------------------------------------------------------
// 写1个字节到DS18B20
// CPU将数据线从高电平拉至低电平,产生写起始信号;
// 15us之内,将所写的位送到数据线上;
// DS18B20在15us~60us之间接收位信息;
// 写下一个位之前要有1us以上的高电平恢复;
// 将以上过程重复8次,即完成一个字节的写操作。
//----------------------------------------------------------------------------
void WR_DS18B20(unsigned char data0)
{
  unsigned char i;
  for (i=0; i<8; i++)
  {
    DATA_18B20_Low;        // 数据线拉成低电平
    delay_us(2);
    if ((data0&0x01)==0x01) 
       DATA_18B20_Hight;
    else  
       DATA_18B20_Low;    // 送出最低位 
    data0=data0>>1;       // 右移1位
    delay_us(60);         // 60us延时,等DS18B20 完成采样    
    DATA_18B20_Hight;     // 数据线恢复高电平
    delay_us(2);
  }
}
//----------------------------------------------------------------------------
// 从DS1820读取1个字节
// CPU将数据线从高电平拉到低电平1us以上,再拉到高电平,产生读起始信号;
// 15us之内,CPU读一位;
// 读周期为60us,
// 读下一个位之前要有1us以上的高电平恢复;
// 将以上过程重复8次,即完成一个字节的读操作。
//----------------------------------------------------------------------------
unsigned char RD_DS18B20()
{
  unsigned char i,data0=0;
  for (i=0; i<8; i++)
  {
    DATA_18B20_Low;       // 数据线拉成低电平
    delay_us(2);
    DATA_18B20_Hight;     // 数据线拉到高电平,准备接收数据
    delay_us(2);
    data0=data0>>1;       // 右移1位
    if(DATA_18B20_Input)  data0 |= 0x80;    // 读取1位
    delay_us(60);         // 60us延时 
    DATA_18B20_Hight;     // 数据线恢复高电平
    delay_us(2);
  }
  return data0;
}
//----------------------------------------------------------------------------
// 读取温度
// 返回温度值*10后的结果
// (例 24.5 度 => 245 度)
//----------------------------------------------------------------------------
unsigned int GetTempDS18B20()
{
  unsigned int temp;
  unsigned char flag,th,tl;
  flag = Reset_DS18B20(); // 复位
  if(flag) return 0x0000;
  WR_DS18B20 (0xcc);      // 跳过ROM
  WR_DS18B20 (0x44);      // 启动温度转换
  delay_ms(1000);         // 延时1s,等待转换结束
  flag = Reset_DS18B20(); // 复位
  if(flag) return 0x0000;
  WR_DS18B20 (0xcc);      // 跳过ROM
  WR_DS18B20 (0xbe);      // 发读温度命令
  tl = RD_DS18B20();      // 读温度低字节     
  th = RD_DS18B20();      // 读温度高字节   
  temp = ((unsigned int)th << 8)|tl;  // 温度高字节加上温度低字节    
  temp = ((temp>>4)*10)+((((temp&0x0008)>>3)*500)+(((temp&0x0004)>>2)*250)+(((temp&0x0002)>>1)*125)+((temp&0x0001)*62))/100; //温度值*10
  return temp;
}

关键字:18b20  温度显示  164驱动  8位LED 引用地址:18b20温度显示(164驱动8位LED)-CVAVR程序

上一篇:24c32 CVAVR程序
下一篇:TLC5615的ICC程序

推荐阅读最新更新时间:2024-03-16 15:18

一个简单的18B20程序
'////////////////////////////////////// '读取DS18B20温度数据,并在LCD上显示出来 '设计者 啊艺 '编译器BASCOM-AVR1.11.8.1 '////////////////////////////////////// $regfile = M16def.dat $crystal = 1000000 Config 1wire = Portb.7 '定义单总线器件的接口 Config Lcdpin = Pin , Db4 = Portb.2 , Db5 = Portb.3 , Db
[单片机]
显示温度及时间(能调时闹时)的bascom-avr程序
$regfile = m16def.dat $crystal = 8000000 Config Lcdpin = Pin , Db4 = Portc.4 , Db5 = Portc.5 , Db6 = Portc.6 , Db7 = Portc.7 , E = Portc.2 , Rs = Portc.0 Config Lcd = 16 * 2 Config 1wire = Porta.0 '************************************************* Dim Id(8) As Byte Dim I As Byte Dim C(2) As Byte Dim T As Word
[单片机]
74LS164扩展的8位LED串行显示接口电路
74LS164扩展的8位LED串行显示接口电路(一) 本实验显示的结果是12345678。利用89C52和74LS164扩展8位LED数码管显示,74LS164是将串行输入转换成并行输出,用来选择数码管的段显示,89C51的P2口是用对数码管的位选,从而驱动数码管按照程序的指令进行显示。 流程图设计 74LS164扩展的8位LED串行显示接口电路(二) 74LS164是串行输入并行输出的移位寄存器,每接一片74LS164可扩展一个8位并行输出口,可以作为LED显示器的8根段选线。实物如图3-1所示。系统总电路原理图如图3-2,为89C52单片机最小系统与8位数码管的连接图,分别用8个74LS164和8个LED数码管。部分
[单片机]
74LS<font color='red'>164</font>扩展的<font color='red'>8位</font><font color='red'>LED</font>串行<font color='red'>显示</font>接口电路
编程控制8位LED循环点亮
8个LED正极通过1千欧的限流电阻接到电源正极,负极接单片机控制端P0口。只要P0口管脚输出低电平,对应的LED就会被点亮。原理图如下: 单片机控制外部器件是通过I/O口的操作来实现的,因此对外围器件的操作,实际上是对I/O口的操作。 编程如下: 1、循环左移 #include reg51.h //51系列单片机头文件包含对单片机内部寄存器等的定义 #include intrins.h //本征函数头文件,包含此头文件可以在程序中直接调用本征函数_crol_(a,n) #define uchar unsigned char /*以下三句属宏定义语句,以#define LED P0为例,它
[单片机]
编程控制<font color='red'>8位</font><font color='red'>LED</font>循环点亮
用74LS164驱动数码管
3、实训进度安排 (1)第一天上午:布置任务、分组、确定题目。 (2)第一天下午和晚上:查找资料确定方案,画出系统组成框图、硬件电路图、软件流程图。 (3)第二天上午:同步进行元件购买和软件设计 (4)第二天下午和晚上:同步进行软件设计与电路焊接 (5)第三天上午:同步进行软件设计与电路焊接 (6)第三天下午和晚上:同步进行软件仿真调试和电路调试 (7)第四天上午:软硬件联调 (8)第四天下午和晚上:软硬件联调,撰写实训报告(每组一份) (9)第五天上午和下午:产品测试与答辩 通过本次课程设计的实践,进一步学习、掌握单片机应用系统的有关知识,加深了解单片机的工作原理。也进一步掌握简单单片机应用系统的设计、制作、
[单片机]
超低功耗温度测量与显示方案
摘要 温度测量系统应用广泛,被大量应用于电厂、建材、煤化工、冶金、供热、工程机械热处理、煤质化验等温度测控领域。实现高精度、低功耗温度监测成为多种行业的需求,本文介绍了一种超低功耗温度测量显示系统的实现方法,给出了其硬件连接方式及软件工作流程,对超低功耗设计方法给出具体思路。 硬件连接 谈到低功耗方案设计,有过单片机开发经历的工程师基本都会想到欧美知名芯片厂商的MSP430超低功耗MCU,MSP430在功耗控制方面处在行业领先水平,但片内资源有限,在进行高精度温度测量时需要采集温度传感器的微弱信号,12位的片内ADC就不能满足要求,需要外加仪表放大器和高精度ADC,以满足温度传感器信号的高精度测量,通常选择AD7794或ADS
[单片机]
超低功耗<font color='red'>温度</font>测量与<font color='red'>显示</font>方案
51单片机温度计2.0版ds18b20+0.96寸OLED IIC显示
51单片机温度计LCD1602显示成功,于是又挑战了OLED显示 main.c #include oled.h #include ds18b20_1.h void Timer0Init(void); //void Gao_Wen(void); //void GaoDiInit(void); sbit Deng=P1^0; //LED灯 sbit FengMing=P1^1; //蜂鸣器 sbit GD=P3^0; //两个功能:高限温减小,关闭LED灯 sbit GF=P3^1; //两个功能
[单片机]
51单片机实现温度采集与显示(二)
下面简单介绍一下DS18B20: DS18B20 是由 DALLAS 半导体公司推出的一种的“一线总线(单总线) ” 接 口的温度传感器。 与传统的热敏电阻等测温元件相比, 它是一种新型的体积小、 适用电压宽、 与微处理器接口简单的数字化温度传感器。 通过P37模拟单总线通信读取数据和发送命令 上面是DS18B20 的示意图,可以看出他与51单片机相连的只有一个管脚——P37,那么二者是如何通信的呢?——采用软件模拟单总线通信 DS18B20 时序包括如下几种: 初始化时序、 写(0 和 1) 时序、 读(0 和 1) 时序。 DS18B20 发送所有的命令和数据都是字节的低位在前。 初始化时序:简单来说,就是主机发送复位
[单片机]
51单片机实现<font color='red'>温度</font>采集与<font color='red'>显示</font>(二)
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved