arduino通过红外遥控和蜂鸣器制作一个小闹钟程序

30 篇文章 49 订阅

本人最近在学习arduino,利用空闲时间制作一些小程序来自娱自乐,也和大家一起交流分享

本次arduino遥控器控制全彩灯珠主要是用到两个名为Timer库和IRremote库,你可以在https://download.csdn.net/download/m0_37738838/10645108下载到这两个库文件及下面提到的源码案例。

#include "Timer.h"        //计时器头文件
Timer t;                //计时器对象
int PIN_RECV = 2;      //红外接收
int buzzer_pin=8;     //蜂鸣器的pin
boolean buzzer_state=true;       //蜂鸣器状态
boolean hours_state=false;      //小时设置
boolean minutes_state=false;   //分钟设置
#include <IRremote.h>        //红外头文件
IRrecv irrecv(PIN_RECV);   //pin设置为接收
decode_results results;  //解码结果
long hours=0;   //默认0小时
long minutes=600000; //默认十分钟
long Ttime;    //定时总时间
int a=1;  //count方法传入个数
void setup()
{
    Serial.begin(9600);
    irrecv.enableIRIn();           //开启红外
    pinMode(buzzer_pin,OUTPUT);   //设置蜂鸣器的pin为输出模式
}
void loop()
{
    t.update();         //必须在loop中调用,它会服务于计时器相关的事件
    if (irrecv.decode(&results)) {
      Serial.print(results.value,HEX);
     switch(results.value)
    {
        //2
      case 0xFF629D:
      setTime();//进入闹钟模式
        break;
    }
    irrecv.resume();
  }
}
void callbackfun(){
  boolean state = true;
  while(state){
        for(int i=0;i<80;i++)//输出一个频率的声音
        {
            digitalWrite(buzzer_pin,HIGH);//发声音
            delay(1);//延时1ms
            digitalWrite(buzzer_pin,LOW);
            delay(1);
        }
         for(int i=0;i<100;i++)//输出另一个频率的声音,这里的100与前面的80一样,用来控制频率,可以自己调节
        {
          digitalWrite(buzzer_pin,HIGH);
          delay(2);
          digitalWrite(buzzer_pin,LOW);
          delay(2);
        }
        if (irrecv.decode(&results)) {
          if(results.value==0xFF9867) {
            state=false;
          }
        }
}
}
void  setTime(){            //unsigned long 0-4,294,967,295
  boolean settime_state = true; //定时状态

   while(settime_state){
          if (irrecv.decode(&results)) {
                 switch(results.value){
                    //*
                  case 0xFF6897:Hours();break;
                    //#
                  case 0xFFB04F:Minutes();break;
                    //OK
                  case 0xFF38C7:StarClock();settime_state = false;break;
                }
          irrecv.resume();
    }
   }
}
void Hours(){   //小时
  Serial.println(111);
  boolean hours_state = true; 
  while(hours_state){
        if (irrecv.decode(&results)) {
          switch(results.value){
               //1
            case 0xFFA25D:hours=3600000;break;
              //2 
            case 0xFF629D:hours=7200000;break;
              //3
            case 0xFFE21D:hours=10800000;break;
              //4
            case 0xFF22DD:hours=14400000;break;
              //5
            case 0xFF02FD:hours=18000000;break;
              //6
            case 0xFFC23D:hours=21600000;break;
              //7
            case 0xFFE01F:hours=25200000;break;
              //8
            case 0xFFA857:hours=28800000;break;
              //9
            case 0xFF906F:hours=32400000;break;
              //0
           case 0xFF9867:hours=0;break;
           //OK
           case 0xFF38C7:hours_state = false;break;
          }
    irrecv.resume();
     }
  }
    Serial.println(333);
}
void Minutes(){    //分钟
  boolean minutes_state = true; 

  while(minutes_state){
     if (irrecv.decode(&results)) {
          switch(results.value){
                  //1
                case 0xFFA25D:count(1);break;
                  //2 
                case 0xFF629D:count(2);break;
                  //3
                case 0xFFE21D:count(3);break;
                  //4
                case 0xFF22DD:count(4);break;
                  //5
                case 0xFF02FD:count(5);break;
                  //6
                case 0xFFC23D:count(6);break;
                  //7
                case 0xFFE01F:count(7);break;
                  //8
                case 0xFFA857:count(8);break;
                  //9
                case 0xFF906F:count(9);break;
                  //0
               case 0xFF9867:count(0);break;
                //OK
               case 0xFF38C7:minutes_state = false;a=1;break;
          }
    irrecv.resume();
     }
  }
}
void StarClock(){       //开始定时
  Ttime = hours+minutes;
 t.after(Ttime,callbackfun);   //1000mm=1s   60000=1min;
 Serial.println(Ttime);
 Serial.println(666);

}
void count(int num){
  Serial.println(num);
  if(a==1){minutes = 60000 * num;a++;}    
  else if(a==2){int shi =minutes*10 ;int ge = 6000*num; minutes = shi + ge;a++;}  
  Serial.println(minutes);
}


