Android网络开发回顾之旅 ② 新年新气象,封装一个esp8266一键配网XSmartConfig , 支持自定义回调。(附带Demo)
Posted on 2018-02-15 14:57 CoreHouse 阅读(146) 评论(0) 收藏 举报- 本系列博客学习由非官方人员 半颗心脏 潜心所力所写,仅仅做个人技术交流分享,不做任何商业用途。如有不对之处,请留言,本人及时更改。 
一. 前言。
之前逛gitHub,有人问过是否支持自定义回调8266的信息,我想应该可以把?所以,一直想动手搞上位机的配网封装,因为太忙了,这几天临近过年有点时间,终于搞好了。
因为本人姓徐,所以命名为 XSmartConfig , 顾名思义原理和smartConfig一样,只是再封装一次。
二. 特点。
- ①、继承了乐鑫8266的一键配网 smartConfig , 保留了其功能。 
- ②、支持多个设备配网的功。 
- ③、支持隐藏的SSID配网。 
- ④、目前V1.0版本仅仅支持配网成功后的UDP回调接收,具体的协议请自定义。 
③. 集成方法与使用。
- 为了兼顾 Eclipse 开发,同时缩短周期,我就不放在 jCenter 了,打包成jar架包大家使用吧。jar包下载地址在下面。
- ①、所需的权限:
 <uses-permission android:name="android.permission.INTERNET" />
 <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
 <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
 <uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE" />
 <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
- ②、xEspTouchTask.java 类,是对外的API接口。详细使用方法,请到Demo查看。
 //这是我们平时用的smartConfig一键配网代码
 xEspTouchTask espTouchTask = new xEspTouchTask.Builder(this) //初始化
                    .setSsid(apSsid) //设置路由器的名字
                    .setPassWord(apPassword)  //设置路由器连接的密码
                    .creat(); //创建对象
           espTouchTask.startSmartConfig();  //开始执行,不带UDP的普通配网 //这是我们smartConfig一键配网后执行UDP接受过滤此设备的自定义一键配网
 xEspTouchTask espTouchTask = new xEspTouchTask.Builder(this) //初始化
                    .setSsid(apSsid) //设置路由器的名字
                    .setPassWord(apPassword)  //设置路由器连接的密码
                    .creat(); //创建对象
              espTouchTask.startSmartConfig(30, 8989);;  //开始执行带UDP协议的 一键配网,30是超时时间,8989是本地端口- ③、设置监听接口 EspTouchTaskListener()。
| code状态码 | message信息回调 | 说明 | 
|---|---|---|
| 0 | 表示成功配网,接着看message的信息,为一个包含设备的Mac地址和网关地址的Json | 一键配网成功回调 | 
| 1 | 为多个配网信息,还在配网中,其中message是刚刚配对成功的设备 | 只有设置了指定的个数配网设备才有回调 | 
| 2 | null | 表示一键配网配网失败 | 
| 3 | 表示成功接受到设备的UDP发来的自定义信息 | 仅当设置了端口号和超时时间才生效 | 
| 4 | null | 表示超过了设置超时时间,未接受到设备的UDP信息 | 
        espTouchTask.setEspTouchTaskListener(new xEspTouchTask.EspTouchTaskListener() {
            @Override
            public void EspTouchTaskCallback(int code, String message) {
                switch (code) {
                    case 0:
                        //一键配网成功...
                        break;
                    case 1:
                        //为多个配网信息,还在配网中,其中message是刚刚配对成功的设备
                        break;   
                    case 2:    
                       //表示配网失败;        
                        break;    
                    case 3:                 
                        //配网成功后,UDP广播后获取到的信息:message
                        break;
                    case 4:
                       //表示超过了设置超时时间,未接受到设备的UDP信息
                        break;
                }
            }
        });④. 关于如何自定义设备成功连接路由器后的信息回调 。
- 我说出来了这样的话语,那肯定有我解决的方法,鉴于我的想法如下,需要有点通讯知识才会看懂哦! - 设备成功连接路由器获取IP之后,确定您的设备和手机在同一个网段,之后设备开启UDP广播包,指定的远程端口号, 发送您的自定义信息。 
- 如果考虑到UDP广播不安全,您可以使用TCP协议,还记得8266那个smartConfig有个 手机的ip地址回调么?拿到这个地址之后,我们可以双方协议好,就好! 
- 但目前我仅仅做了UDP的。 如果您有想法,完全把我这份源码下载下来,做tcp协议。 
 
一句话概括:设备在配网成功获取IP之后,手机也会开启UDP接口来接受局域网的UDP信息包,这样就可以实行我们自定义的信息回调啦; 很多人会问,这样有什么好处,比如我设备已经连接路由器,但是不知道是否成功连接了MQTT服务器,您完全可以在连接MQTT之后再发送UDP广播包,之后关闭。
- 下面是我8266的部分UDP代码。 - UDP的地址为255,255,255,255
- 协议好的端口号 8989 。
 
void udp_client_init(void) {
    wifi_set_broadcast_if(0x01);     //设置 ESP8266 发送 UDP广播包时,从 station 接口发送
    user_udp_espconn.proto.udp = (esp_udp *) os_zalloc(sizeof(esp_udp));//分配空间
    user_udp_espconn.type = ESPCONN_UDP;              //设置类型为UDP协议
    user_udp_espconn.proto.udp->local_port = 2000;            //本地端口
    user_udp_espconn.proto.udp->remote_port = 8989;           //目标端口
    const char udp_remote_ip[4] = { 255, 255, 255, 255 };       //目标IP地址(广播)
    os_memcpy(user_udp_espconn.proto.udp->remote_ip, udp_remote_ip, 4);
    espconn_regist_recvcb(&user_udp_espconn, user_udp_recv_cb);         //接收
    espconn_regist_sentcb(&user_udp_espconn, user_udp_sent_cb);         //发送
    espconn_create(&user_udp_espconn);            //建立 UDP 传输
    getUDPSendMessage();
    os_timer_disarm(&sendDataTimer);      //取消定时器定时
    os_timer_setfn(&sendDataTimer, (os_timer_func_t *) timerSendData,
    NULL);    //设置定时器回调函数
    os_timer_arm(&sendDataTimer, 2500, 1);    //启动定时器,单位:毫秒
}
 
                    
                     
                    
                 
                    
                 
 
         
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号