在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

OpenHarmony項目實戰:智能體重秤

王程 ? 來源:jf_75796907 ? 作者:jf_75796907 ? 2024-02-18 09:26 ? 次閱讀

一、簡介

本demo基于OpenHarmony3.1Beta版本開發,該樣例能夠接入數字管家應用,通過數字管家應用監測體重秤上報數據,獲得當前測量到的體重,身高,并在應用端形成一段時間內記錄的體重值,以折線圖的形式表現出來,根據計算的BMI值來提醒當前身體健康狀態,推送健康小知識。

1.交互流程

wKgaomXQnWmAdUYcAAEUlgJ5yiQ402.pngwKgZomXQnNqALcaQAAEUlgJ5yiQ297.png


交互圖

如上圖所示,智能體重稱整體方案原理圖可以大致分成:智能體重稱設備、數字管家應用、云平臺三部分。智能體重稱通過MQTT協議連接華為IOT物聯網平臺,從而實現命令的接收和屬性上報。 關于智能設備接入華為云IoT平臺的詳細細節可以參考 連接IOT云平臺指南;智能設備同數字管家應用之間的設備模型定義可以參考profile .

2.實物簡介

wKgaomXQnWuAdrCRAADRGNjOFSk22.jpegwKgZomXQnOyAToaqAADRGNjOFSk708.png


如上圖示,左邊為全志xr806模組,右邊為超聲波測距模塊,echo腳連接PA19,Triq腳連接PA20,Vcc腳連接5V電源,Gnd腳接地,

wKgZomXQnWyAJr_BAADlLNMwdYU56.jpegwKgZomXQnQaAdR-PAADlLNMwdYU353.png


如上圖示,右邊為稱重模塊,clk腳接PB15,dt腳接PB14,vcc腳接5V,gnd腳接地,稱重傳感器紅色線接E+,黑色線接E-,白色線接A-,綠色線接A+

左邊xr806模塊左下角k1按鍵,長按k1按鍵不放,同時上電,4-5秒后松開按鍵,可以清除已保存得配網信息

xr806模塊,在設備正常工作后,按k1按鍵,可以初始化當前得重量為0,高度為0

二、 快速上手

1.硬件準備

全志xr806模組

hcsr04超聲波模塊

hx711稱重模塊帶支架托盤

預裝HarmonyOS手機一臺

2、環境準備

參照文檔: XR806快速上手指導文檔

3、編譯前準備

設備側代碼下載
具體倉庫地址:https://gitee.com/openharmony-sig/knowledge_demo_smart_home/

下載方式:使用git 命令下載,指令如下(用戶也可以根據需要將該倉庫fork到自己的目錄下后進行下載)

cd ~
git clone git@gitee.com:openharmony-sig/knowledge_demo_smart_home.git

代碼拷貝

cp -rfa  ~/knowledge_demo_smart_home/dev/team_x  ~/openharmony/vendor/
cp -rfa  ~/knowledge_demo_smart_home/dev/third_party/iot_link  ~/openharmony/third_party/

SOC代碼下載替換

當前官方soc代碼由于DHCP暫未適配,所以暫時不支持AP模式,這時需要下載并替換之前SOC代碼。如果官方soc代碼已修復該問題,可忽略此步驟。

git clone https://gitee.com/moldy-potato-chips/xr806_-ap_mode.git
mv ~/openharmony/device/soc/allwinner ~/allwinner.org			// 不建議直接刪除,
cp -raf xr806_-ap_mode ~/openharmony/device/soc/allwinner

整合并修改完成后的目錄結構如下圖

wKgaomXQnWyAeVB1AAA9-Ujk-9c718.pngwKgaomXQnSCAf9JCAAA9-Ujk-9c264.png


修改文件

修改編譯依賴
打開 device/soc/allwinner/xradio/xr806/BUILD.gn,添加應用依賴(deps字段):

module_group(module_name) {
  modules = [
      "src",
      "project",
      "include",
  ]
  configs = [
    ":SdkLdCconfig",
  ]
  deps = [ "http://vendor/team_x/smart_weight_scale/demo_smart_weight_scale:smart_weight_scale" ]
}

修改編譯方式
將demo依賴的庫編譯方式(static_library)修改為(source_set):
具體依賴查看demo_smart_weight_scale目錄下的BUILD.gn:

deps = [
       "../../common/iot_wifi_xradio:iot_wifi",
       "../../common/iot_cloud:iot_cloud",
       "http://third_party/cJSON:cjson",
       "../../common/iot_boardbutton_xradio:iot_boardbutton",
       "../../common/iot_boardled_xradio:iot_boardled_xradio",
    ]

其中//third_party/cJSON目錄下的BUILD.gn建議參照下面的修改:

source_set("cJSON") {
  sources = [
    "cJSON.c",
    "cJSON_Utils.c",
  ]
  ldflags = [ "-lm" ]
}

third_party/iot_link目錄下的各級使用到的BUILD.gn也需要將編譯方式修改為source_set,或者將所有需要編譯的文件放在iot_link目錄的BUILD.gn中,如下:

source_set("iot_link") {
    sources = [
        "link_log/link_log.c",
        "link_misc/link_random.c",
        "link_misc/link_ring_buffer.c",
        "link_misc/link_string.c",
        "network/dtls/dtls_al/dtls_al.c",
        "network/dtls/mbedtls/mbedtls_port/dtls_interface.c",
        "network/dtls/mbedtls/mbedtls_port/mbed_port.c",
        "network/dtls/mbedtls/mbedtls_port/timing_alt.c",
        "network/mqtt/mqtt_al/mqtt_al.c",
        "network/mqtt/paho_mqtt/port/paho_mqtt_port.c",
        "network/mqtt/paho_mqtt/port/paho_osdepends.c",
        "network/mqtt/paho_mqtt/paho/MQTTClient-C/src/MQTTClient.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTConnectClient.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTConnectServer.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTDeserializePublish.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTFormat.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTPacket.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTSerializePublish.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTSubscribeClient.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTSubscribeServer.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTUnsubscribeClient.c",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src/MQTTUnsubscribeServer.c",
        "oc_mqtt/oc_mqtt_al/oc_mqtt_al.c",
        "oc_mqtt/oc_mqtt_profile_v5/oc_mqtt_profile.c",
        "oc_mqtt/oc_mqtt_profile_v5/oc_mqtt_profile_package.c",
        "oc_mqtt/oc_mqtt_profile_v5/oc_mqtt_event.c",
        "oc_mqtt/oc_mqtt_tiny_v5/oc_mqtt_tiny.c",
        "oc_mqtt/oc_mqtt_tiny_v5/hmac.c",
        "queue/queue.c",
    ]
    
    cflags = [ "-Wno-unused-variable" ]
    cflags += [ "-Wno-unused-but-set-variable" ]
    cflags += [  "-Wno-sign-compare" ]
    cflags += [  "-Wno-unused-parameter" ]
    cflags += [  "-Wno-unused-function" ]

    ldflags = [ "-Wl,-rpath-link=//device/xradio/xr806/xr_skylark/lib" ]
    ldflags += [ "-lmbedtls" ]

    include_dirs = [
        "inc",
        "link_log",
        "link_misc",
        "queue",
        "oc_mqtt/oc_mqtt_tiny_v5",
        "oc_mqtt/oc_mqtt_profile_v5",
        "oc_mqtt/oc_mqtt_al",
        "network/dtls/mbedtls/mbedtls_port",
        "network/mqtt/paho_mqtt/port",
        "network/mqtt/paho_mqtt/paho/MQTTClient-C/src",
        "network/mqtt/paho_mqtt/paho/MQTTPacket/src",
        "http://third_party/mbedtls/include/",
        "http://third_party/mbedtls/include/",
        "http://third_party/cJSON",
        "http://kernel/liteos_m/components/cmsis/2.0",
        "http://device/xradio/xr806/xr_skylark/include/net/mbedtls-2.2.0/",
    ]

    defines = [
        "MQTTCLIENT_PLATFORM_HEADER=paho_osdepends.h",
        "WITH_DTLS",
        "MBEDTLS_AES_ROM_TABLES",
        "MBEDTLS_CONFIG_FILE="los_mbedtls_config_dtls.h"",
        "CONFIG_DTLS_MBEDTLS_CERT",
        "CONFIG_DTLS_MBEDTLS_PSK",
        "CFG_MBEDTLS_MODE=PSK_CERT",
        "CONFIG_OC_MQTT_TINY_ENABLE=1"
    ]
}

