ImageVerifierCode 换一换
格式:DOCX , 页数:12 ,大小:140.09KB ,
资源ID:8614985      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-8614985.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(ds18b20 C程序proteus仿真Word格式.docx)为本站会员(b****6)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

ds18b20 C程序proteus仿真Word格式.docx

1、 else disp0=temp/100; disp1=temp/10-disp0*10; if(!disp0) /百位数不为0则显示,若要显示0,可将其注释掉 disp0=10; /3、显示*/ Seg_Display(disp); Lib51v3.cvoid Delay_Nus (unsigned char n) while(n-); /for (;n0;n-);18b20.c:/* 时序很重要,移植时注意延时函数*/#define B20_PORT P1 /此处可以设置I/O口#define B20_CHANNEL 0#define R_B20_CHANNEL() B20_PORT&(1

2、B20_CHANNEL)#define W_B20_CHANNEL_1() B20_PORT|=(1#define W_B20_CHANNEL_0() B20_PORT&=(1#define SKIP_ROM 0xCC#define TEMPUTER_CONVERT 0x44#define READ_ROM 0xBE/one/*初始化函数,失败会返回1,初始化过程见注释若单片机读到了数据线上的低电平“0”后,还要做延时,其延时的时间从单片机发出的高电平算起最少要480微秒。之后单片机将数据线再次拉高到高电平“1”后结束。*/static unsigned char Init_18b20 (vo

3、id) unsigned char x=0; W_B20_CHANNEL_1(); /1、从单片机拉高数据线开始 Delay_Nus(8); /6*n useconds lib51v3.c W_B20_CHANNEL_0(); Delay_Nus(81); /2、单片机拉低数据线480us以上,拉高数据线,释放 Delay_Nus(14); /3、之后ds18b20,1560us以后反应,拉高数据线 x=R_B20_CHANNEL(); /4、单片机读取数据线if(x) return x; Delay_Nus(20); /x=0代表复位成功/twostatic void Write_18b20

4、(unsigned char w_data) unsigned char i; unsigned char temp; for(i=0;i8;i+) W_B20_CHANNEL_1(); temp=w_data&0); W_B20_CHANNEL_0(); /单片机从高到低,拉低1us以上,并在15us内产生写间隙 B20_PORT=temp=1; Delay_Nus(4);/threestatic unsigned char Read_18b20(void) unsigned char r_data=0x00; r_data /从高到低15us内,再到高,产生读间隙 Delay_Nus(1)

5、; temp=B20_PORT(7-B20_CHANNEL); /读数据,从低位开始 temp&=(17); r_data+=temp; Delay_Nus(8); /整个读一位过程在60120us return r_data;/four若要读出当前的温度数据我们需要执行两次工作周期,第一个周期为复位、跳过ROM指令、执行温度转换存储器操作指令、等待500uS温度转换时间。紧接着执行第二个周期为复位、跳过ROM指令、执行读RAM的存储器操作指令、读数据(最多为9个字节,中途可停止,只读简单温度值则读前2个字节即可)signed char Get_Temputer (void)/读取温度值,返回

6、的带符号字符型-55到+127;128无法显示,初始化失败会显示00.C unsigned char tem_h,tem_l; signed char temp; if(Init_18b20()=0) /复位18b20 Write_18b20(SKIP_ROM); /跳过ROM Write_18b20(TEMPUTER_CONVERT); /温度变换 else return temp=0; /Delay_Nus(100); if(Init_18b20()=0) /复位18b20 /跳过ROM Write_18b20(READ_ROM); /读暂存存储器 tem_l=Read_18b20();

7、/读数据 tem_h=Read_18b20();只要高字符的低四位和低字符的高四位,温度范围099,temp为补码,直接由unsigned char 赋值给 signed char 内容不变,代表的值改变temp=(tem_h4); return temp;Segv3.c:#define COMMON_ANODIC 0 /共阳数码管#define COMMON_CATHODAL 1 /共阴数码管#define SEG_CATEGORY 0 /选择共阳数码管#define SEG8_A (10) /段A亮时为0,属共阳数码管#define SEG8_B (11)#define SEG8_C (1

