无线控制小车项目模块(一)

基于esp8266无线控制模块应用:MQTT发布主题

智能wifi小车项目说明:
使用两块esp8266建立通信,加入了mqtt协议,esp8266发送方通过按键发布信息(手柄作用)esp8266作为接收方,接收订阅主题所发来的信息并通过串口打印数据,stm32作为主控,控制两个车轮的前进后退,左转右转,并做好串口接收的执行功能

完整项目分为三个模块
1,esp8266发送方(用于控制小车) 类似遥控装置
2,esp8266接收方(接收发送方的消息) 类似接收装置
3.主控方(stm32c8t6用于直接驱动小车) 执行命令方

本项目为第《1》 模块,开发环境Arduino

第《1》 模块说明:esp8266上使用mqtt协议向某一主题发布信息,外接四个按键,通过四个按键向主题发布不同信息,四个按键引脚分别为:

pinMode(16,INPUT); //key1
pinMode(5, INPUT); //key2
pinMode(4, INPUT); //key3
pinMode(0, INPUT); //key4

按键一方接控制端,一方接GND

示例代码如下

注:该项目需要导入esp8266支持包,PubSubClient库,可以添加

#include <ESP8266WiFi.h>
#include <PubSubClient.h>
#include <Ticker.h>

// 设置wifi接入信息(请根据您的WiFi信息进行修改)
  
const char* ssid = "iphone";//wifi账号自定义
const char* password = "112233445566";//wifi密码自定义
const char* mqttServer = "test.ranye-iot.net";//连接公共服务端地址

 
Ticker ticker;
WiFiClient wifiClient;
PubSubClient mqttClient(wifiClient);
 
int count;    // Ticker计数用变量
 
void setup() {
  Serial.begin(9600);

  pinMode(16,INPUT);   //key1
  pinMode(5, INPUT);   //key2
  pinMode(4, INPUT);   //key3
  pinMode(0, INPUT);   //key4
 
  // Ticker定时对象
  ticker.attach(1, tickerCount);
  
  //设置ESP8266工作模式为无线终端模式
  WiFi.mode(WIFI_STA);
  
  // 连接WiFi
  connectWifi();
  
  // 设置MQTT服务器和端口号
  mqttClient.setServer(mqttServer, 1883);//固定端口号一般为1883
  mqttClient.setCallback(receiveCallback);
 
  // 连接MQTT服务器
  connectMQTTServer();
}
 
void loop() {
  int i;
   
  if (mqttClient.connected()) { // 如果开发板成功连接服务器
     pubMQTTmsg();
    mqttClient.loop();       // 保持心跳
  } else {                  // 如果开发板未能成功连接服务器
    connectMQTTServer();    // 则尝试连接服务器
  }
}
 
void tickerCount(){
//  count++;
}
 
void connectMQTTServer(){
  // 根据ESP8266的MAC地址生成客户端ID(避免与其它ESP8266的客户端ID重名)
  String clientId = "esp8266-" + WiFi.macAddress();
 
  // 连接MQTT服务器
  if (mqttClient.connect(clientId.c_str())) { 
    Serial.println("MQTT Server Connected.");
    Serial.println("Server Address: ");
    Serial.println(mqttServer);
    Serial.println("ClientId:");
    Serial.println(clientId);
    subscribeTopic(); // 订阅指定主题
  } else {
    Serial.print("MQTT Server Connect Failed. Client State:");
    Serial.println(mqttClient.state());
    delay(3000);
  }   
}
 
// 发布信息
void pubMQTTmsg(){
  // 建立发布主题。主题名称以Taichi-Maker-为前缀,后面添加设备的MAC地址。
  // 这么做是为确保不同用户进行MQTT信息发布时,ESP8266客户端名称各不相同,
  String topicString = "Taichi-Maker-Pub-" + WiFi.macAddress();
  char publishTopic[topicString.length() + 1];  
  strcpy(publishTopic, topicString.c_str());
 
  // 定时向服务器主题发布当前D3(gpio0)引脚状态
   String messageString;
  
   if(digitalRead(16)==LOW)
     messageString = "1"; 
   else if(digitalRead(5)==LOW)
     messageString = "2";
   else if(digitalRead(4)==LOW)
     messageString = "3";   
   else if(digitalRead(0)==LOW)
     messageString = "4";
   else
     messageString = "0"; 

   delay(300); 
        

/******************************************************************************************/
  char publishMsg[messageString.length() + 1];   
  strcpy(publishMsg, messageString.c_str());

  // 实现ESP8266向主题发布信息
  if(mqttClient.publish(publishTopic, publishMsg)){
    Serial.println("Publish Topic:");Serial.println(publishTopic);
    Serial.println("Publish message:");Serial.println(publishMsg);    
  } else {
    Serial.println("Message Publish Failed."); 
  }
}
 