修改iot_link中的部分文件
1.third_party/iot_link/network/mqtt/paho_mqtt/port/paho_mqtt_port.c

測試發現,當fd為0的時候,在執行recv時會立馬返回-1,因此做下面規避操作。

static int __socket_connect(Network *n, const char *host, int port)
{
	...
	int tmpfd = socket(AF_INET,SOCK_STREAM,0); // to skip fd = 0;
	fd = socket(AF_INET,SOCK_STREAM,0);
	if(fd == -1) {
		return ret;
	}
	close(tmpfd);       // to skip fd = 0;
	...
}

系統setsockopt函數未適配,因此需要做下面的修改:

static int __socket_read(void *ctx, unsigned char *buf, int len, int timeout)
{
	int fd;
    int ret = 0;
#if 0
	struct timeval timedelay = {timeout / 1000, (timeout % 1000) * 1000};
    if(NULL== uf)
    {
        return ret;
    }
    
    fd = (int)(intptr_t)ctx;  ///< socket could be zero

    if (timedelay.tv_sec < 0 || (timedelay.tv_sec == 0 && timedelay.tv_usec <= 0))
    {
        timedelay.tv_sec = 0;
        timedelay.tv_usec = 100;
    }
    
    if(0 != setsockopt(fd,SOL_SOCKET,SO_RCVTIMEO,&timedelay,sizeof(struct timeval)))
    {
        return ret;  //could not support the rcv timeout
    }
    int bytes = 0;
    while (bytes < len) {
        int rc = recv(fd, &buf[bytes], (size_t)(len - bytes), 0);
        printf("[%s|%s|%d]fd = %d, rc = %dn", __FILE__,__func__,__LINE__, fd, rc);
        if (rc == -1) {
            if (errno != EAGAIN && errno != EWOULDBLOCK) {
                bytes = -1;
            }
            break;
        } else if (rc == 0) {
            bytes = 0;
            break;
        } else {
            bytes += rc;
        }
    }
    return bytes;
#else
	int bytes = 0;
    fd_set fdset;

    struct timeval timedelay = {timeout / 1000, (timeout % 1000) * 1000};
    if(NULL== buf)
    {
        return ret;
    }
    
    fd = (int)(intptr_t)ctx;  ///< socket could be zero

    if (timedelay.tv_sec < 0 || (timedelay.tv_sec == 0 && timedelay.tv_usec <= 0))
    {
        timedelay.tv_sec = 0;
        timedelay.tv_usec = 100;
    }
    timedelay.tv_sec = 2;
    FD_ZERO(&fdset);
    FD_SET(fd, &fdset);

    ret = select(fd + 1, &fdset, NULL, NULL, &timedelay);
    if (ret > 0) {
        while (bytes < len) {
            int rc = recv(fd, &buf[bytes], (size_t)(len - bytes), 0);
 //         printf("[%s|%s|%d]fd = %d, rc = %d, errno=%d(%s)n", __FILE__,__func__,__LINE__, fd, rc,errno, strerror(errno));
            if (rc == -1) {
                if (errno != EAGAIN && errno != EWOULDBLOCK) {
                    bytes = -1;
                }
                break;
            } else if (rc == 0) {
                bytes = 0;
                break;
            } else {
                bytes += rc;
            }
        }
    }

    return bytes;
#endif
}

2.third_party/iot_link/network/dtls/mbedtls/mbedtls_port/dtls_interface.c

在文件頂部添加打印函數定義以及添加mbedtls_calloc以及mbedtls_free的定義,否則編譯會提示錯誤:

#define MBEDTLS_LOG LINK_LOG_DEBUG
#ifndef mbedtls_calloc
#define mbedtls_calloc  calloc
#endif
#ifndef mbedtls_free
#define mbedtls_free  free
#endif

系統部分mbedtls接口不一致,固需要注釋部分接口代碼:

mbedtls_ssl_context dtls_ssl_new(dtls_establish_info_s *info, char plat_type)
{
	...
	if (info->psk_or_cert == VERIFY_WITH_PSK)
    {
/*
        if ((ret = mbedtls_ssl_conf_psk(conf,
                                        info->v.p.psk,
                                        info->v.p.psk_len,
                                        info->v.p.psk_identity,
                                        strlen((const char *)info->v.p.psk_identity))) != 0)
        {
            MBEDTLS_LOG("mbedtls_ssl_conf_psk failed: -0x%x", -ret);
            goto exit_fail;
        }
*/
    }
    ...
}

