欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

企业者的福音之8266接入阿里智能,点亮一盏灯

程序员文章站 2022-05-15 14:18:20
...

代码地址如下:
http://www.demodashi.com/demo/12178.html


企业者的福音之8266接入阿里智能,点亮一盏灯


一、前言。


最近的天猫精灵火热朝天,双十一仅仅99块就抱回家!这门博文,涉及到绝大部分的接入阿里智能的商业者,为了隐私,我必须要把某些图片的信息隐藏 !但是我会把整个过程给需要的人理顺 一下,绝不是为了凑人气而写。

  • 如果你没有企业的注册信息,不用往下看了!只有在阿里智能注册签订协议的商家,方可开发!

1.1 了解ALINK 阿里智能开发平台。

智能硬件模组、阿里智能云、阿里智能 APP,阿里智能生活事业部为厂商提供一站式设备智能化解决方案。

  • 申请接入阿里智能平台的模组必要要有阿里智能官方的认证!否则不允许接入!已通过认证的模组列表:点击查看

  • 乐鑫官网已经给出了接入阿里智能的Demo点击查看,我们开发者不需自己搭建框架,只需关注上发逻辑和下发逻辑处理即可,这个和机智云的一站式开发一样的道理!

  • 由于指定的操作是 freertos ,并非 nons ,所以本博文的工程,不能直接导入就编译,个人最好的方法就是Windows平台搭建Linux虚拟机导入8266的系统,进行编译。

  • 成功上架的产品,均可被天猫精灵语音控制,不管是哪个厂商的设备,只有接入阿里智能,都可以实现语音控制、设备联动控制,而且APP控制都是已经自动生成,无需投入成本再次开发!

企业者的福音之8266接入阿里智能,点亮一盏灯


二. 申请阿里智能商家,签订协议。


  • 1、怎么签订协议?签约详情点击:点击查看

  • 2、怎么创建产品?产品注册,产品注册是设备上云的必要过程,任何一款产品在上云之前必须完成在平台的注册。本博客因为就控制一盏灯,所以我们只需选择基础属性就可以了,即开关灯!


企业者的福音之8266接入阿里智能,点亮一盏灯


企业者的福音之8266接入阿里智能,点亮一盏灯

  • 3 、注册完毕之后,在设备列表中看到该产品后面有个“界面配置”,点击配置,选择标准面板,之后就会出现“正在绑定虚拟设备”, 注意此操作账号是在淘宝账号登录下的,如果提示“无权处理”或者其他错误信息!请确认当前登录的淘宝账号是否被该企业管理的授权下?

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 4、提示绑定成功之后,请回到商家后台!填写“产品配网说明”。截图如下:

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 5、上面步骤确认没错之后,下载厂测包,厂测包的名字叫 ONEAPK,此APP不是正式版阿里智能APP,是官方特意开发未上架的开发者所需要,请勿用正式版阿里智能App操作。系统会自动绑定虚拟设备到上述的淘宝账号的个人设备目录下,打开截图如下:定时开关是云端预约的,我们不用管它,官方解释是,买多送一!

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 6、至此,我们的控制端已经做好,下面就开始搞设备端!

二、设备端8266的开发。


1. 欲要工其事,必要利其器。



  • 2.打开共享文件,把乐鑫提供的demo下载在您的共享文件夹下面,之后在虚拟机命令符操作,输入 ./mount.sh , 提示输入密码 espressif ,成功之后cd到工程目录下,复制控制台如下:
esp8266@esp8266-VirtualBox:~$ ./mount.sh
[sudo] password for esp8266: 
esp8266@esp8266-VirtualBox:~$ cd /home/esp8266/Share/esp8266-alink-v1.0-master
esp8266@esp8266-VirtualBox:~/Share/esp8266-alink-v1.0-master$ 

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 3.修改配置文件。 打开工程目录下的 gen_misc.sh , 指定SDK路径信息,修改如下:
export SDK_PATH=/home/esp8266/Share/esp8266-alink-v1.0-master/esp8266-rtos-sdk
export BIN_PATH=/home/esp8266/Share/esp8266-alink-v1.0-master/bin

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 4.修改user_config.h配置文件,