// 订阅指定主题
void subscribeTopic(){
 
  // 建立订阅主题。主题名称以Taichi-Maker-Sub为前缀,后面添加设备的MAC地址。
  // 这么做是为确保不同设备使用同一个MQTT服务器测试消息订阅时,所订阅的主题名称不同
  String topicString = "Taichi-Maker-Sub-" + WiFi.macAddress();
  char subTopic[topicString.length() + 1];  
  strcpy(subTopic, topicString.c_str());
  
  // 通过串口监视器输出是否成功订阅主题以及订阅的主题名称
  if(mqttClient.subscribe(subTopic)){
    Serial.println("Subscribe Topic:");
    Serial.println(subTopic);
  } else {
    Serial.print("Subscribe Fail...");
  }  
}
 
// 收到信息后的回调函数
void receiveCallback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message Received [");
  Serial.print(topic);
  Serial.print("] ");
  for (int i = 0; i < length; i++) {
    Serial.print((char)payload[i]);
  }
  Serial.println("");
  Serial.print("Message Length(Bytes) ");
  Serial.println(length);
 
  if ((char)payload[0] == '1') {     // 如果收到的信息以“1”为开始
    digitalWrite(LED_BUILTIN,HIGH);  // 则点亮LED。
  } else {                           
    digitalWrite(LED_BUILTIN, LOW); // 否则熄灭LED。
  }
}
 
// ESP8266连接wifi
void connectWifi(){
 
  WiFi.begin(ssid, password);
 
  //等待WiFi连接,成功连接后输出成功信息
  while (WiFi.status() != WL_CONNECTED) {
    delay(1000);
    Serial.print(".");
  }
  Serial.println("");
  Serial.println("WiFi Connected!");  
  Serial.println(""); 
}
 

通过以上代码可以实现向某一主题发送信息,并且通过串口(9600)打印出来所发布主题信息
连接成功后将通过串口输出 一次WiFi Connected!

我们可以通过MQTTfx软件进行验证,加入同一公网:test.ranye-iot.net
配置如下:

在这里插入图片描述
拷贝串口上打印的主题,添加到所要订阅的主题
(不同开发板所发布的主题不一致,根据自己开发板串口所打印的主题进行选择)
在这里插入图片描述
在订阅了之后不出意外就会持续接收到数据了—》持续打印0
通过按键key1,key2,key3.key4,按下,会打印不同的数据,分别对应1,2,3,4

