MeowBot:ESP32 语音控制宠物猫 DIY 教程——玩转语音识别与 MQTT 智能家居控制 (附代码解析)

摘要: 本文将手把手教你打造一只名为 MeowBot 的智能宠物猫!它不仅可以通过舵机灵动地打招呼,还能听懂你的语音指令,帮你控制智能家居设备。让我们一起开启这段充满乐趣的 DIY 之旅吧!

关键词: ESP32、语音识别、MQTT、智能家居、宠物机器人

一、 引言

厌倦了冰冷的智能音箱?渴望一只既能陪伴你,又能帮你控制家居的萌宠?今天就来教你 DIY 一只基于 ESP32 的智能宠物猫 MeowBot!它能够识别你的语音指令,并通过 MQTT 协议控制智能家居设备,为你的生活增添乐趣和科技感。

二、 MeowBot 功能介绍

MeowBot 具备以下功能:

  • 打招呼: 当你靠近 MeowBot 时,它会通过舵机控制头部和尾巴摆动,并发出喵叫声,萌化你的心。
  • 语音控制: MeowBot 能听懂你的指令,例如“小猫,帮我打开灯”,然后通过 MQTT 协议发送控制指令给智能家居设备。
  • 扩展功能: MeowBot 还可以根据你的创意扩展其他功能,例如播放音乐、语音播报天气等。

三、 MeowBot 系统设计

MeowBot 的系统架构图如下所示:

 

3.1 硬件部分

MeowBot 的硬件清单如下:

  • ESP32 开发板: 作为 MeowBot 的大脑,负责接收传感器数据、处理语音指令、控制舵机和发送 MQTT 消息。
  • LD3320 语音识别模块: 用于识别用户的语音指令,将其转换为文本信息。
  • MG995 舵机 (x2): 用于控制 MeowBot 的头部和尾巴动作,使其更加生动形象。
  • HC-SR501 人体红外传感器: 用于检测是否有人靠近 MeowBot,触发打招呼动作。
  • 其他模块 (可选): OLED 显示屏、扬声器、LED 灯等,可以根据需要添加。
3.2 软件部分

MeowBot 的软件部分主要包括:

  • Arduino IDE: 用于编写和上传 ESP32 代码。
  • LD3320 库: 用于驱动 LD3320 语音识别模块。
  • PubSubClient 库: 用于 ESP32 连接 MQTT 服务器。
  • Servo 库: 用于控制舵机的转动角度。

四、 MeowBot 制作步骤

4.1 硬件连接

按照以下电路图连接各个硬件模块:

注意: 具体的引脚连接需要根据你使用的硬件模块进行调整。

4.2 软件编写
4.2.1 安装库文件

在 Arduino IDE 中,依次点击“项目”->“加载库”->“管理库”,搜索并安装以下库文件:

  • LD3320
  • PubSubClient
  • Servo
4.2.2 代码示例

 

#include <LD3320.h>
#include <WiFi.h>
#include <PubSubClient.h>
#include <Servo.h>

// WiFi 和 MQTT 设置
const char* ssid = "你的WiFi名称";
const char* password = "你的WiFi密码";
const char* mqtt_server = "你的MQTT服务器地址";
const int mqtt_port = 1883;
const char* mqtt_user = "你的MQTT用户名";
const char* mqtt_password = "你的MQTT密码";

// 定义引脚
const int headServoPin = 12;  // 头部舵机引脚
const int tailServoPin = 14;  // 尾巴舵机引脚
const int pirSensorPin = 27; // 人体红外传感器引脚

// 定义语音指令
const char* openLightCommand = "小猫,帮我打开灯";
const char* closeLightCommand = "小猫,帮我关灯";

// 创建对象
LD3320 voiceRecognition;
WiFiClient espClient;
PubSubClient mqttClient(espClient);
Servo headServo;
Servo tailServo;

// MQTT 主题
const char* lightTopic = "home/light";

