原理简述:利用发布订阅模式,即:ESP8266-01订阅了一个主题,再利用app inventor 编写得app 往这个主题发布消息,由于ESP8266 -01订阅了这个消息,所以就可以收到app发布得消息,从而执行相应得动作。

基于TCP长连接的模式,ESP8266通过TCP长连接,连接到服务器,app也同样通过TCP长连接,连接到服务器,两者通过主题(topic)进行耦合。

第一 下载ESP8266-01示例(arduino ide 编程开发)

下载地址: 点击下载

本demo 是利用arduino IDE开发,关于arduino IDE 的ESP8266环境配置可参考:环境配置: 点击跳转

安装好esp8266开发环境后,esp8266-01/01s 选择Generic ESP8266 Module开发板,其他默认即可。

在这里插入图片描述

第二 修改demo例程

需要修改的信息有WIF名称,WIFI密码,用户私钥UID,设备主题topic。

用户私钥可以巴法云控制台点击跳转获取,注册绑定邮箱即可在巴法创客云控制台点击跳转获取。

登陆完成后,可在控制台看到自己的私钥UID,如图所示:

在这里插入图片描述

创建主题,在控制台,可创建主题。

  • 第一输入主题,字母或数字或字母+数字组合。
  • 点击创建主题。

在这里插入图片描述

WIFI名称为自己的路由器WIFI名称,区分大小写,写错会导致连接不上网络的。

关于主题topic:主题可在控制台新建,字母+数字自定义组合即可。如下,例程的主题为light002。

//********************需要修改的部分*******************//

#define DEFAULT_STASSID  "newhtc"     //WIFI名称,区分大小写,不要写错
#define DEFAULT_STAPSW   "qq123456"  //WIFI密码
String UID = "7d54f85af42976ee3c2693e692a6bb59";  //用户私钥,可在控制台获取,修改为自己的UID
String TOPIC =   "light002";         //主题名字,可在控制台新建
const int LED_Pin = 0;              //单片机LED引脚值,GPIO0引脚

//**************************************************//

在本demo中是控制的ESP8266-01的0 口。

//单片机LED引脚值
const int LED_Pin = 0;

推荐使用下载器下载:插上之后,arduino IDE 中找到下载器端口端口就行,在ide 导航栏-“工具”-“端口”,都设置好后,点下载烧录就行了。
在这里插入图片描述

下载程序到ESP8266中,如果WIFI信息没有填错的话ESP8266就会自动连接到云服务器上。

开发者可进行测试,测试方法,在控制台该主题处推送消息,可观察ESP8266是否收到该消息。可通过串口工具查看输出。

消息检测代码默认为(在例程147行):

//********************可根据需要修改的部分*******************//

    if((TcpClient_Buff.indexOf("&msg=on") > 0)) {
      turnOnLed();
    }else if((TcpClient_Buff.indexOf("&msg=off") > 0)) {
      turnOffLed();
    }

//**************************************************//

当检测到消息为on 时,执行开灯,当检测到消息为off 时,执行关灯。开发者可在控制台推送on或者off,然后检测esp8266是否收到,如果收到,说明正常可进行下一步app编写。

说明:消息不单单局限于on或off,开发者可以张大脑洞随意定义的,你推送什么消息,在单片机处做什么消息检测就可以了。例如app推送json数据,esp8266就可以收到json数据包。

第三 app inventor 开发

原理:同样通过TCP 长连接,连接到服务器,当按下按钮,就向服务器该主题推送个消息,ESP8266就可以收到该消息了。

简介:Google App Inventor是一个完全在线开发的Android编程环境,抛弃复杂的程式代码而使用积木式的堆叠法来完成您的Android程式。 而且这款编程软件不一定非要是专业的研发人员,甚至根本不需要掌握任何的程序编制知识。因为这款软件已经事先将软件的代码全部编写完毕,用户只需要根据自己的需求向其中添加服务选项即可。也就是我们所要做的只是写简单的代码拼装程序。

安装appInventor 点击安装

本操作只提供一个app的demo,界面过于丑陋,大家可自由发挥更改界面。

demo 下载点击下载

顶部导航栏,依次点击(项目–>导入项目aia),选择上一步骤下载的aia文件导入即可。点击导入的项目,即可看到控制面板,面板主要分为在组建设计和逻辑设计,用户可在右上角进行模式切换。

app

(组建设计)面板可以向屏幕添加组建以进行二次开发。(逻辑面板)则进行相关逻辑编写。

app
导入aia文件后,如果只是简单使用,只需要修改两个地方,一个是主题名字,一个是UID,均需开发者置换成自己的topic(主题名字)和UID(用户私钥),均可在创客云控制台获取点击跳转

此处的主题topic应该和ESP8266程序里面设定的主题修改为一样,不然会收不到消息。UID修改为自己的私钥。

在这里插入图片描述

app

控制逻辑

当按钮’打开’被点击,发送on,ESP8266即可收到on消息

在这里插入图片描述

具体发送的消息,开发者可自定义,例程中只是发送简单的字符串,开发者也可发送json之类的,

不过在ESP8266端要对json消息体进行解析。更多指令格式说明:接入文档

如果想控制家里的灯具,加个继电器即可,通过引脚输出高低电平控制继电器的开和关,从而达到控制220v交流电的效果。继电器需要用3.3V继电器。

在这里插入图片描述
如果使用下图这种继电器模块,他们的控制引脚就是0脚,上述程序可以直接使用,插上就行了,可以在控制台推送on或者off测试,或者使用app 或小程序进行控制。

在这里插入图片描述

第四 微信小程序控制

教程:https://bemfa.blog.csdn.net/article/details/107019002

在这里插入图片描述

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