HarmonyOS碰一碰基本功能如何实现

描述

碰一碰简单来说就是,使用 NFC 拉起配网 FA,入网之后,使用控制 FA 进行设备控制。

总结下来开发碰一碰能力需要 3 部分:

设备端:安装碰一碰固件程序。

手机端:可以使用原子化服务配网模板、控制模板。

NFC 标签:存放设备端信息。用原子化服务的包名→生成 Product ID,用于拉起 FA。

接下来参考官方 demo 和 OneHop 模板来体验下碰一碰的流程。

设备端

①源码下载

硬件需要 Hi3861,OpenHarmony 版本需要 1.1.0,可以 repo 拉取。

repo init -u https://gitee.com/openharmony/manifest.git -b refs/tags/OpenHarmony_release_v1.1.0 --no-repo-verify
repo sync -c
 

 

关于 Ubuntu 编译环境搭建可以参考软通动力大佬的帖子,写的特别详细:

 

https://harmonyos.51cto.com/posts/9453
   

 

首先要完成官方镜像的拉取和编译,成功之后在尝试安装 OneHop 设备端代码,设备端代码获取链接:

 

https://gitee.com/openharmony-sig/knowledge_demo_smart_home/tree/master/dev/team_x/demo_winder

 

OneHop 设备端固件代码,只需要 hals 和 winder 两个文件夹,为了方便大家下载,我在文末上传了这两个文件夹。这两个文件夹需要拷贝到 applications/sample/wifi-iot/app/ 目录下。

②源码修改

修改文件:

 

device/hisilicon/hispark_pegasus/hi3861_adapter/hals/communication/wifi_lite/wifiservice/source/wifi_device.c

 

代码如下:

 

static void HiWifiWpaEventCb(const hi_wifi_event *hisiEvent)
{
    if (hisiEvent == NULL) {
        return;
    }
    /*注释此处
    if (LockWifiEventLock() != WIFI_SUCCESS) {
        return;
    }
    */
    for (int i = 0; i < WIFI_MAX_EVENT_SIZE; i++) {
        if (g_wifiEvents[i] == NULL) {
            continue;
        }
        DispatchEvent(hisiEvent, g_wifiEvents[i]);
    }
    /*注释此处
    if (UnlockWifiEventLock() != WIFI_SUCCESS) {
        return;
    }
    */
}

 

  设备端使用到了 I2C 的屏幕,所以需要在 make 的 config 文件中开启 I2C 的支持。   具体操作如下:

打开下面文件,注意取消前面的#号:

 

device/hisilicon/hispark_pegasus/sdk_liteos/build/config/usr_config.mk

 

 

- # CONFIG_I2C_SUPPORT is not set
+ CONFIG_I2C_SUPPORT=y

 

为了方便调试需要关闭 test 子系统,在 vendorhisiliconhispark_pegasusconfig.json 文件中,删除下面代码,注意逗号。

 

,
      {
       "subsystem": "test",
       "components": [
         { "component": "xts_acts", "features":[] },
         { "component": "xts_tools", "features":[] }
        ]
      }

 

最后将 app 添加到编译框架,在 applications/sample/wifi-iot/app/BUILD.gn 文件,将 features 字段中的 startup 修改为 winder,并添加 winder 模块的索引 deps。

 

 import("//build/lite/config/component/lite_component.gni")

   lite_component("app") {
   #将startup修改为winder
   features = [
       "winder",
   ] 
   #添加winder模块的索引deps
   deps = [ "//applications/sample/wifi-iot/app/hals:hi3861_hals" ] 
 }

 

③构建编译

1.1.0 的构建使用的是 hb 命令,方式如下:

 

hb set                # 设置编译路径
.                    # 选择当前路径
# hisilicon            # 选择编译的目标类型
    > wifiiot_hispark_pegasus
      ipcamera_hispark_aries
      ipcamera_hispark_taurus

hb build -b debug    # 执行编译

 

烧录推荐使用 HiBurn,简单高效,一张图就明白了。

nfc

nfc

最后烧录完成提示:

 