int dtls_shakehand(mbedtls_ssl_context *ssl, const dtls_shakehand_info_s *info)
{
	...
	if (MBEDTLS_SSL_IS_CLIENT == info->client_or_server)
    {
        ret = mbedtls_net_connect(server_fd, info->u.c.host, info->u.c.port, info->udp_or_tcp);
        if( 0 != ret)
        {
            ret = MBEDTLS_ERR_NET_CONNECT_FAILED;
            goto exit_fail;
        }
    }
    else
    {
        //server_fd = (mbedtls_net_context*)atiny_net_bind(NULL, info->u.s.local_port, MBEDTLS_NET_PROTO_UDP);
        ///< --TODO ,not implement yet
    }
	...
}

void dtls_init(void)
{
    (void)mbedtls_platform_set_calloc_free(calloc, free);
    (void)mbedtls_platform_set_snprintf(snprintf);
//    (void)mbedtls_platform_set_printf(printf);
}

在iot_link/network/dtls/mbedtls/mbedtls_port/mbed_port.c文件中的dtls_imp_init()函數中,也需要注釋掉未實現的接口,否則編譯報錯:

int dtls_imp_init(void)
{
    int ret =-1;

    // (void)mbedtls_platform_set_calloc_free(calloc, free); 
    // (void)mbedtls_platform_set_snprintf(snprintf);
    // (void)mbedtls_platform_set_printf(printf);
    ret = dtls_al_install(&s_mbedtls_io);

    return ret;
}

3.在文件iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.c中添加對應timersub和timeradd的實現(系統中未實現該函數):

// add this for "timersub" && "timeradd"
#ifndef	timersub
#define timersub(s,t,a) (void) ( (a)->tv_sec = (s)->tv_sec - (t)->tv_sec, 
        ((a)->tv_usec = (s)->tv_usec - (t)->tv_usec) < 0 && 
        ((a)-?>tv_usec += 1000000, (a)->tv_sec--) )
#endif
#ifndef	timeradd
#define timeradd(s,t,a) (void) ( (a)->tv_sec = (s)->tv_sec + (t)->tv_sec, 
        ((a)->tv_usec = (s)->tv_usec + (t)->tv_usec) >= 1000000 && 
        ((a)->tv_usec -= 1000000, (a)->tv_sec++) )
#endif

4.編譯中會有部分頭文件提示找不到,這個時候直接將其注釋即可

(iot_link/network/mqtt/paho_mqtt/port/paho_osdepends.h):

#define INVALID_SOCKET SOCKET_ERROR
// #include 
#include 
#include 
// #include 
// #include 
// #include 
// #include 
#include 
#include 
#include 
#include 
#include 
#include 
#endif

#if defined(WIN32)
#include 
#else
// #include 
// #include 
#endif

5.因為弱引用導致無法鏈接相關符號,因此需要注釋以下幾個文件中的弱引用。

文件一 third_party/iot_link/network/dtls/dtls_al/dtls_al.c
#if 0
__attribute__((weak))  int dtls_imp_init(void)
{
    LINK_LOG_DEBUG("%s:###please implement dtls by yourself####",__FUNCTION__);
    return -1;
}
#endif
extern int dtls_imp_init(void);

文件二 third_party/iot_link/network/mqtt/mqtt_al/mqtt_al.c
#if 0
__attribute__((weak))  int mqtt_imp_init(void)
{
    LINK_LOG_DEBUG("%s:###please implement mqtt by yourself####",__FUNCTION__);
    return -1;
}
#endif
extern int mqtt_imp_init(void);

文件三 third_party/iot_link/oc_mqtt/oc_mqtt_al/oc_mqtt_al.c
#if 0
__attribute__ ((weak)) int oc_mqtt_imp_init(void)
{
    LINK_LOG_DEBUG("%s:###please implement oc mqtt by yourself####",__FUNCTION__);
    return 0;
}

__attribute__ ((weak)) int oc_mqtt_demo_main(void)
{
    LINK_LOG_WARN("Please implement the oc mqtt v5 demo yourself");
    return -1;
}
#endif
extern int oc_mqtt_demo_main(void);