// 初始化函数
void setup() {
  Serial.begin(115200);
  // 初始化语音识别模块
  voiceRecognition.init();
  voiceRecognition.setInterrupt(false);
  // 初始化舵机
  headServo.attach(headServoPin);
  tailServo.attach(tailServoPin);
  // 初始化人体红外传感器
  pinMode(pirSensorPin, INPUT);
  // 连接 WiFi
  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) {
    delay(1000);
    Serial.println("正在连接WiFi...");
  }
  Serial.println("WiFi连接成功!");
  // 连接 MQTT 服务器
  mqttClient.setServer(mqtt_server, mqtt_port);
  mqttClient.setCallback(mqttCallback);
  while (!mqttClient.connected()) {
    if (mqttClient.connect("MeowBot", mqtt_user, mqtt_password)) {
      Serial.println("MQTT连接成功!");
    } else {
      Serial.print("MQTT连接失败,错误码:");
      Serial.println(mqttClient.state());
      delay(2000);
    }
  }
}

// 主循环函数
void loop() {
  // 处理 MQTT 连接
  mqttClient.loop();
  // 检测是否有人靠近
  if (digitalRead(pirSensorPin) == HIGH) {
    greet();
  }
  // 语音识别
  if (voiceRecognition.available()) {
    String command = voiceRecognition.readVoice();
    Serial.print("识别到的指令:");
    Serial.println(command);
    // 处理语音指令
    handleCommand(command);
  }
}

// 打招呼函数
void greet() {
  // 头部和尾巴摆动
  for (int i = 0; i < 3; i++) {
    headServo.write(60);
    tailServo.write(120);
    delay(500);
    headServo.write(120);
    tailServo.write(60);
    delay(500);
  }
  // 发出喵叫声 (可选)
}

// 处理语音指令函数
void handleCommand(String command) {
  if (command == openLightCommand) {
    // 发送 MQTT 消息控制灯打开
    mqttClient.publish(lightTopic, "on");
    Serial.println("已发送打开灯的指令");
  } else if (command == closeLightCommand) {
    // 发送 MQTT 消息控制灯关闭
    mqttClient.publish(lightTopic, "off");
    Serial.println("已发送关闭灯的指令");
  } else {
    // 未识别到的指令
    Serial.println("未识别到的指令");
  }
}

// MQTT 回调函数
void mqttCallback(char* topic, byte* payload, unsigned int length) {
  // 处理接收到的 MQTT 消息
}

