极客工坊

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 293082|回复: 118

【库和教程】ESP8266 WIFI模块实现远程wifi控制(持续更新)

  [复制链接]
发表于 2014-10-15 16:48:32 | 显示全部楼层 |阅读模式
本帖最后由 ITEAD创易工作室 于 2015-9-18 18:39 编辑

----------------------------------------------------2015年9月18日更新------------------------------------------------------

     ITEAD首款智能wifi通用改装件成功上市http://www.geek-workshop.com/thread-17944-1-1.html



----------------------------------------------------2015年6月10日更新-------------------------------------------------------

最新wifi库下载地址:https://github.com/itead/ITEADLIB_Arduino_WeeESP8266/archive/master.zip
库默认是使用硬件串口与ESP8266通信,需要软串口通信只需取消注释Esp8266.h文件里的一行代码
#define ESP8266_USE_SOFTWARE_SERIAL

--------------------------------------------------2015年2月5日发布---------------------------------------------------------
2014年10月发的第一篇mini Rboard的开关教程很多小伙伴问我如果用UNO的话该怎么使用?软件安装不了,手机怎么翻墙?等等问题。当然我们也一直在尽全力解决这些问题,很幸运,软硬件的问题都解决了!现在我们就用ITEAD自己开发的wifi APK和最新版ESP8266 WiFi bee模块WEE实现远程遥控开关操作。

使用UNO搭建硬件所需配件:

因为UNO只有一对串口,已经被WIFI模块占用了,所以要增加一个转串口的板子用软串口来打印串口信息。

使用ITEADUINO  MEGA2560搭建硬件所需配件:

此处也可以使用Arduino MEGA2560,但是需要飞线到后面的TX2RX2。这个就交给小伙伴们自己去尝试吧,成功后可以发到帖子回复里跟大家分享。

需要使用到的库文件地址:http://pan.baidu.com/s/1kT9TBz5这个库跟之前发的库是一样的,但很多小伙伴反应编译不过,这个库我是用1.0.6版本的IDE测试一定能过的。不放心的朋友可以把以前下的库从libraries里移除,重新下载这个到libraries文件夹里面。

库默认设置的是UNO可以直接使用本教程,无需做任何修改。
使用mega2560的时候,只需要打开uartWIFI.h文件,把UNO注释掉,取消注释MEGA,如下:

//#define UNO        //uncommentthis line when you use it with UNO board
#define MEGA      //uncommentthis line when you use it with MEGA board


硬件搭建方面我们先不说怎么接线,因为经常有人问我:“你好,程序已经烧给模块了,为什么不成功?”我的亲大哥啊,所有代码都是烧写进UNOmega2560主板的,你就算不接模块,代码也是可以上传编译成功的。所以我们的步骤是先把代码烧写进UNOMEGA2560

代码如下:


  1. #define SSID "ITEAD_2"        //type your own SSID name
  2. #define PASSWORD "27955416"        //type your own WIFI password
  3.   
  4.   
  5. #include "uartWIFI.h"
  6. #include <SoftwareSerial.h>
  7. WIFI wifi;
  8.   
  9. extern int chlID;        //client id(0-4)
  10.   
  11.   
  12. void setup()
  13. {

  14. pinMode(6,OUTPUT); //使用mega的时候在不改变接线的情况下,此处改为24脚

  15. wifi.begin();
  16. bool b = wifi.Initialize(STA, SSID, PASSWORD);
  17. if(!b)
  18. {
  19. DebugSerial.println("Init error");
  20. }
  21. delay(8000); //make sure the module can have enough time to get an IP address
  22. String ipstring = wifi.showIP();
  23. DebugSerial.println(ipstring);        //show the ip address of module
  24.   
  25. delay(2000);
  26. wifi.confMux(1);
  27. delay(100);
  28. if(wifi.confServer(1,8080))
  29. DebugSerial.println("Server is set up");
  30.   
  31.   
  32. }
  33. void loop()
  34. {
  35.   
  36. char buf[100];
  37. int iLen = wifi.ReceiveMessage(buf);
  38. if(iLen > 0)
  39. {

  40.   
  41. if (strcmp(buf, "CH0ON") == 0)
  42. {
  43. digitalWrite(6,HIGH);  //使用mega的时候在不改变接线的情况下,此处改为24脚
  44. DebugSerial.println("CH0ON");
  45. }
  46. if (strcmp(buf, "CH0OFF") == 0)
  47. {
  48. digitalWrite(6,LOW); //使用mega的时候在不改变接线的情况下,此处改为24脚
  49. DebugSerial.println("CH0OFF");
  50. }
  51. }
  52. }
复制代码

使用MEGA时,把代码里继电器的D6脚改为D24脚。代码烧写完成后,我们现在来搭建硬件。

UNO接线如图:

