Arduino爱好者

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 129899|回复: 60

【库和教程】ESP8266 WIFI模块连接Yeelink平台

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

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

ITEAD首款智能wifi通用改装件上市:http://www.arduino.cn/thread-17423-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配件.jpg

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

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

此处也可以使用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

代码如下:
[mw_shl_code=c,true]
#define SSID "ITEAD_2"        //type your own SSID name
#define PASSWORD "27955416"        //type your own WIFI password


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

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


void setup()
{

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

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

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


}
void loop()
{

char buf[100];
int iLen = wifi.ReceiveMessage(buf);
if(iLen > 0)
{


if (strcmp(buf, "CH0ON") == 0)
{
digitalWrite(6,HIGH);  //使用mega的时候在不改变接线的情况下,此处改为24脚
DebugSerial.println("CH0ON");
}
if (strcmp(buf, "CH0OFF") == 0)
{
digitalWrite(6,LOW); //使用mega的时候在不改变接线的情况下,此处改为24脚
DebugSerial.println("CH0OFF");
}
}
}
[/mw_shl_code]

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

UNO接线如图:

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

ITEADUINO MEGA2560接线如图:
mega.jpg
此处的Xbee扩展板的跳帽应该是2和3,而不是0和1,此处有错。正确跳帽如下:

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

Xbee扩展板插在TX2RX2这排排母上。如图:
mega插脚.jpg

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

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




                   ↑ UNO和MEGA串口打印的信息

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

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

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

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

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

设置后.png
                                  ↑修改前
设置前.png
                                ↑修改后

输入完成后,点击“返回”到操作界面,此时点击OnOff就可以成功控制开关了!
IMG_0154.JPG
                             关状态(UNO)
IMG_0137.JPG
                       开状态(UNO)
IMG_0160.JPG
                                   关状态(MEGA)
IMG_0159.JPG
                                    开状态(MEGA)




可以收到串口打印信息如下:
成功开关.png
               ↑ UNO串口打印信息
开关成功.png
                   ↑MEGA串口打印信息





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

使用ESP8266+UNO测试局域网控制

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

主要配件:
peijian.jpg

一张图介绍mini Rboard:
mini rboard.jpg

步骤:

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”,点击烧写程序。如下图:

foca.jpg

代码:
[mw_shl_code=c,true]/*
ESP8266 library

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

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

Connection:
When you use it with UNO board, the connection should be like these:
ESP8266_TX->D0
ESP8266_RX->D1
ESP8266_CH_PD->3.3V
ESP8266_VCC->3.3V
ESP8266_GND->GND

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

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

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

DebugSerial.println("hello");


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

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

#define SERIAL_BUFFER_SIZE 64

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





*/


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


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

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


void setup()
{
  pinMode(4,OUTPUT);
  pinMode(5,OUTPUT);
  pinMode(6,OUTPUT);
  pinMode(7,OUTPUT);
  wifi.begin();
  bool b = wifi.Initialize(STA, SSID, PASSWORD);
  if(!b)
  {
    DebugSerial.println("Init error");
  }
  delay(8000);  //make sure the module can have enough time to get an IP address
  String ipstring  = wifi.showIP();
  DebugSerial.println(ipstring);                //show the ip address of module
  
  delay(2000);
  wifi.confMux(1);
  delay(100);
  if(wifi.confServer(1,8080))
        DebugSerial.println("Server is set up");
        

}
void loop()
{
  
  char buf[100];
  int iLen = wifi.ReceiveMessage(buf);
  if(iLen > 0)
  {
    //mini Rboard D4 pin is relay,mini Rboard URL:http://item.taobao.com/item.htm? ... keTJ&id=39334222369

    if (strcmp(buf, "CH0ON") == 0)
    {
      digitalWrite(4,HIGH);  
          DebugSerial.println("CH0ON");
    }
    if (strcmp(buf, "CH0OFF") == 0)
    {
      digitalWrite(4,LOW);
          DebugSerial.println("CH0OFF");
    }
   /* the other 3 chanels below are for Rboard D5 D6 D7 , Rboard  URL:http://item.taobao.com/item.htm? ... keTJ&id=39334222369

if (strcmp(buf, "CH1ON") == 0)
    {
      digitalWrite(5,HIGH);     
          DebugSerial.println("CH1ON");         
    }
    if (strcmp(buf, "CH1OFF") == 0)
    {
      digitalWrite(5,LOW);     
          DebugSerial.println("CH1OFF");         
    }
    if (strcmp(buf, "CH2ON") == 0)
    {
      digitalWrite(6,HIGH);      
          DebugSerial.println("CH2ON");
    }
    if (strcmp(buf, "CH2OFF") == 0)
    {
      digitalWrite(6,LOW);
          DebugSerial.println("CH2OFF");      
    }
    if (strcmp(buf, "CH3ON") == 0)
    {
      digitalWrite(7,HIGH);
          DebugSerial.println("CH3ON");         
    }
    if (strcmp(buf, "CH3OFF") == 0)
    {
      digitalWrite(7,LOW);
          DebugSerial.println("CH3OFF");         
    }
    */

  }
}[/mw_shl_code]
黏贴代码到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上。
lianjie.jpg
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以上