修改GPIO查找方式

因為GPIO框架修改了設備驅動注冊的管腳號,導致應用無法根據HCS的引腳操作對應的GPIO,此問題已經提issue,如果該問題已解決,可以忽略此步驟。

打開drivers/framework/support/platform/src/gpio/gpio_manager.c,將cntlr->start = start;注釋即可。

static int32_t GpioManagerAdd(struct PlatformManager *manager, struct PlatformDevice *device)
{
    uint16_t start;
    struct GpioCntlr *cntlr = CONTAINER_OF(device, struct GpioCntlr, device);

    if ((start = GpioCntlrQueryStart(cntlr, &manager->devices)) >= GPIO_NUM_MAX) {
        PLAT_LOGE("GpioCntlrAdd: query range for start:%d fail:%d", cntlr->start, start);
        return HDF_ERR_INVALID_PARAM;
    }

//    cntlr->start = start;
    DListInsertTail(&device->node, &manager->devices);
    PLAT_LOGI("%s: start:%u count:%u", __func__, cntlr->start, cntlr->count);
    return HDF_SUCCESS;
}

將對應的驅動文件復制到drvier對應目錄:

因為主倉代碼中未將對應的驅動文件合并到driver/adpater/platform對應的目錄下,固需要手動將文件拷貝到對應目錄。若主倉已合入,可忽略此步驟。

// 拷貝gpio驅動
cp -af device/soc/allwinner/xradio/drivers/gpio/gpio_xradio.* driver/adpater/platform/gpio

// 修改driver/adpater/platform/gpio/BUILD.gn文件,加上gpio_xradio的編譯

hdf_driver(module_name) {
  sources = []
  if (defined(LOSCFG_SOC_COMPANY_BESTECHNIC)) {
    sources += [ "gpio_bes.c" ]
  }

  if (defined(LOSCFG_SOC_COMPANY_ALLWINNER)) {
    sources += [ "gpio_xradio.c" ]
  }

  include_dirs = [ "." ]
}

為了節省ram資源,可以把無用的資源先關閉,如關閉內部codec,將 device/soc/allwinner/xradio/xr806/project/prj_config.h中的PRJCONF_INTERNAL_SOUNDCARD_EN設置為0,如下:

/* Xradio internal codec sound card enable/disable */
#define PRJCONF_INTERNAL_SOUNDCARD_EN   0

4、代碼編譯

#首先可以查看一下hb的版本,如果hb版本為0.4.4版本就不需要更新。

查看hb版本

hb --version

更新hb, 以下指令需要在openharmony SDK根目錄執行

pip3 uninstall ohos_build
pip3 install build/li

編譯命令:
hb set  // 如果是第一次編譯,Input code path 命令行中鍵入"./" 指定OpenHarmony工程編譯根目錄后 回車,

如下圖所示,使用鍵盤上下鍵選中wifi_skylark

wKgZomXQnW2AfJ7CAAA9-Ujk-9c553.pngwKgZomXQnUuAP_yPAAAhKpafk90437.png

hb build // 如果需要全量編譯,可以添加-f 選項

生成的固件保存在out/xradio/smart_weight_scale目錄下

5、固件燒錄

參照文檔: XR806快速上手指導文檔

6、設備配網

在設備上電前需準備好安裝了數字管家應用的HarmonyOS手機,詳情見數字管家應用開發, 并在設置中開啟手機的NFC功能;

寫設備NFC標簽,詳細操作見設備NFC標簽指導文檔;

燒錄完成后,上電。開發者在觀察開發板上狀態LED燈以8Hz的頻率閃爍時,將手機上半部靠近開發板NFC標簽處(無NFC標簽的可用NFC貼紙替代);

碰一碰后手機將自動拉起數字管家應用并進入配網狀態;

配網過程中需要 連接設備的AP熱點,然后填寫需要配置的wifi的密碼;

最后點擊配置,手機會將ssid以及對應的密碼通過AP熱點發送到設備。

wKgaomXQnW6Ad5CrAA9xFE6PAlY180.gifpoYBAGJCzzCAI8MiAA9xFE6PAlY065.gif


