找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4554|回复: 0
收起左侧

温度计数码管显示proteus仿真与单片机源码

[复制链接]
ID:291942 发表于 2018-3-14 18:44 | 显示全部楼层 |阅读模式
四位数码管显示仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.png 0.png

单片机源程序如下:
  1. #include <reg52.h>                 //调用单片机头文件
  2. #define uchar unsigned char  //无符号字符型 宏定义        变量范围0~255
  3. #define uint  unsigned int         //无符号整型 宏定义        变量范围0~65535

  4. //数码管段选定义      0     1    2    3    4    5           6          7          8           9       
  5. uchar code smg_du[]={0x28,0xee,0x32,0xa2,0xe4,0xa1,0x21,0xea,0x20,0xa0,
  6.                                            0x60,0x25,0x39,0x26,0x31,0x71,0xff};         
  7. //数码管位选定义
  8. uchar code smg_we[]={0x80,0x40,0x20,0x10};
  9. uchar dis_smg[8] = {0x28,0xee,0x32,0xa2,0xe4,0x92,0x82,0xf8};       
  10. uchar smg_i = 3;    //显示数码管的个位数
  11. sbit dq   = P2^4;        //18b20 IO口的定义

  12. uint temperature ;  
  13. bit flag_300ms ;
  14. uchar menu_1;  
  15. uint t_high = 300,t_low = 100;
  16. uint number;

  17. /***********************1ms延时函数*****************************/
  18. void delay_1ms(uint q)
  19. {
  20.         uint i,j;
  21.         for(i=0;i<q;i++)
  22.                 for(j=0;j<120;j++);
  23. }

  24. /***********************小延时函数*****************************/
  25. void delay_uint(uint q)
  26. {
  27.         while(q--);
  28. }


  29. /***********************数码显示函数*****************************/
  30. void display()
  31. {
  32.         static uchar i;   
  33.         i++;
  34.         if(i >= smg_i)
  35.                 i = 0;       
  36.         P1 = 0xff;                             //消隐
  37.         P3 = smg_we[i];                          //位选
  38.         P1 = dis_smg[i];                 //段选                
  39. }



  40. /***********************DS18B20初始化函数*****************************/
  41. void init_18b20()
  42. {
  43.         bit q;
  44.         dq = 1;                                //把总线拿高
  45.         delay_uint(1);            //15us
  46.         dq = 0;                                //给复位脉冲
  47.         delay_uint(80);                //750us
  48.         dq = 1;                                //把总线拿高 等待
  49.         delay_uint(10);                //110us
  50.         q = dq;                                //读取18b20初始化信号
  51.         delay_uint(20);                //200us
  52.         dq = 1;                                //把总线拿高 释放总线
  53. }

  54. /*************写DS18B20内的数据***************/
  55. void write_18b20(uchar dat)
  56. {
  57.         uchar i;
  58.         for(i=0;i<8;i++)
  59.         {
  60.                 dq = 0;                              //把总线拿低写时间隙开始
  61.                 dq = dat & 0x01; //向18b20总线写数据了
  62.                 delay_uint(5);         // 60us
  63.                 dq = 1;                             //释放总线
  64.                 dat >>= 1;
  65.         }       
  66. }

  67. /*************读取DS18B20内的数据***************/
  68. uchar read_18b20()
  69. {
  70.         uchar i,value;
  71.         for(i=0;i<8;i++)
  72.         {
  73.                 dq = 0;                            //把总线拿低读时间隙开始
  74.                 value >>= 1;         //读数据是低位开始
  75.                 dq = 1;                           //释放总线
  76.                 if(dq == 1)                 //开始读写数据
  77.                         value |= 0x80;
  78.                 delay_uint(5);//60us        读一个时间隙最少要保持60us的时间
  79.         }
  80.         return value;                 //返回数据
  81. }

  82. /*************读取温度的值***************/
  83. uint read_temp()
  84. {
  85.         uint value;
  86.         uchar low;
  87.         init_18b20();                        //初始化18b20
  88.         EA = 0;
  89.         write_18b20(0xcc);
  90.         write_18b20(0x44);           //启动一次温度转换命令
  91.         EA = 1;
  92.         delay_uint(50);                    //500us

  93.         init_18b20();                     //初始化18b20
  94.        
  95.         EA = 0;
  96.         write_18b20(0xcc);           //跳过64位ROM
  97.         write_18b20(0xbe);           //发出读取暂存器命令
  98.        
  99.         low = read_18b20();           //读温度低字节
  100.         value = read_18b20();  //读温度高字节
  101.         EA = 1;
  102.         value <<= 8;                      //把温度的高位左移8位
  103.         value |= low;                      //把读出的温度低位放到value的低八位中
  104.         value *= 0.625;              //转换到温度值 小数
  105.         return value;                      //返回读出的温度 带小数
  106. }

  107.                

  108. /****************主函数***************/
  109. void main()
  110. {
  111.         P0 = P1 = P2 = P3 = 0xff;
  112.         temperature = read_temp();                             //读温度值
  113.         delay_1ms(650);                               
  114. ……………………

  115. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
温度计.rar (81.7 KB, 下载次数: 48)
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表