4.3 代码解析
  • 头文件: 代码开头的 #include 部分引入了程序所需库文件的头文件。

    • <LD3320.h>: LD3320 语音识别模块库,用于控制和读取 LD3320。
    • <WiFi.h>: ESP32 WiFi 库,用于连接 WiFi 网络。
    • <PubSubClient.h>: MQTT 客户端库,用于 ESP32 与 MQTT 服务器进行通信。
    • <Servo.h>: 舵机控制库,用于控制 MeowBot 的头部和尾巴舵机。
  • WiFi 和 MQTT 设置:

    • ssid 和 password : 存储你的 WiFi 网络名称和密码,确保 MeowBot 能够连接到你的家庭网络。
    • mqtt_servermqtt_portmqtt_usermqtt_password: MQTT 服务器的相关信息,包括地址、端口号、用户名和密码。你需要设置好自己的 MQTT 服务器,并将这些信息填写到代码中,以便 MeowBot 与服务器进行通信。
  • 定义引脚:

    • headServoPintailServoPinpirSensorPin: 定义了头部舵机、尾巴舵机和人体红外传感器分别连接到 ESP32 开发板的哪些引脚。你需要根据实际连接情况修改这些引脚号。
  • 定义语音指令:

    • openLightCommandcloseLightCommand: 定义了 MeowBot 能够识别的语音指令,例如 "小猫,帮我打开灯" 和 "小猫,帮我关灯"。 你可以根据自己的喜好修改这些指令,甚至添加更多指令来控制不同的智能家居设备。
  • 创建对象:

    • voiceRecognition: 创建 LD3320 对象,用于控制 LD3320 语音识别模块。
    • espClient: 创建 WiFiClient 对象,用于 ESP32 连接到 WiFi 网络。
    • mqttClient: 创建 PubSubClient 对象,用于 MQTT 通信,需要传入 WiFiClient 对象作为参数。
    • headServotailServo: 创建 Servo 对象,分别控制 MeowBot 的头部和尾巴舵机。
  • MQTT 主题:

    • lightTopic: 定义了控制灯光状态的 MQTT 主题,例如 "home/light"。 你可以根据实际控制的设备修改主题名称。
  • 初始化函数 setup():

    • Serial.begin(115200): 初始化串口通信,用于调试输出信息。
    • voiceRecognition.init(): 初始化 LD3320 语音识别模块。
    • voiceRecognition.setInterrupt(false): 设置语音识别模块为非中断模式,即程序会一直等待识别结果,不会被其他任务打断。
    • headServo.attach(headServoPin): 将头部舵机对象与对应的引脚关联起来。
    • tailServo.attach(tailServoPin): 将尾巴舵机对象与对应的引脚关联起来。
    • pinMode(pirSensorPin, INPUT): 将人体红外传感器引脚设置为输入模式。
    • WiFi.begin(ssid, password): 连接 WiFi 网络。
    • mqttClient.setServer(mqtt_server, mqtt_port): 设置 MQTT 服务器地址和端口号。
    • mqttClient.setCallback(mqttCallback): 设置 MQTT 消息回调函数,当收到订阅主题的消息时,会调用该函数进行处理。
    • mqttClient.connect("MeowBot", mqtt_user, mqtt_password): 连接 MQTT 服务器。
  • 主循环函数 loop():

    • mqttClient.loop(): 处理 MQTT 连接状态,保持与服务器的连接。
    • digitalRead(pirSensorPin) == HIGH: 检测人体红外传感器是否检测到有人靠近。
    • greet(): 如果检测到有人靠近,则调用 greet() 函数让 MeowBot 打招呼。
    • voiceRecognition.available(): 检查语音识别模块是否识别到语音指令。
    • voiceRecognition.readVoice(): 读取识别到的语音指令。
    • handleCommand(command): 调用 handleCommand() 函数处理识别到的语音指令。
  • 打招呼函数 greet():

    • 通过控制头部和尾巴舵机的角度,模拟 MeowBot 打招呼的动作。
  • 处理语音指令函数 handleCommand():

    • 该函数接收一个字符串类型的参数 command,表示识别到的语音指令。
    • 首先,使用 if (command == openLightCommand) 判断指令是否为打开灯的指令。
      • 如果是,则调用 mqttClient.publish(lightTopic, "on") 向 MQTT 服务器发送打开灯的指令。
      • lightTopic 是预先定义的控制灯光状态的 MQTT 主题,"on" 表示打开灯。
      • 最后,通过串口打印 "已发送打开灯的指令",方便调试。
    • 接着,使用 else if (command == closeLightCommand) 判断指令是否为关闭灯的指令。
      • 如果是,则调用 mqttClient.publish(lightTopic, "off") 向 MQTT 服务器发送关闭灯的指令。
      • "off" 表示关闭灯。
      • 最后,通过串口打印 "已发送关闭灯的指令",方便调试。
    • 最后,如果指令既不是打开灯也不是关闭灯,则进入 else 分支,表示未识别到有效指令。
      • 此时,程序会通过串口打印 "未识别到的指令",提示用户重新输入指令。
  • MQTT 回调函数 mqttCallback():

    • 该函数在 ESP32 从订阅的 MQTT 主题接收到消息时被调用。
    • 你可以根据需要编写该函数,例如,当接收到控制灯光状态的反馈消息时,可以通过串口打印出来,或者控制 LED 灯指示灯状态等。

