天天看點

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

作者:樂其觀察

本文說是快速入門,其實應該算是開發闆開發的Hello World[靈光一閃]

本文還将講解如何配置VS Code可以實作代碼自動補全提示。

一、添加點亮LED源碼檔案

1、新增my_led檔案夾

在./applications/BearPi/BearPi-HM_Nano/sample路徑下建立一個my_led目錄,用于存放業務源碼檔案。

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮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...

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

輸入 c/c++,選擇 Edit Configuration(JSON) 或者 Edit Configuration(UI),筆者這裡選擇的JSON,感覺簡單一些

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

在 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
}           

然後檔案中的錯誤提示消失,文法也高亮了。

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

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",           
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

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           
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

将 out 目錄下的 BearPi-HM_Nano 目錄複制到Windows中;打開hiBurn,選擇自己電腦上的開發闆的通信接口,筆者的是COM3;點選 Setting 菜單下的 Com Settings,選擇921600;點選 Select file 選擇 Hi3861_wifiiot_app_allinone.bin;勾選 Auto burn;點選 Connect;按一下開發闆上的 RESET 鍵開始燒錄;燒錄成功後點選 Disconnect。

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈
小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

6、按開發闆上的 RESET (複位鍵)點亮LED燈

點亮前

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮LED燈

點亮後

小熊派鴻蒙作業系統(HarmonyOS)開發闆快速入門:點亮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步

繼續閱讀