找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7508|回复: 9
收起左侧

51单片机智能温控风扇Proteus仿真+程序

  [复制链接]
1063941314li 发表于 2019-5-8 08:11 | 显示全部楼层 |阅读模式
用51单片机通过外界环境温度控制风扇的转速。话不多说,直接上图;

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.png

程序

程序

程序

程序

总体

总体


单片机源程序如下:
  1. #include<reg51.h>
  2. #include<intrins.h>                         //包含头文件
  3. #define uchar unsigned char
  4. #define uint unsigned int                 //宏定义
  5. ////////////////////
  6. sbit dj=P1^0;//电机控制端接口
  7. sbit DQ=P1^6;//温度传感器接口
  8. //////////按键接口/////////////////////////////////
  9. sbit key1=P3^5;//设置温度
  10. sbit key2=P3^6;//温度加
  11. sbit key3=P3^7;//温度减
  12. //////////////////////////////////////////////////////
  13. sbit w1=P2^4;
  14. sbit w2=P2^5;
  15. sbit w3=P2^6;
  16. sbit w4=P2^7;                          //数码管的四个位
  17. /////共阴数码管段选//////////////////////////////////////////////
  18. uchar table[22]=
  19. {0x3F,0x06,0x5B,0x4F,0x66,
  20. 0x6D,0x7D,0x07,0x7F,0x6F,
  21. 0x77,0x7C,0x39,0x5E,0x79,0x71,
  22. 0x40,0x38,0x76,0x00,0xff,0x37};//'-',L,H,灭,全亮,n         16-21
  23. uint wen_du;                                                //温度变量  
  24. uint shang,xia; //对比温度暂存变量
  25. uchar dang;//档位显示
  26. uchar flag;
  27. uchar d1,d2,d3;//显示数据暂存变量
  28. void delay(uint ms)                //延时函数,大约延时25us
  29. {
  30.         uchar x;
  31.         for(ms;ms>0;ms--)
  32.                 for(x=10;x>0;x--);
  33. }
  34. /***********ds18b20延迟子函数(晶振12MHz )*******/
  35. void delay_18B20(uint i)
  36. {
  37.         while(i--);
  38. }
  39. /**********ds18b20初始化函数**********************/
  40. void Init_DS18B20()
  41. {
  42.          uchar x=0;
  43.          DQ=1;          //DQ复位
  44.          delay_18B20(8);  //稍做延时
  45.          DQ=0;          //单片机将DQ拉低
  46.          delay_18B20(80); //精确延时 大于 480us
  47.          DQ=1;          //拉高总线
  48.          delay_18B20(14);
  49.          x=DQ;            //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
  50.          delay_18B20(20);
  51. }
  52. /***********ds18b20读一个字节**************/  
  53. uchar ReadOneChar()
  54. {
  55.         uchar i=0;
  56.         uchar dat=0;
  57.         for (i=8;i>0;i--)
  58.          {
  59.                   DQ=0; // 给脉冲信号
  60.                   dat>>=1;
  61.                   DQ=1; // 给脉冲信号
  62.                   if(DQ)
  63.                   dat|=0x80;
  64.                   delay_18B20(4);
  65.          }
  66.         return(dat);
  67. }
  68. /*************ds18b20写一个字节****************/  
  69. void WriteOneChar(uchar dat)
  70. {
  71.         uchar i=0;
  72.         for (i=8;i>0;i--)
  73.         {
  74.                   DQ=0;
  75.                 DQ=dat&0x01;
  76.             delay_18B20(5);
  77.                 DQ=1;
  78.             dat>>=1;
  79.         }
  80. }
  81. /**************读取ds18b20当前温度************/
  82. void ReadTemperature()
  83. {
  84.         uchar a=0;
  85.         uchar b=0;
  86.         uchar t=0;
  87.         Init_DS18B20();
  88.         WriteOneChar(0xCC);            // 跳过读序号列号的操作
  89.         WriteOneChar(0x44);         // 启动温度转换
  90.         delay_18B20(100);       // this message is wery important
  91.         Init_DS18B20();
  92.         WriteOneChar(0xCC);         //跳过读序号列号的操作
  93.         WriteOneChar(0xBE);         //读取温度寄存器等(共可读9个寄存器) 前两个就是温度
  94.         delay_18B20(100);
  95.         a=ReadOneChar();            //读取温度值低位
  96.         b=ReadOneChar();                   //读取温度值高位
  97.         wen_du=((b*256+a)>>4);    //当前采集温度值除16得实际温度值
  98. }
  99. void display()//显示温度
  100. {
  101.         w1=0;P0=table[d1];delay(10); //第1位
  102.         P0=0x00;w1=1;delay(1);
  103.          
  104.         w2=0;P0=table[16];delay(10);//第2位
  105.         P0=0x00;w2=1;delay(1);

  106.         w3=0;P0=table[d2]; delay(10);//第3位
  107.         P0=0x00;w3=1;delay(1);

  108.         w4=0;P0=table[d3];delay(10);//第4位
  109.         P0=0x00;w4=1;delay(1);
  110. }
  111. void zi_keyscan()//自动模式按键扫描函数
  112. {
  113.         if(key1==0)                                                          //设置键按下
  114.         {
  115.                 delay(30);                                                  //延时去抖
  116.                 if(key1==0)flag=1;                                  //再次判断按键,按下的话进入设置状态
  117.                 while(key1==0);//松手检测                  //按键释放
  118.         }
  119.         while(flag==1)                                                  //进入设置上限状态
  120.         {
  121.                 d1=18;d2=shang/10;d3=shang%10;          //显示字母H 和上限温度值
  122.                 display();                                                  //调用显示函数
  123.                 if(key1==0)                                                  //判断设置键是否按下
  124.                 {
  125.                         delay(30);                                          //延时去抖
  126.                         if(key1==0)flag=2;                          //按键按下,进入设置下限模式
  127.                         while(key1==0);//松手检测
  128.                 }
  129.                 if(key2==0)                                                  //加键按下
  130.                 {
  131.                         delay(30);                                          //延时去抖
  132.                         if(key2==0)                                          //加键按下
  133.                         {
  134.                                 shang+=5;                                  //上限加5
  135.                                 if(shang>=100)shang=100;  //上限最大加到100
  136.                         }while(key2==0);//松手检测
  137.                 }
  138.                 if(key3==0)                                                  //减键按下
  139.                 {
  140.                         delay(30);                                          //延时去抖
  141.                         if(key3==0)                                          //减键按下
  142.                         {
  143.                                 shang-=1;                                  //上限减1
  144.                                 if(shang<=10)shang=10;          //上限最小减到10
  145.                         }while(key3==0);//松手检测
  146.                 }               
  147.         }
  148.         while(flag==2)                                                  //设置下限
  149.         {
  150.                 d1=17;d2=xia/10;d3=xia%10;                  //显示字母L 显示下限温度值
  151.                 display();                                                  //以下注释同上
  152.                 if(key1==0)
  153.                 {
  154.                         delay(30);
  155.                         if(key1==0)flag=0;
  156.                         while(key1==0);//松手检测
  157.                 }
  158.                 if(key2==0)
  159.                 {
  160.                         delay(30);
  161.                         if(key2==0)
  162.                         {
  163.                                 xia+=5;
  164.                                 if(xia>=95)xia=95;       
  165.                         }while(key2==0);//松手检测
  166.                 }
  167.                 if(key3==0)
  168.                 {
  169.                         delay(30);
  170.                         if(key3==0)
  171.                         {
  172.                                 xia-=1;
  173.                                 if(xia<=0)xia=0;       
  174.                         }while(key3==0);//松手检测
  175.                 }               
  176.         }
  177. }
  178. void zi_dong()//自动温控模式
  179. {
  180.         uchar i;
  181.         d1=dang;d2=wen_du/10;d3=wen_du%10;                //显示档位,显示当前温度值
  182.         zi_keyscan();//按键扫描函数
  183.         display();         //调用显示函数
  184.         if(wen_du<xia){dj=0;dang=0;}//低于下限  档位为0 电机停止
  185.         if((wen_du>=xia)&&(wen_du<=shang))//温度大于下限,小于上限  1挡
  186.         {
  187.                 dang=1;                                                                                        //档位置1
  188.                 for(i=0;i<3;i++){dj=0;display();zi_keyscan();}        //PWM通过延时得到
  189.                 for(i=0;i<6;i++){dj=1;display();zi_keyscan();}               
  190.         }
  191.         if(wen_du>shang){dj=1;dang=2;}//高温全速
  192. }
  193. void main()                  //主函数
  194. {
  195.         uchar j;
  196.         dj=0;                  //电机开
  197.         shang=30;
  198.         xia=20;                  //初始上下限值
  199.         for(j=0;j<80;j++)          //先读取温度值,防止开机显示85
  200.         ReadTemperature();
  201.         while(1)                          //进入while循环
  202.         {       
  203.                 ReadTemperature();        //读取温度值
  204.                 for(j=0;j<100;j++)zi_dong();//自动温控模式
  205.         }
  206. }
