本文來源電子發燒友社區,作者:hehung, 帖子地址:https://bbs.elecfans.com/jishu_2013493_1_1.html
有一周多沒有時間弄這個板子了,這段時間實在是有點忙,這周末抓緊了點時間弄了弄。資料確實有點少了,只能一點一點的摸索。弄了一個按鍵控制LED的程序。
核心板上有一個LED以及按鍵,我們查看原理圖可以知道,LED連接到GPIO9,按鍵連接到了GPIO5.
?
所以只需要初始化這兩個引腳作為輸入輸出就行了,還是比較簡單的,因為是學習,所以從簡單的開始入手。
初始化代碼如下:
LED初始化,初始化為輸出:
復制代碼
KEY初始化函數,初始化為輸入:
復制代碼
如何調用呢?
看下邊:
控制GPIO輸出,1為輸出高,0位輸出低:
復制代碼
獲取GPIO輸入電平:
復制代碼
其中:Key_Status
就是獲取的電平值,GpioGetInputVal()的返回值表示獲取是否成功的標志。
我創建了兩個任務:
一個任務專門控制LED,一個任務控制Key。
上電之后,LED閃爍,頻率是500ms。
按下user按鍵之后,LED滅
再次按下user按鍵,LED亮
再次按下user按鍵,再次閃爍
以此循環。
完整代碼如下:
BUILD.gn
復制代碼
my_main.c函數
復制代碼
我的軟件目錄如下:

最后效果圖見視頻。
有一周多沒有時間弄這個板子了,這段時間實在是有點忙,這周末抓緊了點時間弄了弄。資料確實有點少了,只能一點一點的摸索。弄了一個按鍵控制LED的程序。
核心板上有一個LED以及按鍵,我們查看原理圖可以知道,LED連接到GPIO9,按鍵連接到了GPIO5.
?
所以只需要初始化這兩個引腳作為輸入輸出就行了,還是比較簡單的,因為是學習,所以從簡單的開始入手。
初始化代碼如下:
LED初始化,初始化為輸出:
KEY初始化函數,初始化為輸入:
- GpioInit();
- IoSetFunc(WIFI_IOT_IO_NAME_GPIO_5, WIFI_IOT_IO_FUNC_GPIO_5_GPIO);
- GpioSetDir(WIFI_IOT_IO_NAME_GPIO_5, WIFI_IOT_GPIO_DIR_IN);
如何調用呢?
看下邊:
控制GPIO輸出,1為輸出高,0位輸出低:
- GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_9, 1);
- WifiIotGpioValue Key_Status = WIFI_IOT_GPIO_VALUE1;
- GpioGetinputVal(WIFI_IOT_IO_NAME_GPIO_5, &Key_Status);
就是獲取的電平值,GpioGetInputVal()的返回值表示獲取是否成功的標志。
我創建了兩個任務:
一個任務專門控制LED,一個任務控制Key。
上電之后,LED閃爍,頻率是500ms。
按下user按鍵之后,LED滅
再次按下user按鍵,LED亮
再次按下user按鍵,再次閃爍
以此循環。
完整代碼如下:
BUILD.gn
my_main.c函數
- /*this is my first application*/
- /*2020/11/08*/
- #include
- #include "ohos_init.h"
- #include "ohos_types.h"
- #include
- #include
- #include "ohos_init.h"
- #include "cmsis_os2.h"
- #include "wifiiot_gpio.h"
- #include "wifiiot_gpio_ex.h"
- #include "wifiiot_adc.h"
- #include
- #include
- #include
- #include
- #define LED_INTERVAL_TIME_US 500000 /*500ms*/
- #define LED_TASK_STACK_SIZE 512
- #define LED_TASK_PRIO 25
- #define KEY_INTERVAL_TIME_US 10000 /*10ms*/
- #define KEY_TASK_STACK_SIZE 1024
- #define KEY_TASK_PRIO 26
- static void *LedTask(const char *arg);
- static void *KeyTask(const char *arg);
- /*LED Control*/
- enum LedState {
- LED_ON = 0,
- LED_OFF,
- LED_SPARK,
- };
- enum LedState g_ledState = LED_SPARK;
- static void *LedTask(const char *arg)
- {
- (void)arg;
- while (1) {
- switch (g_ledState) {
- case LED_ON:
- GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_9, 1);
- usleep(LED_INTERVAL_TIME_US);
- break;
- case LED_OFF:
- GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_9, 0);
- usleep(LED_INTERVAL_TIME_US);
- break;
- case LED_SPARK:
- GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_9, 0);
- usleep(LED_INTERVAL_TIME_US);
- GpioSetOutputVal(WIFI_IOT_IO_NAME_GPIO_9, 1);
- usleep(LED_INTERVAL_TIME_US);
- break;
- default:
- usleep(LED_INTERVAL_TIME_US);
- break;
- }
- }
- return NULL;
- }
- static void Led0Entry(void)
- {
- osThreadAttr_t attr;
- GpioInit();
- IoSetFunc(WIFI_IOT_IO_NAME_GPIO_9, WIFI_IOT_IO_FUNC_GPIO_9_GPIO);
- GpioSetDir(WIFI_IOT_IO_NAME_GPIO_9, WIFI_IOT_GPIO_DIR_OUT);
- attr.name = "LedTask";
- attr.attr_bits = 0U;
- attr.cb_mem = NULL;
- attr.cb_size = 0U;
- attr.stack_mem = NULL;
- attr.stack_size = LED_TASK_STACK_SIZE;
- attr.priority = LED_TASK_PRIO;
- if (osThreadNew((osThreadFunc_t)LedTask, NULL, &attr) == NULL) {
- printf("[Led0Task] Falied to create LedTask!n");
- }
- }
- SYS_RUN(Led0Entry);
- /*OLED board KEY Control - vased on ADC input*/
- static void *KeyTask(const char *arg)
- {
- (void)arg;
- WifiIotGpioValue Key_Status = WIFI_IOT_GPIO_VALUE1;
- WifiIotGpioValue Last_key_Status = WIFI_IOT_GPIO_VALUE1;
- uint8_t Key_press_cnt = 0u;
- while (1) {
- GpioGetInputVal(WIFI_IOT_IO_NAME_GPIO_5, &Key_Status);
- // printf("%dn", Key_Status);
- if((Key_Status == WIFI_IOT_GPIO_VALUE0) && (Last_key_Status != Key_Status))
- {
- // Key_press_cnt = (Key_press_cnt>2) ? 0:(++Key_press_cnt);
- if(Key_press_cnt >= 2)
- {
- Key_press_cnt = 0;
- }
- else
- {
- Key_press_cnt ++;
- }
- switch(Key_press_cnt)
- {
- case 0:g_ledState = LED_ON;break;
- case 1:g_ledState = LED_OFF;break;
- case 2:g_ledState = LED_SPARK;break;
- }
- }
- else
- {
- }
- Last_key_Status = Key_Status;
- usleep(LED_INTERVAL_TIME_US);
- }
- return NULL;
- }
- static void KeyEntry(void)
- {
- osThreadAttr_t attr;
- GpioInit();
- IoSetFunc(WIFI_IOT_IO_NAME_GPIO_5, WIFI_IOT_IO_FUNC_GPIO_5_GPIO);
- GpioSetDir(WIFI_IOT_IO_NAME_GPIO_5, WIFI_IOT_GPIO_DIR_IN);
- // AdcRead();
- attr.name = "KeyTask";
- attr.attr_bits = 0U;
- attr.cb_mem = NULL;
- attr.cb_size = 0U;
- attr.stack_mem = NULL;
- attr.stack_size = KEY_TASK_STACK_SIZE;
- attr.priority = KEY_TASK_PRIO;
- if (osThreadNew((osThreadFunc_t)KeyTask, NULL, &attr) == NULL) {
- printf("[KeyTask] Falied to create KeyTask!n");
- }
- }
- SYS_RUN(KeyEntry);
我的軟件目錄如下:

最后效果圖見視頻。
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
wi-fi
+關注
關注
15文章
2424瀏覽量
129553 -
HarmonyOS
+關注
關注
80文章
2153瀏覽量
36051 -
HiSpark
+關注
關注
1文章
156瀏覽量
7757
發布評論請先 登錄
相關推薦
熱點推薦
技術資訊 I Wi-Fi 模塊設計
本文要點Wi-Fi模塊設計旨在打造一套緊湊且高效的硬件和軟件解決方案,使設備能夠通過Wi-Fi網絡實現通信。Wi-Fi模塊設計是一個復雜的過程,要求研發人員兼具硬件與軟件工程方面的專業知識
ESP32 Wi-Fi 控制 LED 燈的原理
控制LED燈的——從底層硬件連接,到網絡通信邏輯,一步步拆解整個過程。一、系統概覽ESP32是一顆集成度極高的芯片,內置Wi-Fi、藍牙、雙核MCU和豐富的外設接
Wi-Fi:無線連接的全球通用語
Wi-Fi功能,跨品牌、跨設備互聯互通性強,生態完整。3. 靈活部署,易于擴展支持星型、Mesh等多種組網方式,可根據環境靈活布置接入點,擴大覆蓋范圍。4. 技術持續演進從802.11a/b/g到
發表于 01-07 09:49
Nordic發布nRF7002 EBII 開發板, 支持Wi-Fi 6, 解鎖nRF54L新玩法
了 Wi-Fi 6 功能,幫助開發人員創建高性能、高能效的Wi-Fi 6 物聯網解決方案。
基于 Nordic 的 nRF7002 Wi-Fi 協同 IC,nRF7002 EBII幫助 采用
發表于 12-10 11:58
Wi-Fi模塊選型指南 | 低功耗藍牙/Wi-Fi 6模塊推薦 | 物聯網設備集成攻略
物聯網的快速發展,Wi-Fi技術的成熟的情況下,越來越多的場景需要用到Wi-Fi來無線傳輸數據,尤其是移動設備中,怎么再設備中選擇合適的Wi-Fi模塊呢?下面我們來介紹下Wi-Fi模塊
淺談Wi-Fi 6E與Wi-Fi 7的關鍵器件——BAW濾波器新技術
作者: Qorvo 亞太區無線連接事業部高級行銷經理林健富 ? 2020年1月,Wi-Fi聯盟正式宣布開放6GHz頻段(5925MHz-7125MHz),并將其命名為Wi-Fi 6E。2020年4月
發表于 09-19 18:29
?2125次閱讀
LitePoint Wi-Fi測試軟件減輕客戶設計負擔
自Wi-Fi 7于一年多前獲得Wi-Fi聯盟認證以來,作為最新一代通信技術,Wi-Fi正逐步成為用戶實現無所不在無線連接的新選擇。隨著每一代Wi-Fi信號復雜性的提升,建議將硬件測試納
雙頻匹配 SP4T Wi-Fi 交換機 skyworksinc
電子發燒友網為你提供()雙頻匹配 SP4T Wi-Fi 交換機相關產品參數、數據手冊,更有雙頻匹配 SP4T Wi-Fi 交換機的引腳圖、接線圖、封裝手冊、中文資料、英文資料,雙頻匹配
發表于 08-01 18:34
Texas Instruments CC335x SimpleLink?雙頻Wi-Fi? 6配套IC數據手冊
Texas Instruments CC335x SimpleLink?雙頻Wi-Fi ^?^ 配套IC提供Wi-Fi 6、BLE,并兼容Wi-Fi 4 (802.11 a/b/g/n
Wi-Fi 8:開啟極高可靠性 (UHR) 連接的新紀元——1
,在2019年,Wi-Fi 6憑借著MU-MIMO、1024QAM、OFDMA等“革命性創新”技術,大幅提升了Wi-Fi 本身的能效,讓Wi-Fi 6在短短的3-4年內成為
發表于 06-13 11:09
基于 Wi-Fi 的定位服務
以下捕獲使用 location_wifi_get 函數請求 Wi-Fi 定位服務。該事件的總功耗為 125.85mC,日志顯示精確度為 30.0m。
Got location:
method
發表于 04-17 15:16
nRF Cloud Wi-Fi 定位服務
、Predictive-GPS、Single-Cell、Multi-Cell 和 Wi-Fi 定位。通過利用 nRF Cloud 的優化定位算法,基于 Nordic SoC 和 模組的產品可在定位用例
發表于 04-17 15:07
Wi-Fi 定位服務
Wi-Fi 是一種著名的無線網絡技術,用于設備的局域網和互聯網接入。Wi-Fi 通過 Wi-Fi 網絡為家庭、辦公室和學校等環境提供便捷的無線互聯網接入服務。
Wi-Fi 定位是一種
發表于 04-17 15:01
【HarmonyOS HiSpark Wi-Fi IoT 套件試用連載】4, 按鍵驅動LED
評論