天天看点

小熊派鸿蒙操作系统(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步

继续阅读