对于Combo设备(同时支持Wi-Fi和BLE),除了可以先配网再绑定设备(即蓝牙辅助配网开发实践),还可以先绑定设备再配网,且该方式配网速度更快。当您的业务场景需要快速配网时,可根据本文档来进行App端的Android系统开发。

操作步骤

  1. 创建一个自有App,详细操作请参见创建自有App
  2. 获取App端SDK。详细操作请参见下载并集成SDK
  3. 初始化SDK。详细操作请参见SDK初始化
  4. 开发Combo设备发现。

    Combo设备通过调用LocalDeviceMgr中的startDiscovery方法来实现设备发现。如果您已实现过设备发现业务,则在该基础上,在EnumSet<DiscoveryType>入参中新增⼀个DiscoveryType.BLE_ENROLLEE_DEVICE类型即可。

    1. 发起本地发现。
      EnumSet<DiscoveryType> discoveryTypes=EnumSet.of(DiscoveryType.CLOUD_ENROLLEE_DEVICE, DiscoveryType.SOFT_AP_DEVICE, DiscoveryType.LOCAL_
      ONLINE_DEVICE, DiscoveryType.BLE_ENROLLEE_DEVICE);
      LocalDeviceMgr.getInstance().startDiscovery(AApplication.getInstance
      (), discoveryTypes, null, new IDeviceDiscoveryListener() {
       @Override
       public void onDeviceFound(DiscoveryType discoveryType, L
      ist<DeviceInfo> list) {
      
       }
       });
    2. 调用获取产品productKey接口来使用productId换取设备的ProductKey。
    3. 调用本地发现设备列表信息过滤接口来过滤掉非法设备(如已绑定的设备等)。
      说明 对于Combo设备,该接口的请求参数中deviceName需配置为Combo设备的MAC地址。
  5. 开发Combo设备绑定。

    下面以公版App为示例介绍Combo快速配网流程,您可以根据自己的业务逻辑来实现。

    1. 调用蓝牙上线接口DevService.breezeSubDevLogin,传入ProductKey、MAC等参数。

      示例代码如下。

      DevService.breezeSubDevLogin(pk, mac, new DevService.ServiceListener() {
          @Override
          public void onComplete(boolean b, Object o) {
          }
      });

      调用接口后SDK会通过onComplete接口返回蓝牙上线结果。如果蓝牙上线成功则继续绑定操作;蓝牙上线失败,则流程结束。

    2. 调用基于时间窗口方式的绑定设备接口在云端绑定设备。
    3. 调用DevService.notifySubDeviceBinded接口通知设备绑定结果。

      示例代码如下。

      private void tmpNotify(String iotId){
              ALog.d(TAG,"tmpNotify->"+iotId);
              SubDevInfo subDevInfo=new SubDevInfo();
              subDevInfo.iotId=iotId;
              if (netType==ILopNetTypeCodes.NET_TYPE_BT){
                  ALog.d(TAG,"mac->"+mac);
                  subDevInfo.deviceName=mac;
              }else {
                  ALog.d(TAG,"dn->"+dn);
                  subDevInfo.deviceName=dn;
              }
              subDevInfo.productKey=pk;
      
      // 调用DevService.notifySubDeviceBinded接口通知设备已绑定成功
              DevService.notifySubDeviceBinded(subDevInfo,new DevService.ServiceListener(){
      
                  @Override
                  public void onComplete(boolean b, @Nullable Object o) {
                      ThreadTools.runOnUiThread(new Runnable() {
                          @Override
                          public void run() {
                              gotoStepFinish();
                          }
                      });
                  }
              });
      
          }
  6. 开发Combo设备配网。
    说明

    Combo设备类型为DiscoveryType.COMBO_SUBTYPE_0X04_DEVICE,表示已配网,此时您可忽略该步骤的以下操作。

    1. 开始配网时,设置wifistateDeviceWifiStatus_Setting,表示Wi-Fi正在配置中。

      示例代码如下。

      DevService.setWifiStatus(iotID, TmpEnum.DeviceWifiStatus.DeviceWifiStatus_Setting, new DevService.ServiceListenerEx() {
         @Override    
      public void onComplete(boolean b, @Nullable String s) {
              
      }});
    2. 调用AddDeviceBiz.getInstance().setDevice设置配网信息。

      示例代码如下。

      DeviceInfo deviceInfo = new DeviceInfo();
      deviceInfo.devType = ILopNetTypeCodes.DEV_TYPYE_BLE_SUBTYPE_3;
      deviceInfo.mac = mac;
      deviceInfo.linkType = LinkType.ALI_BLE.getName();
      RegionInfo regionInfo = new RegionInfo();
      regionInfo.shortRegionId = 0;
      deviceInfo.regionInfo = regionInfo;
      ProvisionConfigParams params = new ProvisionConfigParams();
      params.ignoreSoftAPRecoverWiFi = true;
      params.enableGlobalCloudToken = true;
      ProvisionConfigCenter.getInstance().setProvisionConfiguration(params);
      AddDeviceBiz.getInstance().setDevice(deviceInfo);
    3. 调用AddDeviceBiz.getInstance().startAddDevice方法发起配网。

      示例代码如下。

      
      
      
      AddDeviceBiz.getInstance().startAddDevice(AApplication.getInstance(), new IAddDeviceListener() {
          @Override
          public void onPreCheck(boolean b, DCErrorCode dcErrorCode) {
      
          }
      
          @Override
          public void onProvisionPrepare(int prepareType) {
              if (prepareType == 1) {
      //传入SSID和Wi-Fi密码开始配网
                 AddDeviceBiz.getInstance().toggleProvision(ssid, password, 60);
              }
          }
      
          @Override
          public void onProvisioning() {
      
          }
      
          @Override
          public void onProvisionStatus(ProvisionStatus provisionStatus) {
              if ((provisionStatus != null) && provisionStatus.code() == ProvisionStatus.BLE_DEVICE_SCAN_SUCCESS.code()) {
                  ALog.d(TAG, "BLE_DEVICE_SCAN_SUCCESS");
                  if (provisionStatus.getExtraParams() != null) {
              //扫描到该设备
                      String devType = (String) provisionStatus.getExtraParams().get(ILopNetTypeCodes.KEY_DEV_TYPE);
                      String bleMac = (String) provisionStatus.getExtraParams().get(ILopNetTypeCodes.KEY_BLE_MAC);
                      String prouctID = (String) provisionStatus.getExtraParams().get(ILopNetTypeCodes.KEY_PRODUCT_ID);
                      ALog.d(TAG, "devType->" + devType + " bleMac->" + bleMac + " prouctID->" + prouctID);
                      if (ILopNetTypeCodes.DEV_TYPYE_BLE_SUBTYPE_3.equals(devType)){
                  //继续配网
                          AddDeviceBiz.getInstance().continueProvision(null);
                      }
                  }
              }
          }
      
          @Override
          public void onProvisionedResult(boolean isSuccess, DeviceInfo deviceInfo, DCErrorCode dcErrorCode) {
              String message = "onProvisionedResult. isSuccess:" + isSuccess + " deviceInfo:" + deviceInfo + " dcErrorCode:" + dcErrorCode;
              ALog.d(TAG, message);
              ThreadTools.runOnUiThread(new Runnable() {
                  @Override
                  public void run() {
                     AddDeviceBiz.getInstance().stopAddDevice();//配网完成,结束当前配网流程
                      if (isSuccess) {
                     //配网成功
      
                      } else {
                        //配网失败
                      }
                  }
              });
      
          }
      });
                                          
  7. 调用DevService#setWifiStatus向TMP通知设备的配网结果。

    示例代码如下。

    DevService.setWifiStatus(iotID, TmpEnum.DeviceWifiStatus.state, new DevService.ServiceListenerEx() {
       //配网成功state为DeviceWifiStatus_Set;配网不成功state为DeviceWifiStatus_NotSet
    @Override
        public void onComplete(boolean b, @Nullable String s) {
             }
    });