審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • IOT
    IOT
    +關注

    關注

    187

    文章

    4210

    瀏覽量

    196794
  • 智能體重秤
    +關注

    關注

    0

    文章

    7

    瀏覽量

    1613
  • 華為云
    +關注

    關注

    3

    文章

    2491

    瀏覽量

    17427
  • OpenHarmony
    +關注

    關注

    25

    文章

    3722

    瀏覽量

    16317
收藏 人收藏

    評論

    相關推薦

    凌蒙派OpenHarmony開源項目榮獲本期Gitee官方推薦

    近日,我司凌蒙派OpenHarmony開源項目榮獲本期Gitee官方推薦。本期Gitee官方推薦不僅是對凌蒙派OpenHarmony開源項目的高度認可,也是對我司在推動開源生態建設方面
    的頭像 發表于 11-20 01:04 ?278次閱讀
    凌蒙派<b class='flag-5'>OpenHarmony</b>開源<b class='flag-5'>項目</b>榮獲本期Gitee官方推薦

    STM32項目實戰:基于STM32U5的智能大棚溫控系統(LVGL),附項目教程/源碼

    智能大棚溫控系統_STM32U5》項目完整文檔、項目源碼,點擊下方鏈接免費領取。項目資料領取https://s.c1ns.cn/F5XyUSTM32
    的頭像 發表于 11-13 17:08 ?593次閱讀
    STM32<b class='flag-5'>項目</b><b class='flag-5'>實戰</b>:基于STM32U5的<b class='flag-5'>智能</b>大棚溫控系統(LVGL),附<b class='flag-5'>項目</b>教程/源碼

    STM32項目實戰:基于STM32U5的智能燈光控制系統(LVGL),附項目教程/源碼

    智能燈光控制系統_STM32U5》項目完整文檔、項目源碼,點擊免費領取。項目資料領取:https://s.c1ns.cn/F5XyUSTM32項目
    的頭像 發表于 11-07 18:50 ?846次閱讀
    STM32<b class='flag-5'>項目</b><b class='flag-5'>實戰</b>:基于STM32U5的<b class='flag-5'>智能</b>燈光控制系統(LVGL),附<b class='flag-5'>項目</b>教程/源碼

    STM32項目實戰:基于STM32F4的智能燈光控制系統(LVGL),附項目教程/源碼

    智能燈光控制系統_STM32F4》項目完整文檔、項目源碼,私信小雯老師免費領取。STM32項目實戰之“
    的頭像 發表于 10-17 16:16 ?796次閱讀
    STM32<b class='flag-5'>項目</b><b class='flag-5'>實戰</b>:基于STM32F4的<b class='flag-5'>智能</b>燈光控制系統(LVGL),附<b class='flag-5'>項目</b>教程/源碼

    【全新課程資料】正點原子《ESP32基礎及項目實戰入門》培訓課程資料上線!

    與組件添加、下載與調試、GPIO外設講解、GPIO外部中斷講解、UART外設講解、TIMG定時器組講解和LEDC外設的講解 實戰項目:火災報警器項目、超聲波測距項目、搶答器
    發表于 09-24 17:59

    【全新課程資料】正點原子《ESP32物聯網項目實戰》培訓課程資料上線!

    正點原子《ESP32物聯網項目實戰》全新培訓課程上線啦!正點原子工程師手把手教你學!通過多個項目實戰,掌握ESP32物聯網項目的開發! 一、
    發表于 09-24 17:05

    基于迅為RK3588【RKNPU2項目實戰1】:YOLOV5實時目標分類

    [/url] 【RKNPU2 人工智能開發】 【AI深度學習推理加速器】——RKNPU2 從入門到實踐(基于RK3588和RK3568) 【RKNPU2項目實戰1】:YOLOV5實時目標分類 【RKNPU2
    發表于 08-15 10:51

    OpenHarmony項目群技術指導委員會2024年中務虛研討會圓滿落幕

    7月19日至20日,OpenHarmony項目群技術指導委員會(后文簡稱“OpenHarmony TSC”)2024年中務虛研討會于中國廈門順利召開。 本次會議由OpenHarmony
    的頭像 發表于 07-23 10:42 ?526次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>項目</b>群技術指導委員會2024年中務虛研討會圓滿落幕

    快準狠!體脂VS體重,你來選

    快準狠!體脂VS體重,你來選
    的頭像 發表于 05-21 08:04 ?2.3w次閱讀
    快準狠!體脂<b class='flag-5'>秤</b>VS<b class='flag-5'>體重</b><b class='flag-5'>秤</b>,你來選

    OpenHarmony南向開發案例:【智能體重

    通過數字管家應用監測體重上報數據,獲得當前測量到的體重,身高,并在應用端形成一段時間內記錄的體重值,以折線圖的形式表現出來,根據計算的BMI值來提醒當前身體健康狀態,推送健康小知識。
    的頭像 發表于 04-17 11:12 ?620次閱讀
    <b class='flag-5'>OpenHarmony</b>南向開發案例:【<b class='flag-5'>智能</b><b class='flag-5'>體重</b><b class='flag-5'>秤</b>】

    OpenHarmony內核編程實戰

    編程入門[Hello,OpenHarmony]在正式開始之前,對于剛接觸OpenHarmony的伙伴們,面對大篇幅的源碼可能無從下手,不知道怎么去編碼寫程序,下面用一個簡單的例子帶伙伴們入門。▍任務
    的頭像 發表于 03-27 08:31 ?835次閱讀
    <b class='flag-5'>OpenHarmony</b>內核編程<b class='flag-5'>實戰</b>

    鴻蒙OpenHarmony開發實戰:【MiniCanvas】

    基于OpenHarmony的Cavas組件封裝了一版極簡操作的MiniCanvas,屏蔽了原有Canvas內部復雜的調用流程,支持一個API就可以實現相應的繪制能力,該庫還在繼續完善中,也歡迎PR。
    的頭像 發表于 03-23 20:43 ?358次閱讀

    【六】Purple Pi OH開發板帶你7天入門OpenHarmony!

    今天我們來從OpenHarmony簡介、環境搭建、創建第一個OpenHarmony項目等方面開始OpenHarmony應用開發的第一步。一.Open
    的頭像 發表于 03-14 08:31 ?548次閱讀
    【六】Purple Pi OH開發板帶你7天入門<b class='flag-5'>OpenHarmony</b>!

    鴻蒙實戰項目開發:【短信服務】

    OpenHarmony 多媒體技術、Napi組件、OpenHarmony內核、Harmony南向開發、鴻蒙項目實戰等等)鴻蒙(Harmony NEXT) 技術知識點 如果你是一名An
    發表于 03-03 21:29

    OpenHarmony 項目實戰:基于全志 XR806 實現的上下位機雙 OpenHarmony 智能門鎖樣例

    一、簡介 本 demo 是基于 Openharmony 3.1 Beta 本版開發,不僅可以接收數字管家應用下發的指令來控制門鎖開啟,而且還可以通過數字管家設置不同的開鎖密碼以及一次性密碼,實現給
    的頭像 發表于 02-19 17:25 ?1087次閱讀
    <b class='flag-5'>OpenHarmony</b> <b class='flag-5'>項目</b><b class='flag-5'>實戰</b>:基于全志 XR806 實現的上下位機雙 <b class='flag-5'>OpenHarmony</b> <b class='flag-5'>智能</b>門鎖樣例
    主站蜘蛛池模板: www.狠狠操.com| 免费不卡毛片| 2021天天干| 99久热成人精品视频| 欧美日韩高清性色生活片| 2021韩国理论片ok电影天堂| 国产免费资源| 一级@片| 久久怡红院| 免费性bbbb台湾| 精品久久久久国产免费| 欧美成人性动漫在线观看| 天天做天天爽天天谢| 亚洲一区二区三区网站| 日本三级免费网站| 天天色亚洲| 九九视频热| 激情在线视频| 国产在视频线精品视频2021| 在线成人aa在线看片| 国产欧美在线一区二区三区| 黄页网站在线| 亚洲www| 99伊人| 亚洲一本高清| 免费色视频| 国产亚洲美女精品久久久2020| 永久免费的啪啪免费的网址| 国产精品天天爽夜夜欢张柏芝| 澳门久久| 日本三级精品| 免费看黄色录像| 亚洲bbbbbxxxxx精品三十七| 99久久999久久久综合精品涩| 在线免费视频一区二区| 美国一级毛片不卡无毒| 国产chinesehd精品酒店| 特级一级黄色片| 天天综合视频网| 一级毛片免费在线观看网站| 99综合色|