一、前言。
最近的天貓精靈火熱朝天,雙十一僅僅99塊就抱回家!這門博文,涉及到絕大部分的接入阿里智能的商業者,為了隱私,我必須要把某些圖片的信息隱藏 !但是我會把整個過程給需要的人理順 一下,絕不是為了湊人氣而寫。
- 如果你沒有企業的注冊信息,不用往下看了!只有在阿里智能注冊簽訂協議的商家,方可開發!
1.1 了解ALINK 阿里智能開發平台。
智能硬件模組、阿里智能雲、阿里智能 APP,阿里智能生活事業部為廠商提供一站式設備智能化解決方案。
-
申請接入阿里智能平台的模組必要要有阿里智能官方的認證!否則不允許接入!已通過認證的模組列表:點擊查看
-
樂鑫官網已經給出了接入阿里智能的Demo點擊查看,我們開發者不需自己搭建框架,只需關注上發邏輯和下發邏輯處理即可,這個和機智雲的一站式開發一樣的道理!
-
由於指定的操作是 freertos ,並非 nons ,所以本博文的工程,不能直接導入就編譯,個人最好的方法就是Windows平台搭建Linux虛擬機導入8266的系統,進行編譯。
-
成功上架的產品,均可被天貓精靈語音控制,不管是哪個廠商的設備,只有接入阿里智能,都可以實現語音控制、設備聯動控制,而且APP控制都是已經自動生成,無需投入成本再次開發!

二. 申請阿里智能商家,簽訂協議。
-
1、怎么簽訂協議?簽約詳情點擊:點擊查看
-
2、怎么創建產品?產品注冊,產品注冊是設備上雲的必要過程,任何一款產品在上雲之前必須完成在平台的注冊。本博客因為就控制一盞燈,所以我們只需選擇基礎屬性就可以了,即開關燈!
- 3 、注冊完畢之后,在設備列表中看到該產品后面有個“界面配置”,點擊配置,選擇標准面板,之后就會出現“正在綁定虛擬設備”, 注意此操作賬號是在淘寶賬號登錄下的,如果提示“無權處理”或者其他錯誤信息!請確認當前登錄的淘寶賬號是否被該企業管理的授權下?
- 4、提示綁定成功之后,請回到商家后台!填寫“產品配網說明”。截圖如下:
- 5、上面步驟確認沒錯之后,下載廠測包,廠測包的名字叫 ONEAPK,此APP不是正式版阿里智能APP,是官方特意開發未上架的開發者所需要,請勿用正式版阿里智能App操作。系統會自動綁定虛擬設備到上述的淘寶賬號的個人設備目錄下,打開截圖如下:定時開關是雲端預約的,我們不用管它,官方解釋是,買多送一!
- 6、至此,我們的控制端已經做好,下面就開始搞設備端!
二、設備端8266的開發。
1. 欲要工其事,必要利其器。
- 1.搭建開發環境,使用樂鑫官方的ESP8266開發環境,此鏈接是機智雲官網提供!
- 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$
- 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
- 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表:
- 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:
-
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接入阿里智能,點亮一盞燈。
注:本文著作權歸作者,由demo大師代發,拒絕轉載,轉載需要作者授權