在阿里智能的产品详情有个“TRD表下载”,下载设备 TRD 表格后 ,并将相应信息修改 user_config.h 下相应的宏定义即可,系统会调用alink_init()传入产品注册的信息,注册事件回调函数



#define DEV_NAME              "ALINKTEST"
#define DEV_BRAND             "espressif"
#define DEV_CATEGORY          "LIVING"
#define DEV_TYPE              "LIGHT"
#define DEV_MANUFACTURE       "ALINKTEST"
#define DEV_MODEL             "ALINKTEST_LIVING_LIGHT_SMARTLED"
/* key/secret */
#define ALINK_KEY             "ljB6vqoLzmP8fGkE6pon"
#define ALINK_SECRET          "YJJZjytOCXDhtQqip4EjWbhR95zTgI92RVjzjyZF"
/* sandbox key/secret */
#define ALINK_KEY_SANDBOX     "dpZZEpm9eBfqzK7yVeLq"
#define ALINK_SECRET_SANDBOX  "THnfRRsU5vu6g6m9X6uFyAjUWflgZ0iyGjdEneKm"
/* device hardware information */
#define DEV_SN                "1234567890"
#define DEV_VERSION           "1.0.0"
/* device MAC addr and chip ID, should acquired by call functions */
#define DEV_MAC               ""
#define DEV_CHIPID            ""

  • TRD表:

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 5.修改上发下发的逻辑处理!
    • 查看目录下的sample_passthrough.c文件或sample_json.c文件,sample_passthrough.c 文件是透传的示范,而sample_json.c文件就是我们刚刚选择默认的协议,云端剖析和本地自行剖析数据。
    • 所以我选择把sample_passthrough.c 删除掉,打开sample_json.c 文件,可以看到,乐鑫开发这个demo的人员其实是用一个虚拟数据结构体,我们不需管它,我们修改上发的数据,查看方法 proactive_report_data() , 里面修改如下:switchOpenOff 是我自己定义的int类型。而且我们上发的数据点的字符必须要和TRD表的产品属性的“属性名称”一致!,而且还有个ErrorCode字段。
static alink_err_t proactive_report_data() {
    char *up_cmd = alink_malloc(ALINK_DATA_LEN);
    char *buffer_tmp = NULL;

    buffer_tmp = up_cmd;

    buffer_tmp += sprintf(buffer_tmp, "{");
    if (switchOpenOff == 1) {
        buffer_tmp += sprintf(buffer_tmp, "\"Switch\": { \"value\": \"%d\" },",
                1);
    } else {
        buffer_tmp += sprintf(buffer_tmp, "\"Switch\": { \"value\": \"%d\" },",0);
    }

    buffer_tmp += sprintf(buffer_tmp, "\"ErrorCode\": { \"value\": \"%d\" }",
            0);

    buffer_tmp += sprintf(buffer_tmp, "}");
    ALINK_LOGE("up_cmd(json):%s", up_cmd);

    if (alink_write(up_cmd, strlen(up_cmd) + 1, CONFIG_WIFI_WAIT_TIME) < 0) {
        ALINK_LOGW("alink_write is error");
    }

    alink_free(up_cmd);
    return ALINK_OK;
}
  • 6.目标转移到收到云端数据的read_task_test()方法,修改如下:
void read_task_test(void *pvParameters) {
    while (1) {
        ALINK_LOGI("read down cmd param");
        char *down_cmd = alink_malloc(ALINK_DATA_LEN);

        if (alink_read(down_cmd, ALINK_DATA_LEN, portMAX_DELAY) < 0) {
            ALINK_LOGW("alink_read is error");
            continue;
        }

        ALINK_LOGE("down_cmd param(json):%s", down_cmd);
        json_value *jptr = json_parse(down_cmd, strlen(down_cmd));

         //cJson库解析数据,无需理会
        if (jptr) {
            device_data_parse(jptr, "Switch", &(virtual_device.Switch));
            device_data_parse(jptr, "ErrorCode", &(virtual_device.ErrorCode));

            //如果是1就,开灯;0就关灯;对应的led_on()在demo的led.c有,自行查询。
            if (virtual_device.Switch == 1) {
                led_on();
                switchOpenOff = 1;
            } else {
                led_off();
                switchOpenOff = 0;
            }
            ALINK_LOGE(
                    "read: OnOff_Power:%d, TimeDelay_PowerOff: %d, WorkMode_MasterLight: %d, free heap: %d\n",
                    virtual_device.Switch, virtual_device.ErrorCode,
                    system_get_free_heap_size());
        }

        //读取了云端设备之后再次提交信息给云端 
        proactive_report_data();
        alink_free(down_cmd);
        json_value_free(jptr);
    }
}

  • 7.编译程序,烧录固件。

    • 虚拟机控制台写上 ./gen_misc.sh , 表示运行gen_misc.sh 配置文件,之后打印如下:恭喜,成功!

    • 在Windows下,打开烧录软件,选择bin文件,注意bin文件都在共享目录刚刚那个编译工程的bin文件夹下面,对应的烧录地址见下面第二张图,波特率可以选择 152000:

企业者的福音之8266接入阿里智能,点亮一盏灯

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 8、工程目录说明:

    • 如果要修改触发一键配网smartConfig方法,看 alink_key_trigger.c 文件。
esp8266-alink-v1.0
├── bin                                      // 存放生成的 bin 文件
├── docs                                     // demo 使用文档的图片
├── driver                                   // 按键驱动
├── esp8266-rtos-sdk                         // ESP8266 SDK
├── gen_misc.sh                              // 编译脚本
├── include                                  // 用户配置头文件
├── Makefile                                 // 通过 Makefile 来配置 ALINK 选项
├── platforms                                // 平台相关文件
│   ├── alink                                // alink 相关 API
│   │   ├── adaptation                       // ALINK 的底层适配
│   │   ├── application                      // ALINK 应用层 API 的封装
│   │   │   ├── esp_alink_data_transport.c   // ALINK 数据传传输
│   │   │   ├── esp_alink_main.c             // 连接 AP 、恢复出厂设置、事件回调函数
│   │   │   ├── esp_info_store.c             // FLASH 的读写操作
│   │   │   └── Makefile
│   │   ├── include
│   │   │   ├── alink_adaptation.h           // 应用层适配时定义的一些 API
│   │   │   ├── alink_export.h               // ALINK 官方提供的原生应用层 API
│   │   │   ├── alink_export_rawdata.h       // ALINK 官方提供的原生应用层 API
│   │   │   ├── alink_json.h                 // ALINK 官方提供的原生 JSON API
│   │   │   ├── esp_alink.h                  // 封装的应用层 API 使用说明及配置
│   │   │   ├── esp_alink_log.h              // 定义了打印等级
│   │   │   └── esp_info_store.h             // 信息存储 API 详解及 EXAMPLE
│   │   ├── Makefile
│   │   └── README.md                        
│   └── Makefile
├── README.md                                // demo 使用文档
└── user                                     // 用户相关文件
    ├── alink_key_trigger.c                  // 按键触发函数
    ├── ALINKTEST_LIVING_LIGHT_SMARTLED_LUA.lua  // 透传示例使用的 LUA 脚本
    ├── Makefile
    ├── sample_json.c                        // ALINK 非透传示例
    ├── sample_passthrough.c                 // ALINK 透传示例
    └── user_main.c                          // 用户程序入口

三、开始使用。


  • 打开阿里智能的厂测包ONEAPK,点击右上角加号,分类添加,选择 健康秤 ,选择 阿里配网V2 , 输入wiif密码,点击下一步!

企业者的福音之8266接入阿里智能,点亮一盏灯


  • 按键长按,配网成功!

企业者的福音之8266接入阿里智能,点亮一盏灯


企业者的福音之8266接入阿里智能,点亮一盏灯。

代码地址如下:
http://www.demodashi.com/demo/12178.html

注:本文著作权归作者,由demo大师发表,拒绝转载,转载需要作者授权