硬件连接实物图:

硬件.jpg
Mini Rboard的引脚定义图:
mini rboard pinmap.jpg
ESP8266的引脚定义图:
wifi引脚.jpg

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

wifi.jpg

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

2. 下载UDP TCP Serverapp

打开手机的Google play,搜索UDP TCP Server,安装该软件。(不能翻墙和没有google账户和不能安装google play的小伙伴自行安装VPN和google play所需app)
app、.jpg
打开该软件,点击右上角的settings,将Target IP设置为wifi的IP地址,本文为172.16.1.12,以每次分配的实际IP为准。UPD/TCP选择TCP,TargetPort设置为8080,TCP connectionbehavior设置为“Initiate connection,and keep open”。

set.jpg

ip.jpg

然后返回上一级,点击Button Settings。设置buttons的数量为8个(适用于4通道的Rboard),分别在button的名字和命令上修改成:“CH0ON”, “CH1ON”, “CH2ON”, “CH3ON”, “CH0OFF”, “CH1OFF”, “CH2OFF”, “CH3OFF”。这分别代表设置对应继电器通道的开关状态。此次测试用的mini Rboard只需要用到“CH0ON”和“CH0OFF”这一个通道。
button.jpg
返回主页面,我们可以看到按钮的名称已改变,点击对应的按钮后,会看到miniRboard上对应的通道设置为按钮上的状态。
QQ图片20141015115026.jpg

演示视频:



uno.png
发表于 2015-2-14 23:23 | 显示全部楼层
本帖最后由 wangpingsx 于 2015-2-14 23:24 编辑

求助:始终不通呀。
我现在是esp8266直接链接arduino  UNO,  我的arduino IDE是 1.6  

我的连线是:
ESP8266_TX->D0
ESP8266_RX->D1
ESP8266_CHPD->3.3V
ESP8266_VCC->3.3V
ESP8266_GND->GND

我的HardwareSerial.h 在:  /Applications/Arduino1_6.app/Contents/Resources/Java/hardware/arduino/avr/cores/arduino/下边。
而且我也没有找到 :#define SERIAL_BUFFER_SIZE 64

对HardwareSerial.h, 我做了如下的修改:
#if !(defined(SERIAL_TX_BUFFER_SIZE) && defined(SERIAL_RX_BUFFER_SIZE))
#if (RAMEND < 1000)
#define SERIAL_TX_BUFFER_SIZE 256   16改为256
#define SERIAL_RX_BUFFER_SIZE 256   16改为256
#else
#define SERIAL_TX_BUFFER_SIZE 256    64改为256
#define SERIAL_RX_BUFFER_SIZE 256   64改为256
#endif
#endif


如果我也对uartWIFI.h做出了修改,打开了#define UNO, 并删掉了:// #define MEGA

我把我当前环境的SSID和密码都配置好了。

我的程序运行后总是显示:AT+RST

然后就没有结果了。



求大神帮忙, 谢谢!!!
 楼主| 发表于 2014-10-16 09:19 | 显示全部楼层

ESP8266 wifi模块上传数据到yeelink和IoTgo平台

本帖最后由 ITEAD创易工作室 于 2015-2-11 23:02 编辑


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

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

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