我的红外接收引脚是D2,蜂鸣器信号引脚是D8。要准备好一个红外接收模块,一个红外遥控器,一个蜂鸣器以及一张arduino板。

使用定时闹钟时,先按下遥控器2,进入闹钟设置功能,按下*键则设置时钟时间,将我们要设置的时间0~9遥控输入,按下OK键表示确定,接下来设置分钟时间,按下#键后将我们要设置的时间0~9遥控输入,按下OK键表示确定,最后确认按下OK,这样arduino开始执行我们的定时闹钟的程序啦

当然因为我们的遥控器版本不一样,所以大家首先先将自己的遥控器编码输出来,修改一下红外接收部分的代码便可用啦,如果我们想在更好玩一点,可以在蜂鸣器上花点心思,通过音乐的节拍来设计蜂鸣器的声响,这样就更有意思了

  • 9
    点赞
  • 80
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
好的,你可以使用红外遥控器模块和一个蜂鸣器模块来实现这个功能。 首先,你需要连接红外遥控器模块和 Arduino 板。可以参考这个红外遥控器模块的连接图: ![红外遥控器模块连接图](https://img-blog.csdnimg.cn/20210729153200401.png) 接下来,你需要连接蜂鸣器模块。可以参考这个蜂鸣器模块的连接图: ![蜂鸣器模块连接图](https://img-blog.csdnimg.cn/20210729153224395.png) 接下来,你需要下载并安装红外遥控器库和蜂鸣器库。可以在 Arduino IDE 中使用 "Sketch->Include Library->Manage Libraries" 来搜索和安装这些库。 然后,你可以使用下面的代码来控制蜂鸣器开关: ```C++ #include <IRremote.h> // 引入红外遥控器库 #include <toneAC.h> // 引入蜂鸣器库 int RECV_PIN = 11; // 红外遥控器模块连接到Arduino的11号引脚 int buzzerPin = 9; // 蜂鸣器模块连接到Arduino的9号引脚 IRrecv irrecv(RECV_PIN); decode_results results; void setup() { irrecv.enableIRIn(); // 初始化红外接收模块 pinMode(buzzerPin, OUTPUT); // 设置蜂鸣器引脚为输出模式 } void loop() { if (irrecv.decode(&results)) { if (results.value == 0xFF6897) { // 如果接收到红外码为0xFF6897 toneAC(buzzerPin, 1000, 500); // 播放1000Hz的蜂鸣声500毫秒 delay(500); // 延时500毫秒 noToneAC(buzzerPin); // 停止播放蜂鸣声 } irrecv.resume(); // 继续接收红外信号 } } ``` 在这个代码中,我们使用了 `IRremote` 库和 `toneAC` 库来实现红外遥控器和蜂鸣器的控制。在 `setup()` 函数中,我们初始化了红外接收模块和设置了蜂鸣器引脚为输出模式。在 `loop()` 函数中,我们使用 `irrecv.decode(&results)` 函数来接收红外信号,并判断接收到的红外码是否为0xFF6897。如果接收到了这个红外码,我们就使用 `toneAC` 函数来播放1000Hz的蜂鸣声500毫秒,并在播放完毕后使用 `noToneAC` 函数来停止播放蜂鸣声。最后,我们使用 `irrecv.resume()` 函数来继续接收红外信号。 希望这个代码可以帮助你实现你的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沸腾石灰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值