找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1243|回复: 1
打印 上一主题 下一主题
收起左侧

单片机灭火小车程序 根据L298n驱动,+风扇进行一路的感应灭火

[复制链接]
跳转到指定楼层
楼主
ID:811102 发表于 2020-12-22 09:34 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include<reg52.h>
  2. #include <intrins.h>

  3. /********IO引脚定义***********************************************************/
  4. sbit SPK=P3^7;                        //蜂鸣器驱动引脚

  5. sbit LED1=P0^0;                        //LED
  6. sbit LED2=P0^1;                        //

  7. sbit gy=P1^2;                        //光敏电阻 右
  8. sbit g0=P1^3;                        //         中
  9. sbit gz=P1^4;                        //         左

  10. sbit d1=P1^0;                        //对管 右  黑线高电平(==1)
  11. sbit d2=P1^1;                        //     左

  12. sbit a1=P2^0;                        //电机驱动
  13. sbit a2=P2^1;
  14. sbit b1=P2^2;
  15. sbit b2=P2^3;

  16. sbit f1=P2^4;                        //风扇驱动
  17. sbit f2=P2^5;                        //

  18. /************************************************
  19.              延时函数
  20. ************************************************/
  21. void DelayMs(unsigned int timer)   //参数 整型timer 大小范围 0-65536,决定延时时间长短
  22. {
  23.         int x,y;
  24.         for(x=timer;x>0;x--)
  25.                 for(y=120;y>0;y--);
  26. }

  27. /************************************************
  28. 电机转动函数定义
  29. ************************************************/

  30. /*** 前进 ***/
  31. void QianJin()
  32. {
  33.          a1=0;
  34.          a2=1;
  35.          b1=0;
  36.          b2=1;
  37. }
  38. /*** 后退***/
  39. void HaoDu()
  40. {
  41.          a1=1;
  42.          a2=0;
  43.          b1=1;
  44.          b2=0;
  45. }
  46. /*** 左转 ***/
  47. void ZuoZhuan()
  48. {         
  49.          a1=1;
  50.          a2=0;
  51.          b1=0;
  52.          b2=1;
  53. }
  54. /*** 右转 ***/  
  55. void YouZhuan()
  56. {
  57.         a1=0;
  58.         a2=1;
  59.         b1=1;
  60.         b2=0;  
  61. }
  62. /*** 停止 ***/
  63. void Stop()
  64. {  
  65.          a1=1;
  66.          a2=1;
  67.          b1=1;
  68.          b2=1;
  69. }

  70. /************************************************
  71.             风扇函数定义
  72. ************************************************/
  73. void Feng()
  74. {
  75.         f1=1;f2=0;
  76.         DelayMs(3000);//风扇转3秒
  77.         f1=1;f2=1;
  78.         SPK=0;
  79.         DelayMs(1000);
  80.         SPK=1;
  81. }
  82. /************************************************
  83.            循迹子程序
  84. ************************************************/
  85. void xunjin()
  86. {
  87.                  Stop();
  88.                   LED1=1;LED2=1;
  89.                         while(d1==0&&d2==0)
  90.                         {
  91.                                         LED1=1;LED2=1;
  92.                                   QianJin();
  93.                         }
  94.                         
  95.                   while(d1==1&&d2==0)
  96.                         {   LED1=0;
  97.                                         YouZhuan();DelayMs(200);
  98.                         }
  99.                         
  100.                         while(d1==0&&d2==1)
  101.                         {   LED2=0;
  102.                                         ZuoZhuan();DelayMs(200);
  103.                         }        
  104.                         
  105.                         while(d1==1&&d2==1)
  106.                         {
  107.                                         Stop();LED1=1;LED2=1;
  108.                         }        
  109. }

  110. /*
  111. ******************************************************************************************
  112. ** 函数名称: main
  113. ** 函数功能: 主函数
  114. ** 入口参数: 无
  115. ** 出口参数: 无
  116. ******************************************************************************************
  117. */
  118. void main()
  119. {        

  120.   while(1)
  121.         {  
  122.                
  123.                   Stop();
  124.                   LED1=1;LED2=1;
  125.                         while(d1==0&&d2==0)//两个对管检测到白纸前进
  126.                         {
  127.                                         LED1=1;LED2=1;
  128.                                   QianJin();
  129.                                  
  130.                                          /*如果右边光敏检测到光源右转对准光源则前往光源执行灭火程序 */                                 
  131.                                         if(gy==0){
  132.                                                                                         while(g0==1)YouZhuan();DelayMs(50);
  133.                                                                                         QianJin();DelayMs(2000);//前进距离
  134.                                                                                         Stop();
  135.                                                           Feng();//如果灭灯模拟灭火则用while(g0==0){f1=1;f2=0;}f1=1;f2=1;SPK=0;DelayMs(1000);SPK=1;
  136.                                                                                         while(d1==0&&d2==0)HaoDu();
  137.                                                                                         QianJin();DelayMs(500);
  138.                                                                                         while(d1==0)ZuoZhuan();
  139.                                                                 while(1)xunjin();
  140.                                                                                  }
  141.                                          /*如果左边光敏检测到光源右转对准光源则前往光源执行灭火程序 */                                 
  142.                                         if(gz==0){
  143.                                                                                         while(g0==1)ZuoZhuan();DelayMs(50);
  144.                                                                                         QianJin();DelayMs(2000);//前进距离
  145.                                                                                         Stop();
  146.                                                           Feng();//如果灭灯模拟灭火则用while(g0==0){f1=1;f2=0;}f1=1;f2=1;SPK=0;DelayMs(1000);SPK=1;
  147.                                                                                         while(d1==0&&d2==0)HaoDu();
  148.                                                                                         QianJin();DelayMs(500);
  149.                                                                                         while(d2==0)YouZhuan();
  150.                                                                 while(1)xunjin();
  151.                                                                                  }                                         
  152.                                                 
  153.                                                                                                          
  154.                         }
  155.                         
  156.                   while(d1==1&&d2==0)//右对管检测到黑线右转
  157.                         {   LED1=0;
  158.                                         YouZhuan();DelayMs(200);
  159.                         
  160.                         }
  161.                         
  162.                         while(d1==0&&d2==1)//左对管检测到黑线左转
  163.                         {                LED2=0;
  164.                                         ZuoZhuan();DelayMs(200);
  165.                         }        
  166.                         
  167.                         while(d1==1&&d2==1)//两个对管检测到黑线停止
  168.                         {
  169.                                         Stop();LED1=1;LED2=1;
  170.                         }        
  171.                         
  172.          }

  173.         
  174. }

复制代码


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:1 发表于 2020-12-22 15:04 | 只看该作者
本帖需要重新编辑补全电路原理图,源码,详细说明与图片即可获得100+黑币(帖子下方有编辑按钮)
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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