8、2)#define SEG8_D (13)#define SEG8_E (14)#define SEG8_F (15)#define SEG8_G (16)#define SEG8_DP (17) #define SEG8_CHAR_0 (SEG8_G&SEG8_DP) #define SEG8_CHAR_1 (SEG8_A&SEG8_D&SEG8_E&SEG8_F&SEG8_G&SEG8_DP)#define SEG8_CHAR_2 (SEG8_C&#define SEG8_CHAR_3 (SEG8_E&#define SEG8_CHAR_4 (SEG8_A&#define SEG8_CHA

9、R_5 (SEG8_B&#define SEG8_CHAR_6 (SEG8_B&#define SEG8_CHAR_7 (SEG8_D&#define SEG8_CHAR_8 SEG8_DP#define SEG8_CHAR_9 (SEG8_E&#define SEG8_CHAR_ 0#define SEG8_CHAR_E (SEG8_B&SEG8_C&#define SEG8_CHAR_R (SEG8_A&SEG8_B&#define SEG8_CHAR_SUB (SEG8_A&/#define SEG8_CHAR_A/#define SEG8_CHAR_B#define SEG8_CHAR

10、_C (SEG8_B&/#define SEG8_CHAR_D/#define SEG8_CHAR_F/#define SEG8_CHAR_H#if SEG_CATEGORY=COMMON_ANODIC static const unsigned char SEG8_CODE= SEG8_CHAR_0, SEG8_CHAR_1, SEG8_CHAR_2, SEG8_CHAR_3, SEG8_CHAR_4, SEG8_CHAR_5, SEG8_CHAR_6, SEG8_CHAR_7, SEG8_CHAR_8, SEG8_CHAR_9, SEG8_CHAR_, /SEG8_CODE10 SEG8_

11、CHAR_E, /SEG8_CODE11 SEG8_CHAR_R, /SEG8_CODE12 SEG8_CHAR_SUB, /SEG8_CODE13 SEG8_CHAR_C /SEG8_CODE14 ;#else SEG8_CHAR_0, SEG8_CHAR_1, SEG8_CHAR_2, SEG8_CHAR_3, SEG8_CHAR_4, SEG8_CHAR_5, SEG8_CHAR_6, SEG8_CHAR_7, SEG8_CHAR_8, SEG8_CHAR_9, SEG8_CHAR_, /SEG8_CODE10 SEG8_CHAR_E, /SEG8_CODE11 SEG8_CHAR_R,

12、 /SEG8_CODE12 SEG8_CHAR_SUB, /SEG8_CODE13 SEG8_CHAR_C /SEG8_CODE14 ;#endif#define SEG8_SLECT_PORT P3 /此处可以设置I/O口#define BIT0 0 #define BIT1 1#define BIT2 2#define BIT3 3#define SEG8_BIT0_ON() SEG8_SLECT_PORT|=(1BIT0)#define SEG8_BIT0_OFF() SEG8_SLECT_PORT&#define SEG8_BIT1_ON() SEG8_SLECT_PORT|=(1BI

13、T1)#define SEG8_BIT1_OFF() SEG8_SLECT_PORT&#define SEG8_BIT2_ON() SEG8_SLECT_PORT|=(1BIT2)#define SEG8_BIT2_OFF() SEG8_SLECT_PORT&#define SEG8_BIT3_ON() SEG8_SLECT_PORT|=(1BIT3)#define SEG8_BIT3_OFF() SEG8_SLECT_PORT&#define SEG8_CODE_PORT P2 /此处可以设置I/O口void Seg_Display (char *p) unsigned char temp4

14、; temp0=SEG8_CODE*p+; temp1=SEG8_CODE*p+; temp2=SEG8_CODE*p+; temp3=SEG8_CODE*p+; if(*p #if SEG_CATEGORY=COMMON_ANODIC temp*p&=SEG8_DP; #else temp*p|=SEG8_DP; #endif unsigned char i; for(i=0;150;i+) SEG8_CODE_PORT = temp0; SEG8_BIT0_ON(); Delay_Nus(6); /lib51v1.c SEG8_BIT0_OFF(); SEG8_CODE_PORT = temp1; SEG8_BIT1_ON(); SEG8_BIT1_OFF(); SEG8_CODE_PORT = temp2; SEG8_BIT2_ON(); SEG8_BIT2_OFF(); SEG8_CODE_PORT = temp3; SEG8_BIT3_ON(); SEG8_BIT3_OFF(); (此文档部分内容来源于网络,如有侵权请告知删除,文档可自行编辑修改内容,供参考,感谢您的配合和支持)

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2