找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机智能温控风扇程序Proteus仿真原理图 18B20+直流电机

[复制链接]
ID:660969 发表于 2022-4-9 15:55 | 显示全部楼层 |阅读模式
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
51hei.gif

单片机源程序如下:
  1. #include <reg51.h>               
  2. unsigned char code seg7code[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
  3.                        0x07,0x7f,0x6f};
  4. code unsigned char seg7codeB[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,
  5.                                0xfd,0x87,0xff,0xef,0x00}; //带小数点的共阴数码管段码

  6. sbit DQ=P3^5; //数据传输线接单片机的相应的引脚
  7. sbit motor = P3^0;
  8. sbit up = P3^1;
  9. sbit down = P3^2;

  10. unsigned char count0 = 50;
  11. unsigned char count1 = 0;
  12. unsigned char PWM = 50;

  13. unsigned char tempL=0;         //设全局变量
  14. unsigned char tempH=0;
  15. unsigned int sdata;                //测量到的温度的整数部分
  16. unsigned char xiaoshu1; //小数第一位
  17. unsigned char xiaoshu2; //小数第二位
  18. unsigned char xiaoshu;  //两位小数
  19. bit  fg=1;              //温度正负标志
  20. void delay(unsigned char i)
  21. {
  22.          for(i;i>0;i--);
  23. }
  24. void delay1ms(int n)
  25. {
  26.          unsigned char i;
  27.          for(i=124*n;i>0;i--);  //延时124*8+10=1002us
  28. }
  29. void Init_DS18B20(void)
  30. {
  31.         unsigned char x=0;
  32.         DQ=1; //DQ先置高
  33.         delay(8); //稍延时
  34.         DQ=0; //发送复位脉冲
  35.         delay(80); //延时(>480us)
  36.         DQ=1; //拉高数据线
  37.         delay(5); //等待(15~60us)
  38.         x=DQ; //用X的值来判断初始化有没有成功,18B20存在的话X=0,否则X=1
  39.         delay(20);
  40. }
  41. ReadOneChar(void)  //主机数据线先从高拉至低电平1us以上,再使数据线升为高电平,从而产生读信号
  42. {
  43.         unsigned char i=0; //每个读周期最短的持续时间为60us,各个读周期之间必须有1us以上的高电平恢复期
  44.         unsigned char dat=0;
  45.         for (i=8;i>0;i--) //一个字节有8位
  46.         {
  47.                 DQ=1;
  48.                 delay(1);
  49.                 DQ=0;
  50.                 dat>>=1;            //数据移位
  51.                 DQ=1;
  52.                 if(DQ)
  53.                 dat|=0x80;            //得读取数据线得到一个状态
  54.                 delay(4);
  55.         }
  56.         return(dat);
  57. }
  58. void WriteOneChar(unsigned char dat)
  59. {
  60.         unsigned char i=0; //数据线从高电平拉至低电平,产生写起始信号。15us之内将所需写的位送到数据线上,
  61.         for(i=8;i>0;i--) //在15~60us之间对数据线进行采样,如果是高电平就写1,低写0发生。
  62.         {
  63.                 DQ=0; //在开始另一个写周期前必须有1us以上的高电平恢复期。
  64.                 DQ=dat&0x01;  //按低位发送数据
  65.                 delay(5);
  66.                 DQ=1;
  67.                 dat>>=1;
  68.         }
  69.         delay(4);
  70. }
  71. void ReadTemperature(void)
  72. {
  73.         Init_DS18B20(); //初始化
  74.         WriteOneChar(0xcc); //跳过读序列号的操作
  75.         WriteOneChar(0x44); //启动温度转换
  76.         delay(125); //转换需要一点时间,延时
  77.         Init_DS18B20(); //初始化
  78.         WriteOneChar(0xcc); //跳过读序列号的操作
  79.         WriteOneChar(0xbe); //读温度寄存器(头两个值分别为温度的低位和高位)
  80.         tempL=ReadOneChar(); //读出温度的低位LSB
  81.         tempH=ReadOneChar(); //读出温度的高位MSB
  82.         
  83.         if(tempH>0x7f)      //最高位为1时温度是负
  84.         {
  85.                  tempL=~tempL;         //补码转换,取反加一
  86.                  tempH=~tempH+1;      
  87.                  fg=0;      //读取温度为负时fg=0
  88.         }
  89.         sdata = tempL/16+tempH*16;      //整数部分
  90.         xiaoshu1 = (tempL&0x0f)*10/16; //小数第一位
  91.         xiaoshu2 = (tempL&0x0f)*100/16%10;//小数第二位
  92.         xiaoshu=xiaoshu1*10+xiaoshu2; //小数两位
  93. }
  94. void Led(unsigned int date)
  95. {
  96.         P1=0xfb;     //P1.0=0,选通第一位
  97.         P0=seg7code[date/10];  //十位数,查表,输出
  98.         delay1ms(1);

  99.         P1=0xfd;     //P1.1=0,选通第二位,个位数
  100.         P0=seg7codeB[date%10];
  101.         delay1ms(1);
  102.          
  103.         P1=0xfe;     //P1.2=0,选通第三位,小数点第一位
  104.         P0=seg7code[xiaoshu1];
  105.         delay1ms(1);

  106.                 P1=0xf7;     //P1.3=0,选通第四位
  107.         P0=0x58;
  108.         delay1ms(1);
  109. }

  110. void main()
  111. {         
  112.         unsigned int i;
  113.         while(1)
  114.         {
  115.             ReadTemperature();
  116.             for(i=0;i<20;i++)
  117.             {
  118.                     Led(sdata);        
  119.             }
  120.         }
  121. }

  122. void Timer0_int(void) interrupt 1
  123. {
  124.         TR0 = 0;
  125.         TL0 = (65536-1000) % 256;
  126.         TH0 = (65536-1000) / 256 ;
  127.         TR0 = 1;
  128.         if(++count1 < count0)
  129.   {
  130.     PWM = 1;
  131.   }
  132.     else
  133.     PWM = 0;

  134.     if(count1 >= 100)
  135.     {
  136.     count1=0;
  137.     }
  138. }
复制代码

Keil代码与Proteus仿真2个文件下载:
仿真代码.7z (676.96 KB, 下载次数: 60)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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