总结:

MeowBot 的代码清晰易懂,主要实现了语音识别、舵机控制和 MQTT 通信功能。你可以根据自己的需求修改代码,例如添加更多语音指令、控制其他智能家居设备,甚至设计更复杂的动作和交互逻辑,打造独一无二的智能宠物猫。

  • 37
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,以下是一个使用Arduino和ESP32连接MQTT服务器并控制智能风扇的基本代码示例。该代码假设您已经将ESP32连接到WiFi网络,并且已经连接了一个电机或风扇,可以使用PWM控制其转速。 ```c++ #include <WiFi.h> #include <PubSubClient.h> // 设置WiFi名称和密码 const char* ssid = "your_SSID"; const char* password = "your_PASSWORD"; // 设置MQTT服务器IP地址和端口号 const char* mqtt_server = "your_mqtt_server"; int mqtt_port = 1883; // 设置MQTT主题和客户端ID const char* topic = "your_topic"; const char* clientID = "your_client_id"; // 设置PWM控制引脚 int fanPin = 4; // 创建WiFi和MQTT客户端对象 WiFiClient wifiClient; PubSubClient mqttClient(wifiClient); void setup() { // 初始化串口 Serial.begin(115200); // 连接WiFi网络 Serial.print("Connecting to "); Serial.println(ssid); WiFi.begin(ssid, password); while (WiFi.status() != WL_CONNECTED) { delay(1000); Serial.println("Connecting to WiFi..."); } Serial.println("Connected to WiFi"); // 设置PWM引脚模式 pinMode(fanPin, OUTPUT); // 设置MQTT回调函数 mqttClient.setCallback(callback); // 连接MQTT服务器 Serial.print("Connecting to MQTT server: "); Serial.print(mqtt_server); Serial.print(":"); Serial.println(mqtt_port); mqttClient.setServer(mqtt_server, mqtt_port); while (!mqttClient.connected()) { if (mqttClient.connect(clientID)) { Serial.println("Connected to MQTT server"); mqttClient.subscribe(topic); } else { Serial.print("Failed to connect to MQTT server, rc="); Serial.print(mqttClient.state()); Serial.println(" retrying in 5 seconds"); delay(5000); } } } void loop() { // 处理MQTT消息 mqttClient.loop(); // 检查是否有新的消息到达 if (newMessage) { // 如果收到“ON”指令,则启动风扇 if (strcmp(message, "ON") == 0) { analogWrite(fanPin, 255); mqttClient.publish(topic, "Fan turned ON"); } // 如果收到“OFF”指令,则关闭风扇 if (strcmp(message, "OFF") == 0) { analogWrite(fanPin, 0); mqttClient.publish(topic, "Fan turned OFF"); } // 重置消息状态 newMessage = false; memset(message, 0, sizeof(message)); } } // 定义MQTT消息回调函数 void callback(char* topic, byte* payload, unsigned int length) { Serial.print("Message arrived ["); Serial.print(topic); Serial.print("]: "); for (int i = 0; i < length; i++) { message[i] = (char)payload[i]; Serial.print((char)payload[i]); } Serial.println(); // 标记新的消息到达 newMessage = true; } ``` 这个代码示例使用ESP32连接到WiFi网络,并连接到MQTT服务器。当收到MQTT主题上的“ON”指令时,它将将PWM输出设置为最大值,以启动风扇。当收到MQTT主题上的“OFF”指令时,它将将PWM输出设置为零,以关闭风扇。它还在MQTT主题上发布消息,以指示风扇的状态已更改。 请注意,此代码仅是一个基本示例,您可能需要根据您的具体需求进行修改。例如,您可能需要添加安全性验证,以确保只有经过身份验证的用户才能控制风扇。您还可以使用更复杂的MQTT主题结构,以实现更复杂的控制和状态反馈。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

极客小张

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

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

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

打赏作者

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

抵扣说明:

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

余额充值