如果接收不到数据,
1.检查esp8266是否连接上网络
2.检查按键接线是否正确
3.检查mqttfx软件上所加入是否是同一公网,配置要和上图一致
4.检查发布主题与订阅主题是否一致

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WIFI232模块概述: 串口WiFi,内置天线,带屏蔽罩,被大量使用,适用于大流量通信,不考虑功耗的场合。 关于WIFI232家族: 硬件上,我们集成了MAC、射频收发单元、功率放大器等,加上天线,你就可以直接拿去用。 软件上,我们自带固件,内置WiFi协议、TCP/IP协议,你只需要简单的配置下我即可。 简单来说,我们做了很多事,而你,只需要通过一个UART接口来跟我沟通要做什么,我们就帮你实现。 我们会给你相应的配置命令(AT指令集),操作上,当然就像使用串口一样简单。 WiFi模块作为AP时的应用: 特点: 操作简单:会操作串口就会操控我(提供指令集;我是串口WIFI) 启动时间:6S。(市面上普通WIFI模块启动时间大都多于6S,部分甚至接近30S) 功耗:3.3V供电,170mA-300mA。(功耗偏大,适用于非电池供电等一些对功耗无要求的场合) 带屏蔽罩:对模块核心部分进行封包。(不少厂家没有加屏蔽措施) 适合做热点:可接入终端多,支持路由/桥接模式网络构架。(路由器AP方案) TCPB功能:支持2 x TCP功能,即可以同时支持2个网络连接。(市面上的普通模块没有这个功能) 演示视频: 功能: 方案:Marvell WiFi(路由器方案,硬件AP)、ARM 支持无线局域网标准:IEEE 802.11 b/g/n 支持WIFI加密方式和算法:WEP/WPA-PSK/WPA2-PSK/WAPI等 支持STA/AP/STA+AP共存工作模式(AP即WIFI热点;STA是WIFI终端)AP模式:可接入32个设备 STA模式:server端支持32个连接 AP+STA模式:具有路由功能,AP允许32个客户端连接 支持多种网络协议:TCP/UDP/ARP/ICMP/HTTP/DNS/DHCP 支持DHCP自动获取IP 支持AT+指令集及Web配置模块参数 支持透明/协议数据传输模式,1M缓存空间(用于TCP的缓存是4K) 支持串口分帧延迟和数据量设置 支持波特率可达460800bps,支持硬件流 支持以太网数据传输、PWM输出、GPIO控制 支持web升级固件 内置PA,57600波特率双向互传不丢包,轻松穿三层混泥土墙 通讯距离:外置3DB天线400米,内置天线150米。(开阔地;模块对传) 支持恢复出厂设置:通过拉低Reload IO口三秒即可恢复出厂设置,无须担心设置错误 支持路由/桥接模式网络构架(由路由器方案决定支持) 内建看门狗和心跳机制,保证在线能力 配套软件: WINDOWS、iOS、Android下的测试软件(方便你测试) iOS、Android通信源码(方便你借鉴) 实物购买链接:https://www.waveshare.net/shop/WIFI232-A.htm
/* 这个版本是根据管理员iuviking的51单片机版WIFI小车下位机程序(通信协议版) 版本修改而来,我已经加入了八路舵机控制(p0口),ε咫ヤ涯/ */ #include<reg52.h> #include<math.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int uchar Buffer =0; //从串口接收的数据 uint URTAReceivedCount=0,n=1; uchar data Tempdatatable[5],CommandDatatable[5];//数据包 uchar serVal[2]; uint pwm[]={1120,1190,1382,1382,1382,1382,1382,1382}; //初始90度,(实际是1382.4,取整得1382) uchar pwm_flag=0; uint code ms0_5Con=461; //0.5ms计数 (实际是460.8,取整得461) uint code ms2_5Con=2304; //2.5ms计数 bit key_stime_ok; sbit StatusLight=P2^0; //状态灯 sbit MainLight=P2^1; //主大灯 sbit servo0=P0^0; //舵机控制 sbit servo1=P0^1; sbit servo2=P0^2; sbit servo3=P0^3; sbit servo4=P0^4; sbit servo5=P0^5; sbit servo6=P0^6; sbit servo7=P0^7; /******************************************************************** * 名称 : Delay_1ms() * 功能 : 延时子程序,延时时间为 1ms * x * 输入 : x (延时一毫秒的个数) * 输出 : 无 ***********************************************************************/ void Delay_1ms(uint i)//1ms延时 { uchar x,j; for(j=0;j<i;j++) for(x=0;x<=148;x++); } void TurnOnStatusLight() { StatusLight=0; } /******************************************************************** * 名称 : Send_Data() * 功能 : 向上位机传送字符 * 输入 : 无 * 输出 : 无 ***********************************************************************/ void Send_Data(uchar type,uchar cmd,uchar dat) { uchar data Buffer[5];//构建数据包 uchar *p; uint Send_Count=0; p = Buffer; Buffer[0]=0XFF; Buffer[1]=type; Buffer[2]=cmd; Buffer[3]=dat; Buffer[4]=0XFF; while(1) { if(*p==0XFF) { Send_Count++; //0XFF标志统计位 } SBUF = *p; //发送 while(!TI) //如果发送完毕,硬件会置位TI,等待发送完毕 { _nop_(); } p++; TI = 0; if(Send_Count == 2) //当统计到两次出现0XFF,则认为一个数据包发送完毕,跳出循环 { TI = 0; break;

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值