Foca转串板连接的是D2D3作为软串口。G要共地。

ITEADUINO MEGA2560接线如图:

此处的Xbee扩展板的跳帽应该是2和3,而不是0和1,此处有错。正确跳帽如下:

     .  .  . 4
     ._.  . 3
     .  ._. 2
     .  .  . 1
     .  .  . 0

Xbee扩展板插在TX2RX2这排排母上。如图:

连接电脑,插上9V/1A适配器电源供电,打开Arduino IDE串口监视器就可以查看wifi运行状态了。如果是使用UNO,打开监视器后需要先按一下UNO板子上的重启键再按一下xbee扩展板上的重启键。此时才能看到串口监视信息。使用mega2560则无需操作。如果是出现“Module have no response”则只需要按一下mega板子侧边的重启键。

成功连接路由器后,我们就得到了WiFi模块的IP地址,串口打印信息如下:
↑UNO串口打印信息

↑MEGA串口打印信息

接下来,就需要安装手机APK了。下载地址:http://pan.baidu.com/s/1nt7ND6x

该软件目前只支持4-7寸安卓智能手机或者平板,7寸平板的话排版可能会有空隙,不过不影响使用。

下载安装后,进入set up设置界面。在客户端输入我们刚刚获得的IP地址和端口号8080,如图:

点击“开始连接”,连接成功会显示:成功连接server。如图:

按键指令我们重新设置一下,下拉到最下面,将OnOff的指令改为CH0OFFCH0ON(指令可以任意设置,只要跟代码里的指令一致就行),如果开关状态相反,把指令反过来即可,如图:

↑修改前


↑修改后

输入完成后,点击“返回”到操作界面,此时点击OnOff就可以成功控制开关了!

                                关(UNO)


                                 开(UNO)


                       关(MEGA)


                              开(MEGA)


可以收到串口打印信息如下:






-------------------------------------------------2014年10月15日发布-------------------------------------------------------
更新说明:由于固件升级,很多小伙伴们收到ESP8266模块后用我们的库调不通,在此诚挚道歉。发布此篇教程的时候使用的是旧版本固件,库文件设置的波特率是115200。如果调不通的话应该收到的是新版本,使用的波特率是9600。库文件我们已经更新了http://pan.baidu.com/s/1sj2nUyT 请知悉,谢谢!

(一)ESP8266 wifi模块库文件测试


上周终于写完ESP8266 wifi 模块的库了,测试OK!在此开出源码和实例教程,希望能帮到大家!

主要配件:



一张图介绍mini RBoard


步骤:

1. 下载库文件

烧写程序之前,我们需要用到ESP8266库,下载地址为:

http://pan.baidu.com/s/1sj2nUyT

温馨提示: ESP8266 wifi库文件是基于arduino IDE 1.0.5版本编译的,如遇编译不过,请尝试其他版本。

打开库中的uartWIFI.h文件,因为我们的mini RBoard使用的是跟UNO一样的芯片,所以要在H文件里去掉定义UNO的注释,注销掉MEGA。

#define UNO
//#define MEGA

然后把_DBG_RXPIN_和_DBG_TXPIN_引脚定义改为D9和D10.

#define _DBG_RXPIN_ 9                //A0
#define _DBG_TXPIN_ 10                //A1

然后保存uartWIFI.h文件。

烧写代码:

插上FOCA,板子的类型选择“Arduino UNO”,点击烧写程序。如下图:



  1. /*
  2. ESP8266 library

  3. When you use with UNO board, uncomment the follow line in uartWIFI.h.
  4. #define UNO

  5. When you use with MEGA board, uncomment the follow line in uartWIFI.h.
  6. #define MEGA

  7. Connection:
  8. When you use it with UNO board, the connection should be like these:
  9. ESP8266_TX->D0
  10. ESP8266_RX->D1
  11. ESP8266_CH_PD->3.3V
  12. ESP8266_VCC->3.3V
  13. ESP8266_GND->GND

  14. FTDI_RX->D3        //The baud rate of software serial can't be higher that 19200, so we use software serial as a debug port
  15. FTDI_TX->D2

  16. When you use it with MEGA board, the connection should be like these:
  17. ESP8266_TX->RX1(D19)
  18. ESP8266_RX->TX1(D18)
  19. ESP8266_CH_PD->3.3V
  20. ESP8266_VCC->3.3V
  21. ESP8266_GND->GND

  22. When you want to output the debug information, please use DebugSerial. For example,

  23. DebugSerial.println("hello");


  24. Note:        The size of message from ESP8266 is too big for arduino sometimes, so the library can't receive the whole buffer because
  25. the size of the hardware serial buffer which is defined in HardwareSerial.h is too small.

  26. Open the file from \arduino\hardware\arduino\avr\cores\arduino\HardwareSerial.h.
  27. See the follow line in the HardwareSerial.h file.

  28. #define SERIAL_BUFFER_SIZE 64

  29. The default size of the buffer is 64. Change it into a bigger number, like 256 or more.


  30. */


  31. #define SSID "Itead_1(Public)"        //type your own SSID name
  32. #define PASSWORD "27955416"        //type your own WIFI password


  33. #include "uartWIFI.h"
  34. #include <SoftwareSerial.h>
  35. WIFI wifi;

  36. extern int chlID;        //client id(0-4)


  37. void setup()
  38. {
  39. pinMode(4,OUTPUT);
  40. pinMode(5,OUTPUT);
  41. pinMode(6,OUTPUT);
  42. pinMode(7,OUTPUT);
  43. wifi.begin();
  44. bool b = wifi.Initialize(STA, SSID, PASSWORD);
  45. if(!b)
  46. {
  47. DebugSerial.println("Init error");
  48. }
  49. delay(8000); //make sure the module can have enough time to get an IP address
  50. String ipstring = wifi.showIP();
  51. DebugSerial.println(ipstring);        //show the ip address of module

  52. delay(2000);
  53. wifi.confMux(1);
  54. delay(100);
  55. if(wifi.confServer(1,8080))
  56. DebugSerial.println("Server is set up");


  57. }
  58. void loop()
  59. {

  60. char buf[100];
  61. int iLen = wifi.ReceiveMessage(buf);
  62. if(iLen > 0)
  63. {
  64. //mini Rboard D4 pin is relay,mini Rboard URL:[url=http://item.taobao.com/item.htm?spm=a1z10.3.w4002-2605688463.12.EMkeTJ&id=39334222369]http://item.taobao.com/item.htm? ... keTJ&id=39334222369[/url]

  65. if (strcmp(buf, "CH0ON") == 0)
  66. {
  67. digitalWrite(4,HIGH);
  68. DebugSerial.println("CH0ON");
  69. }
  70. if (strcmp(buf, "CH0OFF") == 0)
  71. {
  72. digitalWrite(4,LOW);
  73. DebugSerial.println("CH0OFF");
  74. }
  75. /* the other 3 chanels below are for Rboard D5 D6 D7 , Rboard URL:[url=http://item.taobao.com/item.htm?spm=a1z10.3.w4002-2605688463.12.EMkeTJ&id=39334222369]http://item.taobao.com/item.htm? ... keTJ&id=39334222369[/url]

  76. if (strcmp(buf, "CH1ON") == 0)
  77. {
  78. digitalWrite(5,HIGH);
  79. DebugSerial.println("CH1ON");        
  80. }
  81. if (strcmp(buf, "CH1OFF") == 0)
  82. {
  83. digitalWrite(5,LOW);
  84. DebugSerial.println("CH1OFF");        
  85. }
  86. if (strcmp(buf, "CH2ON") == 0)
  87. {
  88. digitalWrite(6,HIGH);
  89. DebugSerial.println("CH2ON");
  90. }
  91. if (strcmp(buf, "CH2OFF") == 0)
  92. {
  93. digitalWrite(6,LOW);
  94. DebugSerial.println("CH2OFF");
  95. }
  96. if (strcmp(buf, "CH3ON") == 0)
  97. {
  98. digitalWrite(7,HIGH);
  99. DebugSerial.println("CH3ON");        
  100. }
  101. if (strcmp(buf, "CH3OFF") == 0)
  102. {
  103. digitalWrite(7,LOW);
  104. DebugSerial.println("CH3OFF");        
  105. }
  106. */

  107. }
  108. }
复制代码


黏贴代码到arduino IDE中,在SSID和PASSWORD宏定义中修改成自己的路由器WIFI名称和密码。

#define SSID       "Itead_1(Public)"                //type your own SSID name
#define PASSWORD   "27955416"                //type your own WIFI password

编译,烧写,OK!

接下来我们还需要用到foca来读取串口信息,查看wifi状态。

按照以下连接方式连接FOCA和ESP8266到mini Rboard上。


2015年1月29日修正:此图的foca串口接反了,TX应该接D9,RX接D10。
或者将库文件的9和10反过来。
#define _DBG_RXPIN_ 10                //A0
#define _DBG_TXPIN_ 9                //A1

另外说明:如果使用UNO请提供额外9V/1A适配器供电。Arduino IDE编译版本使用1.0.6以上

实物连接图:


Mini Rboard的引脚定义图:


ESP8266的引脚定义图:


然后打开Serial监视器,按一下复位键,等待一段时间后,会看到串口显示它的ip地址:172.16.1.20,当然你也可以登陆路由器的管理后台查看到这个wifi模块的IP地址。



现在我们还需要下载一个软件来进行无线控制。

2. 下载UDP TCP Server app

打开手机的Google play,搜索UDP TCP Server,安装该软件。(不能翻墙和没有google账户和不能安装google play的小伙伴自行安装VPN和google play所需app)



打开该软件,点击右上角的settings,将Target IP设置为wifi的IP地址,本文为172.16.1.12,以每次分配的实际IP为准。UPD/TCP选择TCP,Target Port设置为8080,TCP connection behavior设置为“Initiate connection,and keep open”。





然后返回上一级,点击Button Settings。设置buttons的数量为8个(适用于4通道的Rboard),分别在button的名字和命令上修改成:“CH0ON”, “CH1ON”, “CH2ON”, “CH3ON”, “CH0OFF”, “CH1OFF”, “CH2OFF”, “CH3OFF”。这分别代表设置对应继电器通道的开关状态。此次测试用的mini Rboard只需要用到“CH0ON”和“CH0OFF”这一个通道。


返回主页面,我们可以看到按钮的名称已改变,点击对应的按钮后,会看到mini Rboard上对应的通道设置为按钮上的状态。


演示视频:



(二)ESP8266 wifi模块上传数据到yeelink平台


上期我们实现了局域网内的wifi控制,基于上面的库文件,我们今天给大家带来使用yeelink平台的upload教程,小伙伴还可以用手机随时随地观看数据变化情况。

所需配件:

步骤:

1. 硬件连接



接线示意图



硬件实物连接图



2. 注册Yeelink账号

在烧写程序之前,我们必须做一些准备工作:注册Yeelink账号,并获取属于自己的API KEY和对应设备、传感器的ID地址值。ESP8266通过地址信息将DHT11的温度信息上传到服务器系统中唯一的标示图上,这样可以在Yeelink的网页上实时观察到该传感器当前环境温度信息。

步骤如下:

第一步,注册用户。Yeelink的地址为:http://www.yeelink.net/

第二步,点击“账号”目录下的“我的账户设置”按钮,记下当前的API KEY,在本例中,API KEY为“7bf75e6c2c8a17351d557f206f89fa2e”。



第三步,点击“我的设备”目录下的“添加新设备”按钮,并按照如下内容范例填写,然后点击保存按钮。




第四步,添加新设备完毕后还需要为该设备增加一个或多个传感器(一个设备可以同时支持多个传感器)。点击“传感器”栏下的“+增加一个传感器”按钮,进入添加传感器的页面。按照如下内容范例填写,然后点击保存。






第五步,保存后,在管理设备页面的下方会出现一个数据曲线的图表。设备的ID值为数据曲线的URL中device后面那串数字,而传感器的ID值为数据曲线的URL中sensor后面那串数字,记下该设备和传感器的ID值,在本例中温度的设备ID值为3047,传感器ID值为4285; 湿度的设备ID值为3047,传感器ID值为26142。




完成上面的操作后,会得到相应的API KEY,设备的ID值和传感器的ID值。如果想了解更具体的步骤,请查看以下网页:http://www.yeelink.net/developer/doc/42

3.烧写程序,我们需要用到ESP8266库,下载地址为:http://pan.baidu.com/s/1sj2nUyT 。库跟第一章的一样,已下载的小伙伴不需要重新下载了。

温馨提示: ESP8266 wifi库文件是基于arduino IDE1.0.5版本编译的,如遇编译不过,请尝试其他版本。

把ESP8266库解压缩到\arduino\libraries目录下。

因为以太网的数据包比较大,我们需要把串口的环形缓冲区的大小改大才能正常显示所有数据。
用记事本打开arduino\hardware\arduino\cores\arduino\HardwareSerial.cpp文件,把第59行的SERIAL_BUFFER_SIZE数值改为500.如下:


#if (RAMEND< 1000)
  #define SERIAL_BUFFER_SIZE 16
#else
  #define SERIAL_BUFFER_SIZE 500
#endif
保存修改。

打开下载的库文件里面的uartWIFI.H文件。确认以下两处是否如下:

    #define _DBG_RXPIN_ 2  //使用UNO的时候改为9
    #define _DBG_TXPIN_ 3  //使用UNO的时候改为10
    #define debugBaudRate 9600
   //#define UNO  //使用UNO的时候取消这行的注释
     #define MEGA //使用mega的时候注释掉这行

确认无误,保存。

复制以下demo代码到arduino IDE。

  1. #define SSID       "Itead_1(Public)"                //type your own SSID name
  2. #define PASSWORD   "27955416"                                //type your own WIFI password


  3. #include "uartWIFI.h"
  4. #include <SoftwareSerial.h>
  5. WIFI wifi;

  6. extern int chlID;        //client id(0-4)

  7. // for yeelink api
  8. #define APIKEY         "3a362e99d6f1daf974561163a8c99a85" // replace your yeelink api key here

  9. //replace the device ID and sensor ID for temperature sensor.
  10. #define DEVICEID0       15483 // replace your device ID
  11. #define SENSORID0       26660 // replace your sensor ID

  12. //replace the device ID and sensor ID for humidity sensor.
  13. #define DEVICEID1       15483 // replace your device ID
  14. #define SENSORID1       26661 // replace your sensor ID

  15. char server[] = "api.yeelink.net";   // name address for yeelink API

  16. unsigned long lastConnectionTime = 0;          // last time you connected to the server, in milliseconds
  17. boolean lastConnected = false;                 // state of the connection last time through the main loop
  18. const unsigned long postingInterval = 5*1000; // delay between 2 datapoints, 5s
  19. String returnValue = "";
  20. boolean ResponseBegin = false;


  21. int DHT11PIN=25;                        //Connect D25 to data pin of DHT11


  22. int humidity;
  23. int temperature;

  24. int post_number;

  25. void setup()
  26. {

  27.   wifi.begin();
  28.   bool b = wifi.Initialize(STA, SSID, PASSWORD);
  29.   if(!b)
  30.   {
  31.     DebugSerial.println("Init error");
  32.   }
  33.   delay(8000);  //make sure the module can have enough time to get an IP address
  34.   String ipstring  = wifi.showIP();
  35.   DebugSerial.println(ipstring);                //show the ip address of module
  36.   

  37.         

  38. }
  39. void loop()
  40. {
  41.   char message[400];
  42.    // if you're not connected, and ten seconds have passed since
  43.   // your last connection, then connect again and send data:
  44.   if((millis() - lastConnectionTime > postingInterval)) {
  45.   
  46.   //read dht11
  47.   int chk = dht11_read(DHT11PIN);
  48.   if(chk==0)
  49.   {
  50.         if(post_number==0)
  51.         {
  52.                 sendData(DEVICEID0,SENSORID0,temperature);
  53.                 post_number++;
  54.         }
  55.         else
  56.         {
  57.                 post_number = 0;
  58.                 sendData(DEVICEID1,SENSORID1,humidity);
  59.         }
  60.         
  61.   }
  62.   
  63.   }
  64.   
  65.   // if there's incoming data from the net connection.
  66.   // send it out the serial port.  This is for debugging
  67.   // purposes only:
  68.   if(wifi.ReceiveMessage(message))
  69.   {
  70.       DebugSerial.println(message);   
  71.   }


  72.   delay(10);

  73. }

  74. // this method makes a HTTP connection to the server:
  75. void sendData(int device_id,int sensor_id,int thisData) {
  76.   // if there's a successful connection:
  77.   if (wifi.ipConfig(TCP,server, 80)) {
  78.     DebugSerial.println("connecting...");
  79.     // send the HTTP PUT request:
  80.     String cmd;
  81.         cmd = "POST /v1.0/device/";
  82.         cmd += String(device_id);
  83.         cmd += "/sensor/";
  84.         cmd += String(sensor_id);
  85.         cmd += "/datapoints";
  86.         cmd += " HTTP/1.1\r\n";
  87.         cmd += "Host: api.yeelink.net\r\n";
  88.         cmd += "Accept: *";
  89.         cmd += "/";
  90.         cmd += "*\r\n";
  91.         cmd += "U-ApiKey: ";
  92.         cmd += APIKEY;
  93.         cmd += "\r\n";
  94.         cmd += "Content-Length: ";
  95.         int thisLength = 10 + getLength(thisData);
  96.     cmd += String(thisLength);
  97.         cmd += "\r\n";
  98.         cmd += "Content-Type: application/x-www-form-urlencoded\r\n";
  99.         cmd += "Connection: close\r\n";
  100.         cmd += "\r\n";
  101.         cmd += "{"value":";
  102.         cmd += String(thisData);
  103.         cmd += "}\r\n";
  104.         
  105.         
  106.         DebugSerial.println(cmd);
  107.         
  108.     wifi.Send(cmd);
  109.     // note the time that the connection was made:
  110.     lastConnectionTime = millis();
  111.   }
  112.   else {
  113.     // if you couldn't make a connection:
  114.     DebugSerial.println("connection failed");
  115.     DebugSerial.println("disconnecting.");
  116.     wifi.closeMux();
  117.   }
  118. }

  119. int getLength(int someValue) {
  120.   // there's at least one byte:
  121.   int digits = 1;
  122.   // continually divide the value by ten,
  123.   // adding one to the digit count for each
  124.   // time you divide, until you're at 0:
  125.   int dividend = someValue /10;
  126.   while (dividend > 0) {
  127.     dividend = dividend /10;
  128.     digits++;
  129.   }
  130.   // return the number of digits:
  131.   return digits;
  132. }




  133. int dht11_read(int pin)
  134. {
  135.         // BUFFER TO RECEIVE
  136.         int bits[5];
  137.         int cnt = 7;
  138.         int idx = 0;

  139.         // EMPTY BUFFER
  140.         for (int i=0; i< 5; i++)
  141.         {bits[i]= 0;}[/i]

  142. [i]        // REQUEST SAMPLE[/i]
  143. [i]        pinMode(pin, OUTPUT);[/i]
  144. [i]        digitalWrite(pin, LOW);[/i]
  145. [i]        delay(18);[/i]
  146. [i]        digitalWrite(pin, HIGH);[/i]
  147. [i]        delayMicroseconds(40);[/i]
  148. [i]        pinMode(pin, INPUT);[/i]

  149. [i]        // ACKNOWLEDGE or TIMEOUT[/i]
  150. [i]        unsigned int loopCnt = 10000;[/i]
  151. [i]        while(digitalRead(pin) == LOW)[/i]
  152. [i]                if (loopCnt-- == 0) return -2;[/i]

  153. [i]        loopCnt = 10000;[/i]
  154. [i]        while(digitalRead(pin) == HIGH)[/i]
  155. [i]                if (loopCnt-- == 0) return -2;[/i]

  156. [i]        // READ OUTPUT - 40 BITS => 5 BYTES or TIMEOUT[/i]
  157. [i]        for (int i=0; i<40; i++)[/i]
  158. [i]        {[/i]
  159. [i]                loopCnt = 10000;[/i]
  160. [i]                while(digitalRead(pin) == LOW)[/i]
  161. [i]                        if (loopCnt-- == 0) return -2;[/i]

  162. [i]                unsigned long t = micros();[/i]

  163. [i]                loopCnt = 10000;[/i]
  164. [i]                while(digitalRead(pin) == HIGH)[/i]
  165. [i]                        if (loopCnt-- == 0) return -2;[/i]

  166. [i]                if ((micros() - t) > 40) bits[idx] |= (1 << cnt);[/i]
  167. [i]                if (cnt == 0)   // next byte?[/i]
  168. [i]                {[/i]
  169. [i]                        cnt = 7;    // restart at MSB[/i]
  170. [i]                        idx++;      // next byte![/i]
  171. [i]                }[/i]
  172. [i]                else cnt--;[/i]
  173. [i]        }[/i]

  174. [i]        // WRITE TO RIGHT VARS[/i]
  175. [i]        // as bits[1] and bits[3] are allways zero they are omitted in formulas.[/i]
  176. [i]        humidity    = bits[0]; [/i]
  177. [i]        temperature = bits[2]; [/i]

  178. [i]        int sum = bits[0] + bits[2];  [/i]

  179. [i]        if (bits[4] != sum) return -1;[/i]
  180. [i]        return 0;[/i]
  181. [i]}
复制代码


在SSID和PASSWORD宏定义中修改成自己的WIFI名称和密码。

#define SSID      "Itead_1(Public)"        //type your own SSID name
#define PASSWORD  "27955416"            //type your own WIFI password

接着,把刚才所取得的APIKEY,设备的ID值和传感器的ID值替换到程序相应的位置中。设备的ID值替换代码中DEVICEID的值,传感器的ID值替换代码中SENSORID的值。

// for yeelink api
#define APIKEY         "7bf75e6c2c8a17351d557f206f89fa2e"// replace your yeelink api key here
//replace the device ID and sensor ID for temperature sensor.
#define DEVICEID0       3047 //replace your device ID
#define SENSORID0       4285 //replace your sensor ID
//replace the device ID and sensor ID for humidity sensor.
#define DEVICEID1       3047 // replaceyour device ID
#define SENSORID1       26142 //replace your sensor ID

修改完后,把该程序烧写到mega中去。

然后打开Serial monitor,等待一段时间后,会看到串口会显示它的ip地址,接着他就会每隔10s钟上传一次数据。



3. 查看数据图表

用网页打开yeelink平台,输入账号密码后,在用户中心的“我的设备”里可以看到温度和湿度的数据曲线。

手机还可以下载yeelink的客户端:http://www.yeelink.net/developer/tools




IoTgo:一个完全开源的物联网平台
由于各种不可控因素,包括硬件固件、平台通信等,小伙伴们在使用我们前面教程提供的ESP8266库文件后,经常遇到编译出错的问题或者对物联网控制方面的内部通信不了解,无法深度开发自己的项目。

在此,ITEAD Studio已经开发了一个现成的、完全开源的物联网平台,所有源码都可以在github下载,包括服务器搭建、web APP、手机APP、桌面APP以及量身定制的Arduino库文件(ESP8266、W5x00、SIM900等)。当然,后续我们也会有详细操作教程一一奉献给大家。

IoTgo项目的初衷是想让用户可以像部署zencart搭建博客,安装 phpbb创建论坛一样,通过部署IoTgo建立自己的云端服务器。服务器不仅仅是接口开放,而是全部代码开源。

项目介绍:http://www.leiphone.com/news/201502/ImM5BlLyyK4bEmQr.html

代码Github链接 :


免费版本:BETA版本通信协议层仅支持HTTP Websocket; 年后通信协议层会支持MQTT, CoAP
商业版本:通信协议层成使用 ARM授权的mbed ds

IoTgo 制作成了 Docker Image,发布到了 Docker Hub 上面:https://registry.hub.docker.com/u/humingchun/iotgo/

使用 IoTgo Docker Image,可以仅用 4 条命令在几分钟内部署 IoTgo 服务,详情请参考 IoTgo Github 文档。视频及图片教程等年后...

今天先简单介绍下如何在IoTgo这个平台获取API Key和设备ID。
我们搭建了两个服务器,版面是一样的:

国内快速访问http://iotgo.itead.cn   
国外快速访问http://iotgo.iteadstudio.com


更多内容可以一一进入其他导航页面查看。这里我们主要介绍下如何创建自己的DIY设备。

首先,我们需要在IoTgo平台上注册一个用户账号。在页面右上角点击“SING UP”即可进入注册页面。
注意:注册非常简单,填写的邮箱地址将作为你的登录账号,密码只确认一次,请牢记注册密码,暂时不提供密码找回功能。
点击“Sign Up”按钮,如果你的邮箱地址已经被注册过,将会提示“该邮箱地址已存在,请使用另一个邮箱”。如果是第一次注册,将会直接登录到系统后台。这种情况应该很少,如果有的话就是你把密码忘记了。

左边栏的个人账户中心有两个选项“My Profile(我的身份)”和“My Device(我的设备)”。


点开“我的身份”这个选项,可以看到自己的账户邮箱地址和API Key,以及修改密码功能。这里的重点是API Key,这个大家应该都懂的。


有了API Key以后,我们就可以创建自己的设备了。点开左边栏的“我的设备”选项,在右上角点击“Creat DIY Device(创建DIY设备)”。


“创建DIY 设备”旁边有个“Add Indie Device(添加成品设备)”按钮,这个是用于用户添加已经出厂就预设好API Key的成品,比如wifi智能开关,只需联网即可使用,不需要编程或者做任何修改,适合终端消费者,略过不谈。

接下来,在打开的添加DIY设备页面可以看到,目前用户可以添加的DIY设备分为4类:“01 Power switch(电源开关)”、“02 Simple light(灯光控制)”、“03Temperature and humidity sensor(温湿度传感器)”和“04 Custom device type(定制类或自行开发设备)”。

我们先来创建一个温湿度数据上传的传感器设备。在设备名称我们输入“机房温湿度”,设备类型选择“03 Temperature and humidity sensor(温湿度传感器)”,在组名输入“1号机房”,最后点击“Creat”创建按钮。


创建完成后,在“我的设备”页面就可以看到这个新增的设备图标。

现在我们点击这个设备图标,就可以看到这个设备目前的状态和ID号以及修改、删除等操作按钮。

同理,我们可以创建另外三种DIY设备,并得到对应的设备ID。

每个组别可以添加多个设备,只需在创建设备的时候填入要放置的组名即可。

设备ID是该传感器设备在服务器系统的唯一标识,上传数据的时候必须经过设备ID和账户API Key进行有效性验证才能成功上传。

至此,我们就成功得到了上传数据所需的服务器验证。

今天关于IoTgo平台的介绍就先到这里。下期我们将开始连载基于这个开源平台的远程控制教程。

第一篇:使用MEGA2560+ESP8266+SHT10温湿度实现实时数据上传,敬请期待!





本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
回复

使用道具 举报

发表于 2014-10-15 18:33:18 | 显示全部楼层
{:soso_e142:}{:soso_e179:}多谢分享。。。严重支持!!!
回复 支持 反对

使用道具 举报

发表于 2014-10-15 22:19:36 | 显示全部楼层
感謝分享.   支持! 支持!  {:soso_e179:}{:soso_e179:}{:soso_e179:}
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-16 09:14:46 | 显示全部楼层
Paderboy 发表于 2014-10-15 18:33
多谢分享。。。严重支持!!!

谢谢支持!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-16 09:16:32 | 显示全部楼层
Super169 发表于 2014-10-15 22:19
感謝分享.   支持! 支持!

谢谢!期待大家用物联网平台实现wifi控制的作品哦!当前演示只是局域网的哦。
回复 支持 反对

使用道具 举报

发表于 2014-10-16 09:30:12 | 显示全部楼层
本帖最后由 Super169 于 2014-10-16 09:31 编辑
ITEAD创易工作室 发表于 2014-10-16 09:16
谢谢!期待大家用物联网平台实现wifi控制的作品哦!当前演示只是局域网的哦。


我也在8 月時就開始測試 ESP8266了, 之前買了三片, 壞了一片.
後尾聽說 ESP8266 還在測試階段, 不太穩定, 就沒再研究了.
看到你的庫後, 正準備略作修改後, 把現在使用 W5100 的監察系統, 轉到 ESP8266.

請問 ESP8266 如果作長時間工作 (7x24) 的話, 穩定嗎?  如果可以的話, ESP8266 成本更低, 而且可以使用較少的 IO (但如只有一個 HW Serial 時, debug 就有點不方便, 如用 mega 之類就沒問題了), 庫也比 W5100 簡單得多.
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-16 10:01:05 | 显示全部楼层
Super169 发表于 2014-10-16 09:30
我也在8 月時就開始測試 ESP8266了, 之前買了三片, 壞了一片.
後尾聽說 ESP8266 還在測試階段, 不太穩 ...

7*24小时我们也没测试过,不过识别IP和联网都挺快的。
详细资料下载地址:http://pan.baidu.com/s/1ntjyrzz
回复 支持 反对

使用道具 举报

发表于 2014-10-16 10:48:03 | 显示全部楼层
謝謝你的資料, 我在 QQ 群的文件庫中也下載了不少資料, 未有時間詳細研究, 只測試過連接 Router 及簡單的網路功能就停了.  但對 ESP8266 提供低成平 WiFi 方案, 確實有興趣.

這個星期就嘗試把你的庫套到我的程式中, 增加一個對 ESP8266 支援的 class.

有些地方想請教的, 我看到你的庫中, 一般以 3秒為基本指令 timeout 時間, 5 秒為發送指令 timeout 時間, 但如果指定時間內收不到預定的字串 (例如 "Ready" 或 "OK" 之類), 應該怎樣處理比較好?  另外就是發送 WiFi.Send 之後, 接收網上回傳的資料 (應該只是簡單的先 等待 Serial.avaialble 再 Serial.read 吧), 這部份好像沒做出來.  

大致流程在寫 W5100 時也做了一次, 只是想看看如何修改配合 uartWiFi 使用.  例如 在 W5100 時, 可以檢查 connection status 而知道 HTTP request 後, 是否已經完成接收有關的資料回傳, 而決定何時執行 clinet.stop. 但在 uartWFi 中, 跟伺服的連線 是否有方法可以檢查?  又或是如何判定伺服器的回傳已經完結?  在 webclientRepeating 的例子中, 是在 loop 中不斷檢查 WiFi message, 但現實的情況, 必須有方法判定資料回傳是否已完成, 否則可能都會被判定為 timeout.  又或要解拆回傳的內容...那太痛苦了, 對 IoT 上傳資料, 個別的成功與否不太重要.    又或如果之前的 http request 回傳未完成之前, 我再發出 http request, 會有什麼後果?
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-16 17:53:52 | 显示全部楼层
这个低成本的wifi模块用在mega板子上的话,主控板确实不能很好地支持,发射还可以,接收的话处理不了太多的信息。目前的库是如果收不到预定的字串,就停在那里了,没做处理。当然通信处理方面还是可以优化的,只是我们目前没有时间去优化,希望大家一起帮忙改进。如果要用这个wifi模块做项目的话,建议使用arm级主控。
回复 支持 反对

使用道具 举报

发表于 2014-10-22 23:31:09 | 显示全部楼层
不错,刚买了模块就有库了,赞一个。ITEAD听说过,好像也买过产品
回复 支持 反对

使用道具 举报

发表于 2014-10-25 21:23:46 | 显示全部楼层
为什么我发送字符前面会有”+IPD,0,1:“  需要怎么弄呢?
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-27 17:08:54 | 显示全部楼层
nick_zm 发表于 2014-10-22 23:31
不错,刚买了模块就有库了,赞一个。ITEAD听说过,好像也买过产品

谢谢关注和支持!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-11-10 15:36:41 | 显示全部楼层
单个UNO不能从串口看到ESP8266的状态,因为仅有的一对串口已经被它占用作为通信了。需要使用mega2560或者增加一个转串板来读取状态。
回复 支持 反对

使用道具 举报

发表于 2014-11-12 15:45:36 来自手机 | 显示全部楼层
请教下楼主,你的库设置的与ESP8266通信的串口波特率是115200吗?
回复 支持 反对

使用道具 举报

发表于 2014-11-18 20:48:07 | 显示全部楼层
顶,楼主辛苦。
回复 支持 反对

使用道具 举报

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

本版积分规则 需要先绑定手机号

Archiver|联系我们|极客工坊

GMT+8, 2024-4-20 01:39 , Processed in 0.047962 second(s), 25 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2021, Tencent Cloud.

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