复制代码

所有资料51hei提供下载:
51温控风扇.zip (790.79 KB, 下载次数: 288)

评分

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

查看全部评分

回复

使用道具 举报

rrqxx 发表于 2019-5-8 22:32 | 显示全部楼层
编程实在是学不好,只好用智能温度变送器串一只100Ω电阻取样,在经过1K5Ω电阻驱动NPN三极管,风扇串联在三极管C极,通过调整智能温度变送器零点、量程来获得非常满意风扇转速调节!
回复

使用道具 举报

18595425193 发表于 2019-5-9 09:33 | 显示全部楼层
x能不能带一下材料图
回复

使用道具 举报

happyjavafish 发表于 2019-5-9 23:06 | 显示全部楼层
请问keil c 和Protues各是什么版本?
回复

使用道具 举报

2584604327 发表于 2019-5-10 09:09 来自手机 | 显示全部楼层
谢谢了  正愁找不到
回复

使用道具 举报

Jinke1 发表于 2020-6-9 11:22 | 显示全部楼层
里面没proteus仿真文件啊
回复

使用道具 举报

枫溪丶 发表于 2020-6-9 15:47 | 显示全部楼层
新来的能先给我借鉴一下么
回复

使用道具 举报

附近很好 发表于 2020-6-16 10:49 | 显示全部楼层
里面东西全不全
回复

使用道具 举报

Jeff_BlindCat 发表于 2020-6-29 12:27 | 显示全部楼层
谢谢楼主指点,给了参考思路,最近也正在琢磨这个问题,
如果有多个温度采集点,可否用串口实现编号采集?
回复

使用道具 举报

ladyboss 发表于 2021-3-15 22:29 | 显示全部楼层
下载了资料,问下怎么仿真?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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