所需配件:
peij.jpg
步骤:

1. 硬件连接

杰斯按.jpg

硬件实物连接图

jiexin.jpg

2. 注册Yeelink账号

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

步骤如下:

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

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

注册.jpg

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

设置.jpg
地址.jpg

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

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

温度线.jpg
湿度线.jpg
完成上面的操作后,会得到相应的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
保存修改。

打开下载的ITEADLIB_ESP8266_master库文件里面的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。
[mw_shl_code=c,true]#define SSID       "Itead_1(Public)"                //type your own SSID name
#define PASSWORD   "27955416"                                //type your own WIFI password


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

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

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

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

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

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

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


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


int humidity;
int temperature;

int post_number;

void setup()
{

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




}
void loop()
{
  char message[400];
   // if you're not connected, and ten seconds have passed since
  // your last connection, then connect again and send data:
  if((millis() - lastConnectionTime > postingInterval)) {

  //read dht11
  int chk = dht11_read(DHT11PIN);
  if(chk==0)
  {
        if(post_number==0)
        {
                sendData(DEVICEID0,SENSORID0,temperature);
                post_number++;
        }
        else
        {
                post_number = 0;
                sendData(DEVICEID1,SENSORID1,humidity);
        }

  }

  }

  // if there's incoming data from the net connection.
  // send it out the serial port.  This is for debugging
  // purposes only:
  if(wifi.ReceiveMessage(message))
  {
      DebugSerial.println(message);   
  }


  delay(10);

}

// this method makes a HTTP connection to the server:
void sendData(int device_id,int sensor_id,int thisData) {
  // if there's a successful connection:
  if (wifi.ipConfig(TCP,server, 80)) {
    DebugSerial.println("connecting...");
    // send the HTTP PUT request:
    String cmd;
        cmd = "POST /v1.0/device/";
        cmd += String(device_id);
        cmd += "/sensor/";
        cmd += String(sensor_id);
        cmd += "/datapoints";
        cmd += " HTTP/1.1\r\n";
        cmd += "Host: api.yeelink.net\r\n";
        cmd += "Accept: *";
        cmd += "/";
        cmd += "*\r\n";
        cmd += "U-ApiKey: ";
        cmd += APIKEY;
        cmd += "\r\n";
        cmd += "Content-Length: ";
        int thisLength = 10 + getLength(thisData);
    cmd += String(thisLength);
        cmd += "\r\n";
        cmd += "Content-Type: application/x-www-form-urlencoded\r\n";
        cmd += "Connection: close\r\n";
        cmd += "\r\n";
        cmd += "{\"value\":";
        cmd += String(thisData);
        cmd += "}\r\n";


        DebugSerial.println(cmd);

    wifi.Send(cmd);
    // note the time that the connection was made:
    lastConnectionTime = millis();
  }
  else {
    // if you couldn't make a connection:
    DebugSerial.println("connection failed");
    DebugSerial.println("disconnecting.");
    wifi.closeMux();
  }
}

int getLength(int someValue) {
  // there's at least one byte:
  int digits = 1;
  // continually divide the value by ten,
  // adding one to the digit count for each
  // time you divide, until you're at 0:
  int dividend = someValue /10;
  while (dividend > 0) {
    dividend = dividend /10;
    digits++;
  }
  // return the number of digits:
  return digits;
}




int dht11_read(int pin)
{
        // BUFFER TO RECEIVE
        int bits[5];
        int cnt = 7;
        int idx = 0;

        // EMPTY BUFFER
        for (int i=0; i< 5; i++)
        {bits= 0;}

        // REQUEST SAMPLE
        pinMode(pin, OUTPUT);
        digitalWrite(pin, LOW);
        delay(18);
        digitalWrite(pin, HIGH);
        delayMicroseconds(40);
        pinMode(pin, INPUT);

        // ACKNOWLEDGE or TIMEOUT
        unsigned int loopCnt = 10000;
        while(digitalRead(pin) == LOW)
                if (loopCnt-- == 0) return -2;

        loopCnt = 10000;
        while(digitalRead(pin) == HIGH)
                if (loopCnt-- == 0) return -2;

        // READ OUTPUT - 40 BITS => 5 BYTES or TIMEOUT
        for (int i=0; i<40; i++)
        {
                loopCnt = 10000;
                while(digitalRead(pin) == LOW)
                        if (loopCnt-- == 0) return -2;

                unsigned long t = micros();

                loopCnt = 10000;
                while(digitalRead(pin) == HIGH)
                        if (loopCnt-- == 0) return -2;

                if ((micros() - t) > 40) bits[idx] |= (1 << cnt);
                if (cnt == 0)   // next byte?
                {
                        cnt = 7;    // restart at MSB
                        idx++;      // next byte!
                }
                else cnt--;
        }

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

        int sum = bits[0] + bits[2];  

        if (bits[4] != sum) return -1;
        return 0;
}
[/mw_shl_code]

