基于单片机的智能火灾报警系统设计源程序代码

2019-03-15 13:47

#include //调用单片机头文件

#define uchar unsigned char //无符号字符型 宏定义 变量范围0~255 #define uint unsigned int //无符号整型 宏定义 变量范围0~65535

#include #include \#include \

sbit CS=P2^4; //CS定义为P2口的第4位脚,连接ADC0832CS脚 sbit SCL=P2^3; //SCL定义为P2口的第3位脚,连接ADC0832SCL脚 sbit DO=P2^2; //DO定义为P2口的第2位脚,连接ADC0832DO脚

sbit dq = P2^0; //18b20 IO口的定义 sbit beep = P3^2; //蜂鸣器IO口定义 uint temperature,s_temp ; //温度的变量 uchar yanwu,s_yanwu; //烟物等级 uchar shoudong; //手动报警键

bit flag_300ms ; uchar key_can; //按键值的变量 uchar menu_1; //菜单设计的变量 bit key_500ms ;

uchar phone1_i = 0; //电话号码是多少位 uchar phone2_i = 0; //电话号码是多少位 uchar phone1_call[11]={\ %uchar phone2_call[11]={\ %uchar dis_smg[11];

/***********************1ms延时函数*****************************/ void delay_1ms(uint q) { uint i,j; for(i=0;i

#include \

/***************把数组清空**********************/ void clear_shuzu(uchar *p,uchar num)

{ for(i=0;i

/******************把数据保存到单片机内部eeprom中**写电话号码****************/ void write_eeprom() //数据保存 { SectorErase(0x2000); for(i=0;i<11;i++) byte_write(0x2000 + i,phone1_call[i]); byte_write(0x2012,phone1_i); byte_write(0x2013,phone2_i); byte_write(0x2014, s_temp); byte_write(0x2015,s_yanwu); byte_write(0x2016,a_a); byte_write(0x2020,phone2_call[0]); byte_write(0x2021,phone2_call[1]); byte_write(0x2022,phone2_call[2]); byte_write(0x2023,phone2_call[3]); byte_write(0x2024,phone2_call[4]); byte_write(0x2025,phone2_call[5]); byte_write(0x2026,phone2_call[6]); byte_write(0x2027,phone2_call[7]); byte_write(0x2028,phone2_call[8]); byte_write(0x2029,phone2_call[9]); byte_write(0x2030,phone2_call[10]); }

/******************把数据从单片机内部eeprom中读出来**读电话号码***************/ void read_eeprom() { for(i=0;i<11;i++) phone1_call[i] = byte_read(0x2000+i); phone1_i = byte_read(0x2012); phone2_i = byte_read(0x2013); s_temp = byte_read(0x2014); s_yanwu = byte_read(0x2015); a_a = byte_read(0x2016); phone2_call[0] = byte_read(0x2020); phone2_call[1] = byte_read(0x2021); phone2_call[2] = byte_read(0x2022);

phone2_call[3] = byte_read(0x2023); phone2_call[4] = byte_read(0x2024); phone2_call[5] = byte_read(0x2025); phone2_call[6] = byte_read(0x2026); phone2_call[7] = byte_read(0x2027); phone2_call[8] = byte_read(0x2028); phone2_call[9] = byte_read(0x2029); phone2_call[10] = byte_read(0x2030); }

/**************开机自检eeprom初始化*****************/ void init_eeprom() { read_eeprom();//读电话号码 if(a_a != 22) { a_a = 22; for(i=0;i<11;i++) { phone1_call[i] = ' '; phone2_call[i] = ' '; } phone1_i = 0; phone2_i = 0; s_temp = 50; s_yanwu = 60; write_eeprom(); //保存数据 } }

/***********************18b20初始化函数*****************************/ void init_18b20() { bit q; dq = 1; //把总线拿高 delay_uint(1); //15us dq = 0; //给复位脉冲 delay_uint(80); //750us dq = 1; //把总线拿高 等待 delay_uint(10); //110us q = dq; //读取18b20初始化信号 delay_uint(20); //200us dq = 1; //把总线拿高 释放总线

}

/*************写18b20内的数据***************/ void write_18b20(uchar dat) { uchar i; for(i=0;i<8;i++) { //写数据是低位开始 dq = 0; //把总线拿低写时间隙开始 dq = dat & 0x01; //向18b20总线写数据了 delay_uint(5); // 60us dq = 1; //释放总线 dat >>= 1; } }

/*************读取18b20内的数据***************/ uchar read_18b20() { uchar i,value; for(i=0;i<8;i++) { dq = 0; //把总线拿低读时间隙开始 value >>= 1; //读数据是低位开始 dq = 1; //释放总线 if(dq == 1) //开始读写数据 value |= 0x80; delay_uint(5); //60us 读一个时间隙最少要保持60us的时间 } return value; //返回数据 }

/*************读取温度的值 读出来的是小数***************/ uint read_temp() { uint value; uchar low; //在读取温度的时候如果中断的太频繁了,就应该把中断给关了,否则会影响到18b20的时序 init_18b20(); //初始化18b20 write_18b20(0xcc); //跳过64位ROM write_18b20(0x44); //启动一次温度转换命令 delay_uint(50); //500us init_18b20(); //初始化18b20

write_18b20(0xcc); //跳过64位ROM write_18b20(0xbe); //发出读取暂存器命令 EA = 0; low = read_18b20(); //读温度低字节 value = read_18b20(); //读温度高字节 EA = 1; value <<= 8; //把温度的高位左移8位 value |= low; //把读出的温度低位放到value的低八位中 value *= 0.0625; //转换到温度值 return value; //返回读出的温度 }

/***********读数模转换数据********************************************************/

//请先了解ADC0832模数转换的串行协议,再来读本函数,主要是对应时序图来理解,本函数是模拟0832的串行协议进行的 // 1 0 0 通道 // 1 1 1 通道 unsigned char ad0832read(bit SGL,bit ODD) { unsigned char i=0,value=0,value1=0; SCL=0; DO=1; CS=0; //开始 SCL=1; //第一个上升沿 SCL=0; DO=SGL; SCL=1; //第二个上升沿 SCL=0; DO=ODD; SCL=1; //第三个上升沿 DO=1; for(i=0;i<8;i++) { SCL=1; SCL=0; //开始从第四个下降沿接收数据 value<<=1; if(DO) value++; } for(i=0;i<8;i++)


基于单片机的智能火灾报警系统设计源程序代码.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:MFC

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: