微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > FPGA,CPLD和ASIC > 基于i2c串口通信的lm75a温度传感器的温度计设计

基于i2c串口通信的lm75a温度传感器的温度计设计

时间:10-02 整理:3721RD 点击:
我们老师布置的一个EDA作业,要求用i2c控制lm75a的温度传感器,来完成一个温度计的设计,要求用数码管显示,并且能够间隔一定时间就可以更新数据,实在是搞不出来了,希望有大神能指点一二

我前两天高弄出来,很容易啊,就是一个I2C么

那个i2c要和lm75a怎么连接

利用LM75测环境温度,设定上限温度27度,下限温度22度。超过范围蜂鸣器会响。将实测温度值利用串口发送到上位机上。将实测温度值*2427,取整后用液晶显示,并将该数转换成16进制且去除A~F后再显示。利用外部按键可以锁定该值,再按后取消锁定。

//LM75温度传感器 程序
#include /*头文件的包含*/
#include
#include
#define uint8 unsigned char /*宏定义*/
#define uint16 unsigned int /*宏定义*/
#define qian (16*16*16)
#define bai (16*16)
#define shi 16
uint8 t0num,flagtime,flag=1,a;
uint8 Num[4];
uint8 Num1[5];
uint8 Num2[4];
//定义寄存器指针值
#define TempReg  0x00
#define ConfReg  0x01
#define ThystReg 0x02           //温度下限值
#define TosReg   0x03           //温度上限值
sbit SCL=P3^3;                   /*模拟I2C 数据传送位*/
sbit SDA=P3^4;                   /*模拟I2C 时钟控制位*/
sbit EN=P1^0;
sbit RS=P1^2;
sbit ling=P1^3;
sbit judge=P1^4;
//sbit Seg_Sel=P2^0;
//sbit Pos_Sel=P2^1;
bit ack;               /*应答标志位*/
uint8 code SegData[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
                        0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
uint8 code SegData1[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,
                        0x87,0xff,0xef};
uint8 code SegData2[]="0123456789      ";
void delayms(uint16 z)
{
        uint16 x,y;
        for(x=z;x>0;x--)
          for(y=10;y>0;y--);
}
void write_com(uint8 com)
{
        RS=0;
        P0=com;
        delayms(3);
        EN=1;
        delayms(3);
        EN=0;
}
void write_data(uint8 dat)
{
        RS=1;
        P0=dat;
        delayms(3);
        EN=1;
        delayms(3);
        EN=0;
}
void initlcd()
{
        EN=0;
        write_com(0x38);
        write_com(0x0c);
        write_com(0x06);
        write_com(0x01);
}
void Delay5us(void)
{
        _nop_();
}
void Delay1ms(uint16 ms)
{
        uint16 i,j;
        for(i=ms;i>0;i--)
                for(j=56;j>0;j--);
}
void init()
{
        TMOD=0x21;
        TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
        TH1=0xfd;
        TL1=0xfd;
        TR1=1;
        ET1=0;
        ET0=1;
        EX0=1;
        IE0=0;
        IT0=0;
        TR0=1;
        SM0=0;
        SM1=1;
        REN=1;
        EA=1;
        ES=1;
}
void timer0() interrupt 1
{
    TH0=(65536-50000)/256;
        TL0=(65536-50000)%256;
        t0num++;
        if(t0num==20)
        {t0num=0;flagtime=1;}
}
void Start_I2c()
{
        SDA=1; /*发送起始条件的数据信号*/
        _nop_(); /*起始条件建立时间大于4.7us,延时*/
        SCL=1;
        Delay5us();
        SDA=0; /*发送起始信号*/
        Delay5us();
        SCL=0; /*钳住I2C 总线,准备发送或接收数据*/
        _nop_();
        _nop_();
}
void Stop_I2c()
{
        SDA=0; /*发送结束条件的数据信号*/
        _nop_(); /*发送结束条件的时钟信号*/
        SCL=1; /*结束条件建立时间大于4μs*/
        Delay5us();
        SDA=1; /*发送I2C 总线结束信号*/
        Delay5us();
}
void WriteByte(uint8 Data)
{
        uint8 i;
        for(i=0;i >7;
                        Delay1ms(180);
                        Display(temp);
                        flagtime=0;
                      ES=0;
                           for(i=0;i<4;i++)
                           {
               SBUF=Num[i];
                           while(!TI);
                           TI=0;
                           if(i==2)
                           {TI=1;
                           printf(".");
                           while(!TI);
                                TI=0;
                                }
                           }
                           ES=1;
               
                   write_com(0x80+0x00);
                        for(num=0;num<5;num++)
                        {
                                write_data(Num1[num]);
                                delayms(3);
                        }
                   write_com(0x80+0x40);
                        for(num=0;num<4;num++)
                        {
                                write_data(SegData2[Num2[num]]);
                                delayms(3);
                        }
                        while(flag==1);
                }
                }  
        }
  }
}
void waibu0()interrupt 0
{
     flag=~flag;
         ling=~ling;
        //        while(flag)
               
}

我刚调出来的,绝对正确哦哦

111111111111111111111111111111111

这不是c语言的啊

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top