SSIDPASSWORD宏定义中修改成自己的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钟上传一次数据。

监视器.jpg

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

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

手机温度.jpg
手机湿度.jpg


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。

iotgo.iteadstudio.com.jpg

我们搭建了两个服务器,版面是一样的,国内快速访问http://iotgo.itead.cn    国外快速访问http://iotgo.iteadstudio.com



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


首先,我们需要在IoTgo平台上注册一个用户账号。在页面右上角点击“SING UP”即可进入注册页面。

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

在左边栏的个人账户中心有两个选项“My Profile(我的身份)”和“My Device(我的设备)”。
左边栏.png
点开“我的身份”这个选项,可以看到自己的账户邮箱地址和API Key,以及修改密码功能。这里的重点是API Key,这个大家应该都懂的。
身份.png
有了API Key以后,我们就可以创建自己的设备了。点开左边栏的“我的设备”选项,在右上角点击“Creat DIY Device(创建DIY设备)”。
creat.png
“创建DIY 设备”旁边有个“AddIndie Device(添加成品设备)”按钮,这个是用于用户添加已经出厂就预设好API Key的成品,比如wifi智能开关,只需联网即可使用,不需要编程或者做任何修改,适合终端消费者,略过不谈。

接下来,在打开的添加DIY设备页面可以看到,目前用户可以添加的DIY设备分为4类:“01 Power switch(电源开关)”、“02 Simple light(灯光控制)”、“03 Temperature and humidity sensor(温湿度传感器)”和“04 Custom device type(定制类或自行开发设备)”。
设备类型.png
我们先来创建一个温湿度数据上传的传感器设备。在设备名称我们输入“机房温湿度”,设备类型选择“03 Temperature and humidity sensor(温湿度传感器)”,在组名输入“1号机房”,最后点击“Creat”创建按钮。
增加.png
创建完成后,在“我的设备”页面就可以看到这个新增的设备图标。
图标.png
现在我们点击这个设备图标,就可以看到这个设备目前的状态和ID号以及修改、删除等操作按钮。
id.png
同理,我们可以创建另外三种DIY设备,并得到对应的设备ID。
更多.png
每个组别可以添加多个设备,只需在创建设备的时候填入要放置的组名即可。

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

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

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

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


发表于 2014-10-17 14:47 | 显示全部楼层
多謝分享,很有參考價值
发表于 2014-10-18 21:58 | 显示全部楼层
这不是我写的库么。。。我擦
 楼主| 发表于 2014-10-20 09:15 | 显示全部楼层
.oο麽麽茶㊣ 发表于 2014-10-18 21:58
这不是我写的库么。。。我擦

是基于你的库修改的。
发表于 2014-10-20 10:01 | 显示全部楼层

一直没空写328的  软串口改成10 11更好~这样2560也可以用了~
 楼主| 发表于 2014-10-21 09:17 | 显示全部楼层
.oο麽麽茶㊣ 发表于 2014-10-20 10:01
一直没空写328的  软串口改成10 11更好~这样2560也可以用了~

这个库也可以用在2560的。软串口随便挑了两个脚,呵呵
//#define UNO
//#define MEGA
发表于 2014-10-21 11:18 | 显示全部楼层
顶    。。。。。  
发表于 2014-10-25 01:18 | 显示全部楼层
这个wifi模块很便宜呀, 就是不知道把它当作soc时要怎么用。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|Archiver|手机版|Arduino爱好者

GMT+8, 2023-2-9 13:58 , Processed in 0.083609 second(s), 20 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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