Execution Successful
     

 

手机端

①编辑模板

手机端就简单了,安装 DevEco Studio 3.0 Beta1 及以上版本,然后 IDE 自带 OneHop 的模板。

 

https://developer.harmonyos.com/cn/develop/deveco-studio#download_beta

 

nfc

②获取证书

源码不怎么需要修改,但是在真机上运行程序,需要在线获取签名证书。基本流程就是在 AppGallery Connect 注册项目和应用,然后用 IDE 软件自动获取。

 

https://developer.huawei.com/consumer/cn/service/josp/agc/index.html#/myProject

 

需要注意的是网站注册时的包名要和 src/main/config.json 中"bundleName"保持一致不然是获取不到的。

这部分出问题参考官方文档吧,文档很详细:

 

https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ide_debug_device-0000001053822404#section837891802519

 

再就是为了方便调试可以先关闭免安装功能(在 src/main/config.json 中,将"installationFree"设置为 false)这样桌面会生成应用图标,无需 NFC 贴纸,打开图标一样可以实现设备配网、控制。

 

"installationFree": false

 

③测试 APP

  到这里可以先打开桌面的 app 测试下配网功能,这里有坑,目前示例的稳定性很差,配网大概率会失败。

先关闭手机 wifi 再打开,然后 Hi3861 上电,再然后开启配网 app 可以提高成功率。

正常情况下配网成功就会自动拉起控制 FA,控制 FA 需要在 DevEco Studio 菜单栏 Run→Edit Configurations。

勾选 entry 模块下的“Deploy Multi Hap Packages”选项,这样项目中的多个模块都能添加到手机端。

如果这样配网完成还是不能自动拉起控制 FA,那么检查下 default/pages/netconfig/netconfig.js,检查下这个函数参数是否正确。

 

let target = {
    bundleName: 'com.liangzili.myonehop.hmservice',
    abilityName: 'com.liangzili.myonehop.ControlMainAbility',
    deviceType: 1,
    data: {

        session_id: getApp(this).ConfigParams.deviceInfo.sessionId,
        product_id: getApp(this).Product.productId,
        product_name: getApp(this).Product.productName
    }
}
FeatureAbility.startAbility(target);
     

 

NFC 标签

      标签的作用类似新建一个快捷方式,然后把快捷方式贴到设备上,手机碰一下打开这个快捷方式就可以自动下载配网 FA 和控制 FA,只要 app 体积在 10M 以内,这些操作用户是感受不到的。接下来就说说这个标签的制作方法。  

①制作贴纸

首先当然是需要购买一些 NFC 贴纸,我使用的是下图这一种。

 

给 NFC 贴纸写内容需要一个 APP,在华为应用市场,搜索“应用调测助手”安装即可。

写入贴纸的信息一共 2 条 Product ID 和设备 SN,或者一些自定义信息。只有 Product ID 是必填的,这个在 APP 拿包名申请即可。  

②设置意图

  当手机碰触 NFC 贴纸的时候,手机需要通过 Product ID 去云端获取用户意图。

所以需要登录华为开发者门户设置下,当检测到设置的 Product ID 是要执行的操作。

 

nfc

主要的设置就在这里,可以看到配网 FA 是通过 NFC 贴纸拉起的,而控制 FA 是配网 FA 拉起的:

“App 包名”填写为 config.json 文件中的 bundleName 字段取值。

“模块名”填写为入口原子化服务(即设备配网模块)config.json 文件中的 moduleName 字段取值。

“服务名”填写为入口原子化服务(即设备配网模块)config.json 文件中的 mainAbility 字段取值。

这样碰一碰的功能基本就实现了。    

总结

      大部分的内容官方文档都有详细说明,我只写了不一样的地方,和我踩过的雷,希望能给大家避避坑。详细流程还是要结合官方文档看。

 

原文标题:鸿蒙“碰一碰”功能实现!

文章出处:【微信公众号:HarmonyOS技术社区】欢迎添加关注!文章转载请注明出处。

  审核编辑:彭菁
 

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分