本文說是快速入門,其實應該算是開發闆開發的Hello World[靈光一閃]
本文還将講解如何配置VS Code可以實作代碼自動補全提示。
一、添加點亮LED源碼檔案
1、新增my_led檔案夾
在./applications/BearPi/BearPi-HM_Nano/sample路徑下建立一個my_led目錄,用于存放業務源碼檔案。
2、用VS Code打開my_led檔案夾,新增light_led.c檔案
在./applications/BearPi/BearPi-HM_Nano/sample/my_led路徑下建立一個light_led.c檔案,該檔案為業務源碼檔案
添加點亮LED燈的代碼
#include <stdio.h>
#include <unistd.h>
#include "ohos_init.h"
#include "wifiiot_gpio.h"
#include "wifiiot_gpio_ex.h"
void light_led(void)
{
// 初始化GPIO
GpioInit();
// 設定GPIO_2的利用功能為普通GPIO
IoSetFunc(WIFI_IOT_IO_NAME_GPIO_2, WIFI_IOT_IO_FUNC_GPIO_2_GPIO);
// 設定GPIO_2為輸出模式
GpioSetDir(WIFI_IOT_IO_NAME_GPIO_2, WIFI_IOT_GPIO_DIR_OUT);
// 設定GPIO_2輸出高電平點亮LED燈
GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_2, 1);
}
APP_FEATURE_INIT(light_led);
設定 VS Code 自動代碼提示
按快捷鍵 Ctrl + Shift + P 或者 View -> Command Palette...
輸入 c/c++,選擇 Edit Configuration(JSON) 或者 Edit Configuration(UI),筆者這裡選擇的JSON,感覺簡單一些
在 includePath 子節點将幾個路徑加進去,讀者根據自己電腦上的路徑修改,這裡隻是作為一個參考
{
"configurations": [
{
"name": "Linux",
"includePath": [
"${workspaceFolder}/**",
"/home/leqi/Documents/bearpi-hm_nano/utils/native/lite/include/**",
"/home/leqi/Documents/bearpi-hm_nano/base/**"
],
"defines": [],
"compilerPath": "/usr/bin/gcc",
"cStandard": "c17",
"cppStandard": "gnu++14",
"intelliSenseMode": "linux-gcc-x64"
}
],
"version": 4
}
然後檔案中的錯誤提示消失,文法也高亮了。
3、編寫業務編譯建構檔案BUILD.gn
添加BUILD.gn檔案,輸入以下代碼
static_library("myled") {
sources = [
"light_led.c"
]
include_dirs = [
"//utils/native/lite/include",
"//base/iot_hardware/interfaces/kits/wifiiot_lite"
]
}
static_library中指定業務子產品的編譯結果,為靜态庫檔案libmyled.a,開發者根據實際情況完成填寫。
sources中指定靜态庫.a所依賴的.c檔案及其路徑,若路徑中包含"//"則表示絕對路徑(此處為代碼根路徑),若不包含"//" 則表示相對路徑。
include_dirs中指定source所需要依賴的.h檔案路徑。
4、編寫子產品編譯建構檔案BUILD.gn
在./applications/BearPi/BearPi-HM_Nano/sample下的BUILD.gn檔案中添加如下代碼。
通過 Code 打開檔案修改代碼
"my_led:myled",
my_led是相對路徑,指向./applications/BearPi/BearPi-HM_Nano/sample/my_led/BUILD.gn。
myled是目标,指向./applications/BearPi/BearPi-HM_Nano/sample/my_led/BUILD.gn中的static_library("myled")。
5、編譯,燒錄
打開終端,進入 bearpi-hm_nano 源碼目錄,運作指令
python build.py BearPi-HM_Nano
将 out 目錄下的 BearPi-HM_Nano 目錄複制到Windows中;打開hiBurn,選擇自己電腦上的開發闆的通信接口,筆者的是COM3;點選 Setting 菜單下的 Com Settings,選擇921600;點選 Select file 選擇 Hi3861_wifiiot_app_allinone.bin;勾選 Auto burn;點選 Connect;按一下開發闆上的 RESET 鍵開始燒錄;燒錄成功後點選 Disconnect。
6、按開發闆上的 RESET (複位鍵)點亮LED燈
點亮前
點亮後
7、添加LED燈閃爍代碼
#include "ohos_init.h"
#include "unistd.h"
#include "wifiiot_gpio.h"
#include "wifiiot_gpio_ex.h"
void led_example(void)
{
GpioInit();
IoSetFunc(WIFI_IOT_IO_NAME_GPIO_2,WIFI_IOT_IO_FUNC_GPIO_2_GPIO);
GpioSetDir(WIFI_IOT_IO_NAME_GPIO_2,WIFI_IOT_GPIO_DIR_OUT);
for(int i = 0; i < 10; i++)
{
GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_2,1);
usleep(1000000);
GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_2,0);
usleep(1000000);
}
GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_2,1);
}
APP_FEATURE_INIT(led_example);
8、重複第5、6步