0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【开源项目】OpenHarmony挑战赛-家庭医生终端系统-血压/心率/血氧检测

电子发烧友论坛 2022-09-21 09:47 次阅读

一、项目介绍

基于OpenHarmony使用HI3861实现血压、心率、血氧的检测和上传(具有独立APP)

采集被测人体血压(高血压/低血压参数)

采集被测人体心率参数

采集被测人体血氧参数

具有WEB配网功能

与服务器进行连接并实现数据交互

可使用清洁能源(太阳能板进行供电和充电)

开发基于OpenHarmony的控制APP

具有离线屏幕显示功能(OLED-0.96寸)

3a4a2176-38da-11ed-b180-dac502259ad0.jpg

二、WEB配网

教程视频


(1)碰一碰配网介绍

3a5f1cfc-38da-11ed-b180-dac502259ad0.png

通过一机一码的形式,识别到NFC后云端验证设备,进行弹窗拉起,再由NAN或AP的方式,实现发送配网的SSID和Password。

NAN配网

1. 操作设备上配网键让设备进入配网模式

2. 手机碰一碰设备上的NFC标签,拉起轻应用

3. 选择配网wifi

4. 调用 discoveryByNAN接口code为0

5. 调用connectDevice接口连接设备

6. 调用configDeviceNet接口开始配网

7. 调用disconnectDevice接口断开网络

8. 调用检测设备是否上线接口

9. 检测到设备上线,调用绑定设备接口

AP配网

1. 操作设备上配网键让设备进入配网模式

2. 手机碰一碰设备上的NFC标签,拉起轻应用

3. 选择配网wifi

4. 调用discoveryByNAN接口code不为0

5. 调用discoveryBySoftAp接口搜索当前设备的ap,搜索不到的话尝试直接去连接ap

6. 调用connectDevice接口连接设备

7. 调用configDeviceNet接口开始配网

8. 调用disconnectDevice接口断开网络

9. 调用检测设备是否上线接口

10. 检测到设备上线,调用绑定设备接口

(2)WEB配网

本章主要讲述如何实现web配网,是在STA模式下,模拟为一个网站服务器,当手机或其它设备进行访问时,检测是否为浏览器的协议头(HTTP),返回一个封装好的网页界面,通过网页上输入框的填写实现配网。

3a6bee28-38da-11ed-b180-dac502259ad0.png

HTTP协议介绍:

1. http协议->超文本传输协议

2. 应用:编写基于http协议的数据传输程序(网站中浏览器端获取网页的过程)

3. http请求作用:将要获取的内容以http协议的格式发送给服务端,服务端根据格式进行解析获取到其真实内容,将结果以http协议的格式回复给客户端。

(3)WEB配网界面

html源代码如下

"UTF-8" />"viewport" content="width=device-width, initial-scale=1.0">"X-UA-Compatible" content="ie=edge">程皖配网"my">"center">"16">欢迎使用程皖配网 
"center">WiFi名称:"text" name="s" placeholder="请输入您WiFi的名称" id="aa" style="text-align:center">
"center">WiFi密码:"text" name="p" placeholder="请输入您WiFi的密码" id="bb">
"center">服务器IP:"text" name="i" placeholder="请输入您的服务器IP" id="cc">
"center">服务器端口:"text" name="t" placeholder="请输入您的服务器端口" id="dd"> 
"center">"button" value="连接" onclick="wifi()" style="width:150px;height:40px" >"javascript">function wifi(){var ssid = my.s.value;var password =my.p.value;var tcp_ip = my.i.value;var tcp_port = my.t.value;var xmlhttp=new XMLHttpRequest();xmlhttp.open("GET","/HandleVal?ssid="+ssid+"&password="+password+"&tcp_ip="+tcp_ip+"&tcp_port="+tcp_port,true);xmlhttp.send()}

实现的效果如下:

3a7bafe8-38da-11ed-b180-dac502259ad0.png

(4)soft模式下实现网页服务器

该部分步骤分为四步:打开WIFI、进入softap模式,创建tcp服务器,解析HTTP指令。此处可参照

润和开源项目:

https://gitee.com/hihopeorg/HarmonyOS-IoT-Application-Development/tree/master

1)打开WIFI

ret = hi_wifi_init(APP_INIT_VAP_NUM, APP_INIT_USR_NUM);
  if (ret != HISI_OK) {
    printf("wifi init failed!
");
  } else {
    printf("wifi init success!
");
  }

2)进入softap模式

在softap.c文件下WifiAPTask函数,注册回调
  //注册wifi事件的回调函数
  g_wifiEventHandler.OnHotspotStaJoin = OnHotspotStaJoinHandler;
  g_wifiEventHandler.OnHotspotStaLeave = OnHotspotStaLeaveHandler;
  g_wifiEventHandler.OnHotspotStateChanged = OnHotspotStateChangedHandler;

  error = RegisterWifiEvent(&g_wifiEventHandler);

3)创建socket通道后进入判断接受内容循环

while (1)
    {
      if ((ret = recv(new_fd, recvbuf, sizeof(recvbuf), 0)) == -1)
      {
        printf("recv error 
");
      }else
      {
      //printf("recv :%s
", recvbuf);
      //返回s1中包含s2所有字符的最大起始段长度
      //size_t strspn(const char *s1, const char *s2);
      char* p= strstr(recvbuf,TEST);
      uint16_t DIR_buff = p - recvbuf;
      printf("
The GET HTTP num:%d
",DIR_buff);
      if(DIR_buff<10)
      {
       Set_clint_flag = 1;

      }else if(DIR_buff>40)
      {
       Set_clint_flag = 2;

       char *p1, *p2;
       p1 = strstr(recvbuf, "ssid=");
       p2 = strstr(recvbuf, "&password");
        if(p1!=0 && p2!=0 && p1
        {
          p1 += strlen("ssid=");
          memcpy(get_ssid, p1, p2 - p1);
          printf("
get the ssid = %s
", get_ssid); 
        }
       p1 = strstr(recvbuf, "password=");
       p2 = strstr(recvbuf, "&tcp_ip");
        if(p1!=0 && p2!=0 && p1
        {
          p1 += strlen("password=");
          memcpy(get_pwd, p1, p2 - p1);
          printf("get the ssid = %s
", get_pwd); 
        }
       WifiConnect(get_ssid,get_pwd);

      }else
      {
        Set_clint_flag = 3;
      }
      
      bzero(recvbuf, sizeof(recvbuf));
      //close(new_fd);
      }

      sleep(2);

      if(Set_clint_flag==1)
      {

    
      if ((ret = send(new_fd, httphard1, strlen(httphard1), 0)) == -1)
      {
        perror("send : ");
        
      }
      if ((ret = send(new_fd, webtr, strlen(webtr), 0)) == -1)
      {
        perror("send : ");
        
      }
        
        Set_clint_flag = 0;
        new_fd = -1;
        break;      
      }else if(Set_clint_flag==2)
      {
        Set_clint_flag = 0;
        new_fd = -1;
        WifiConnect(get_ssid,get_pwd);
        break;  
      }else if(Set_clint_flag==3)
      {
        Set_clint_flag = 0;
        new_fd = -1;
        break;   
      }
      sleep(2);
    }

在这个循环中实现了判断当前是否为HTTP指令,如果接收到访问信号就回发网页具体内容,实现手机显示网页。

在填写SSID和PWD后点击提交,此时手机再向HI3861发出HTTP指令,中间携带填入的信息,该部分由以下程序读取:

p1 = strstr(recvbuf, "ssid=");
       p2 = strstr(recvbuf, "&password");
        if(p1!=0 && p2!=0 && p1
        {
          p1 += strlen("ssid=");
          memcpy(get_ssid, p1, p2 - p1);
          printf("
get the ssid = %s
", get_ssid); 
        }

此时得到帐号密码后尝试连接,即实现网页配网

WifiConnect(get_ssid,get_pwd);

三、外设驱动

本系统使用到usart(PM2.5传感器)、IIC(OLED显示屏)、单总线(DHT11)三个部分和TCP(双线程收发)几个部分

Winodows下HI3861开发:



HI3861:鸿蒙网页显示传感器数据:


(1)打开外设使能

在usr_config.mk文件中去掉注释

CONFIG_I2C_SUPPORT=y
CONFIG_UART0_SUPPORT=y

(2)OLED显示屏驱动

3a9059a2-38da-11ed-b180-dac502259ad0.png

OLED,即有机发光二极管(Organic Light-Emitting Diode),又称为有机电激光显示(Organic Electroluminesence Display)。OLED由于同时具备自发光,不需背光源、对比度高、厚度薄、视角广、反应速度快、可用于挠曲性面板、使用温度范围广、构造及制程较简单等优异之特性,被认为是下一代的平面显示器新兴应用技术。

该传感器使用的IIC协议,经过IIC使能后初始化OLED就可以使用了:

hi_io_set_func(HI_IO_NAME_GPIO_13, HI_IO_FUNC_GPIO_13_I2C0_SDA);
  hi_io_set_func(HI_IO_NAME_GPIO_14, HI_IO_FUNC_GPIO_14_I2C0_SCL);
  ret = hi_i2c_deinit(HI_I2C_IDX_0);
  ret |= hi_i2c_init(HI_I2C_IDX_0, 100000); 
  if (ret != HI_ERR_SUCCESS) {
    printf("IIC error
");
  }else
  {
    printf("IIC sucesefful
");
  }
  OLED_ColorTurn(0);//0正常显示,1 反色显示
  OLED_DisplayTurn(0);//0正常显示 1 屏幕翻转显示

其中主要用到的函数是void OLED_ShowChar(u8 x,u8 y,u8 chr,u8 size1):

//在指定位置显示一个字符,包括部分字符
//x:0~127
//y:0~63
//size:选择字体 12/16/24
//取模方式 逐列式
void OLED_ShowChar(u8 x,u8 y,u8 chr,u8 size1)
{
u8 i,m,temp,size2,chr1;
u8 y0=y;
size2=(size1/8+((size1%8)?1:0))*(size1/2); //得到字体一个字符对应点阵集所占的字节数
chr1=chr-' '; //计算偏移后的值
for(i=0;i
{
//temp=asc2_1206[chr1][i];
if(size1==12)
    {temp=asc2_1206[chr1][i];} //调用1206字体
else if(size1==16)
    {temp=asc2_1608[chr1][i];} //调用1608字体
else return;

    for(m=0;m<8;m++)           //写入数据
    {
      if(temp&0x80)OLED_DrawPoint(x,y);
      else OLED_ClearPoint(x,y);
      temp<<=1;
      y++;
      if((y-y0)==size1)
      {
        y=y0;
        x++;
        break;
      }
}
 }
}

通过该函数,就能实现传感器数值和字符的显示。

(3)数据发送和接收

因为HI3861的线程限制,这边使用双线程,一个实现TCP数据的发送,另一个实现TCP数据的接收

发送线程:

void TcpClientTest(const char* host, unsigned short port)
{
  ssize_t retval = 0;
  int sockfd = socket(AF_INET, SOCK_STREAM, 0); // TCP socket
  SET_SOCKET_ID = sockfd;
  struct sockaddr_in serverAddr = {0};
  serverAddr.sin_family = AF_INET; // AF_INET表示IPv4协议
  serverAddr.sin_port = htons(port); // 端口号,从主机字节序转为网络字节序
  if (inet_pton(AF_INET, host, &serverAddr.sin_addr) <= 0) {  // 将主机IP地址从“点分十进制”字符串 转化为 标准格式(32位整数)
    printf("inet_pton failed!
");
    goto do_cleanup;
  }

  // 尝试和目标主机建立连接,连接成功会返回0 ,失败返回 -1
  if (connect(sockfd, (struct sockaddr *)&serverAddr, sizeof(serverAddr)) < 0) {
    printf("connect failed!
");
    goto do_cleanup;
  }
  printf("connect to server %s success!
", host);
  Wifi_SOCKET_GET();

while (1)
{
  osDelay(500);
  /////////////////////////////////////////////////////////上传函数
  retval = send(sockfd, buff, 6,0);//其中buff为数据
}

  do_cleanup:
  printf("do_cleanup...
");
  closesocket(sockfd);
}

接收处理线程:

static BOOL Wifi_SOCKET_RUN(void)
{
  ssize_t retval = 0;

  while(1)
  {

  retval = recv(SET_SOCKET_ID, &response, sizeof(response), 0);
    if(retval>0)
  {
    response[retval] = '';
    if(response[0] == 'o')
    {
      printf("send open!
");//此处对接收到的数据进行处理,并执行对应内容
    }
  }
  }
  do_cleanup:
  printf("do_cleanup...
");
  closesocket(SET_SOCKET_ID);
}

void Wifi_SOCKET_GET(void)
{
  osThreadAttr_t attr;

  attr.name = "Wifi_SOCKET_RUN";
  attr.attr_bits = 0U;
  attr.cb_mem = NULL;
  attr.cb_size = 0U;
  attr.stack_mem = NULL;
  attr.stack_size = 2048;
  attr.priority = 25;

  if (osThreadNew((osThreadFunc_t)Wifi_SOCKET_RUN, NULL, &attr) == NULL)
  {
    printf("Falied to create WifiAPTask!
");
  }
}

(4)血压测量驱动

3aa384e6-38da-11ed-b180-dac502259ad0.png


血压的测量选择使用便携式测量,在开发中已与电子血压仪行业标杆欧姆龙和传统水银血压仪进行比较,较为准确,可作为参考使用。

当前为使用第一阶段,与厂商(批量)第二阶段合作时可以得到更多的数据,可以当做一次小型的体检,如下图:

3ab6d438-38da-11ed-b180-dac502259ad0.jpg


其驱动方式为USART驱动,协议如下:

3ad02122-38da-11ed-b180-dac502259ad0.png


通过对数据的截取和发送即可实现。

四、APP开发

(1)环境搭建

3adba7e0-38da-11ed-b180-dac502259ad0.png

使用的是官方下载地址:

https://developer.harmonyos.com/cn/develop/deveco-studio#download_beta

我这边用的是今年三月份的版本,不过不影响,界面没什么变化

(2)TCP数据交互

该部分参考官方手册:

https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/apis/js-apis-socket.md/

import socket from '@ohos.net.socket';
let tcp = socket.constructTCPSocketInstance();

tcp.bind({address: '0.0.0.0', port: 12121, family: 1}, err => {
 if (err) {
  console.log('bind fail');
  return;
 }
 console.log('bind success');
})

tcp.on('message', value => {
 console.log("on message, message:" + value.message + ", remoteInfo:" + value.remoteInfo)
 let da = resolveArrayBuffer(value.message);
 let dat_buff = String(da);
//此处对接受到的数据进行处理



});
//将接受到的数据转化为文本型      
function resolveArrayBuffer(message){

 if (message instanceof ArrayBuffer) {
  let dataView = new DataView(message)
  let str = ""
  for (let i = 0;i < dataView.byteLength; ++i) {
   let c = String.fromCharCode(dataView.getUint8(i))
   if (c !== "
") {
    str += c
   }
  }
  return str;
 }
}
//数据的发送函数
function send_once(Con_buff) {
 if (flag == false) {

  let promise = tcp.connect({ address: { address: 'xxx.xxx.xxx.xxx', port: xxxx, family: 1 }, timeout: 2000 });
  promise.then(() => {
   console.log('connect success');
   flag = true;
   tcp.send({
    data: Con_buff
   }, err => {
    if (err) {
     console.log('send fail');
     return;
    }
    console.log('send success');
   })
  }).catch(err => {
   console.log('connect fail');
  });

 } else if (flag == true) {
  tcp.send({
   data: Con_buff
  }, err => {
   if (err) {
    console.log('send fail');
    return;
   }
   console.log('send success');
  })
 }
}

(3)界面设计

OpenHarmony界面设计(简单)教程:


本APP共用到了按钮、图片、标签三个部分,其对应的官网连接如下

按钮(Button):

https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-button.md/

图片(Image):

https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-image.md/

标签(TEXT):

https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/arkui-ts/ts-basic-components-text.md/

竖向排列(Column):

https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/arkui-ts/ts-container-column.md/

横向排列(Row):

https://docs.openharmony.cn/pages/v3.2Beta/zh-cn/application-dev/reference/arkui-ts/ts-container-row.md/

(4)参数动态更新

@State srtText: string = "测试变量";
 Text(this.srtText) //动态
    .fontSize(60)
    .fontWeight(FontWeight.Bold)
    .fontColor("#e94674")
   Button() {  //按钮控件
    Text('点击')
     .fontSize(50)
     .fontWeight(FontWeight.Bold)
   }.type(ButtonType.Capsule)
   .margin({
    top: 200
   })
   .width('50%')
   .height('10%')
   .backgroundColor('#0D9FFB')
   .onClick(() => {  //点击事件
     this.srtText = "更改内容"//更改数据
   })

在使用 @State变量对组件进行刷新时,发现只能在build中实现动态刷新,在外部创建全局变量或者外部函数的方式都不能实现,查阅资料后得到如下部分:

官方文档:

https://docs.openharmony.cn/pages/v3.1/zh-cn/application-dev/ui/ts-application-states-appstorage.md/

AppStorage与组件同步

在管理组件拥有的状态中,已经定义了如何将组件的状态变量与父组件或祖先组件中的@State装饰的状态变量同步,主要包括@Prop、@Link、@Consume。

本章节定义如何将组件变量与AppStorage同步,主要提供@StorageLink和@StorageProp装饰器。

@StorageLink装饰器

组件通过使用@StorageLink(key)装饰的状态变量,与AppStorage建立双向数据绑定,key为AppStorage中的属性键值。当创建包含@StorageLink的状态变量的组件时,该状态变量的值将使用AppStorage中的值进行初始化。在UI组件中对@StorageLink的状态变量所做的更改将同步到AppStorage,并从AppStorage同步到任何其他绑定实例中,如PersistentStorage或其他绑定的UI组件。

@StorageProp装饰器

组件通过使用@StorageProp(key)装饰的状态变量,将与AppStorage建立单向数据绑定,key标识AppStorage中的属性键值。当创建包含@StoageProp的状态变量的组件时,该状态变量的值将使用AppStorage中的值进行初始化。AppStorage中的属性值的更改会导致绑定的UI组件进行状态更新。

let varA = AppStorage.Link('varA')
let envLang = AppStorage.Prop('languageCode')
@Entry
@Component
struct ComponentA {
 @StorageLink('varA') varA: number = 2
 @StorageProp('languageCode') lang: string = 'en'
 private label: string = 'count'

 private aboutToAppear() {
  this.label = (this.lang === 'zh') ? '数' : 'Count'
 }

 build() {
  Row({ space: 20 }) {

   Button(`${this.label}: ${this.varA}`)
    .onClick(() => {
     AppStorage.Set('varA', AppStorage.Get('varA') + 1)
    })
   Button(`lang: ${this.lang}`)
    .onClick(() => {
     if (this.lang === 'zh') {
      AppStorage.Set('languageCode', 'en')
     } else {
      AppStorage.Set('languageCode', 'zh')
     }
     this.label = (this.lang === 'zh') ? '数' : 'Count'
    })
  }
 }
}

即通过AppStorage.Link和 @StorageLink的方式,可实现外部动态刷新Text组件和image组件(等等之类都可以),方便我们在全局调用时更新数据。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OpenHarmony
    +关注

    关注

    25

    文章

    3648

    浏览量

    16078
收藏 人收藏

    评论

    相关推荐

    CCF开源创新大赛决赛结果发布!OpenHarmony应用开发赛道尽展风采

    经过数月的激烈比拼与项目展示,第七届CCF开源创新大赛决赛结果揭榜!其中,深开鸿的“OpenHarmony应用开发-开源项目贡献
    的头像 发表于 11-07 08:07 132次阅读
    CCF<b class='flag-5'>开源</b>创新大赛决赛结果发布!<b class='flag-5'>OpenHarmony</b>应用开发赛道尽展风采

    2024年ICPC与华为挑战赛冠军杯圆满落幕

    近日,2024年ICPC&华为挑战赛冠军杯在深圳圆满落幕。该活动由华为和ICPC联合举办,汇聚全球顶尖的编程人才,共同探讨和解决具有挑战性的工业界真实问题,并对未来技术发展趋势及关键挑战展开讨论。今年的
    的头像 发表于 10-27 16:00 592次阅读

    50万奖金池!开放原子大赛——第二届OpenHarmony创新应用挑战赛正式启动

    第二届OpenHarmony创新应用挑战赛作为开放原子大赛旗下的重要项,聚焦 OpenHarmony应用开发,致力提升开发者的动手实践能力与开发创新应用的能力。
    发表于 10-24 15:40

    Cortex-A55人工智能教学实验箱操作教程_案例分享:5-26 检测实验

    的。 MAX30100芯片 MAX30100是一款集成有脉搏仪和心率监测传感器芯片,该芯片集成了两个LED、一个光电探测器、经过优化的光学器件和低噪声模拟信号处理器,可以检测脉搏
    发表于 10-15 16:34

    思尔芯题正式发布,邀你共战EDA精英挑战赛

    题发布COMPETITIONRELEASE2024中国研究生创芯大赛·EDA精英挑战赛(原“集成电路EDA设计精英挑战赛”)现已正式拉开帷幕。作为核心出题企业之一思尔芯(S2C),已经为你们准备了
    的头像 发表于 08-03 08:24 500次阅读
    思尔芯<b class='flag-5'>赛</b>题正式发布,邀你共战EDA精英<b class='flag-5'>挑战赛</b>!

    基于STM32单片机的心率监测系统设计

    系统内使用STM32单片机进行主控,使用血心率传感器可以进行心率
    的头像 发表于 06-26 11:15 1351次阅读
    基于STM32单片机的<b class='flag-5'>血</b><b class='flag-5'>氧</b><b class='flag-5'>心率</b>监测<b class='flag-5'>系统</b>设计

    开放原子开源大赛OpenHarmony智能化应用生态挑战赛决赛路成功举办

    软件定义世界,开源共筑未来。在江苏省工信厅、市工信局、开放原子开源基金会及相关单位的指导和支持下,4月19-20日,由中软国际教育科技集团联合举办的开放原子开源大赛-OpenHarmony
    的头像 发表于 04-24 09:48 376次阅读

    软通动力子公司鸿湖万联成功举办基于x86架构的OpenHarmony应用生态挑战赛

    应用生态挑战赛”决赛路演在无锡圆满落幕。本次挑战赛历时近3个月,受到了来自企业、院校以及个人开发者等多个领域的广泛关注和积极响应,超过120个团队/个人踊跃报名参赛
    的头像 发表于 04-23 09:34 347次阅读
    软通动力子公司鸿湖万联成功举办基于x86架构的<b class='flag-5'>OpenHarmony</b>应用生态<b class='flag-5'>挑战赛</b>

    鸿湖万联成功举办基于x86架构的OpenHarmony应用生态挑战赛

    近日,由开放原子开源基金会、央视网、江苏省工业和信息化厅、无锡市人民政府、江苏软件产业人才发展基金会、苏州工业园区、无锡高新区等共同承办,鸿湖万联参与共建的“基于x86架构的OpenHarmony应用生态挑战赛”决赛路演在无锡圆
    的头像 发表于 04-23 09:26 315次阅读
    鸿湖万联成功举办基于x86架构的<b class='flag-5'>OpenHarmony</b>应用生态<b class='flag-5'>挑战赛</b>

    便携式心率检测

    便携式心率检测仪使用了一款医疗级别的传感器MAX30102;MAX30102是一个集成的脉搏
    的头像 发表于 03-27 09:16 576次阅读
    便携式<b class='flag-5'>心率</b><b class='flag-5'>血</b><b class='flag-5'>氧</b><b class='flag-5'>检测</b>仪

    开放原子开源大赛—基于OpenHarmony的团结引擎应用开发正式启动!

    “基于OpenHarmony的团结引擎应用开发”是开放原子全球开源大赛下开设的新兴及应用题之一,本次
    发表于 03-13 10:45

    XBLW芯伯乐|指夹式仪方案及算法程序

    仪广泛应用于医院、家庭、体育训练场所等场景。在医院中,仪常被用于监测患者在手术、重症监护、麻醉等环境下的
    的头像 发表于 01-26 00:00 853次阅读
    XBLW芯伯乐|指夹式<b class='flag-5'>血</b><b class='flag-5'>氧</b>仪方案及算法程序

    30万奖金!开放原子开源大赛“云原生数据缓存性能挑战赛” 等你来挑战

      开放原子开源基金会牵头发起的首届“开放原子开源大赛”正在火热进行中。东方通支撑的“云原生数据缓存性能挑战赛”将与1月10日正式启动报名,诚挚欢迎有理想、有激情的开发者、发烧友们前来挑战
    的头像 发表于 01-11 10:31 359次阅读

    OpenHarmony创新冠军团队专访:做开源时代的守正创新者

    点击蓝字 ╳ 关注我们 开源项目 OpenHarmony 是每个人的 OpenHarmony 12月15日,一场以技术交流和创新碰撞为核心的开源
    的头像 发表于 01-09 21:15 523次阅读
    <b class='flag-5'>OpenHarmony</b>创新<b class='flag-5'>赛</b>冠军团队专访:做<b class='flag-5'>开源</b>时代的守正创新者

    OpenHarmony人形机器人创新挑战赛来啦

    12月28日,第二十六届中国机器人及人工智能大赛人形机器人创新挑战赛在苏州正式发布,首次结合
    的头像 发表于 12-30 08:32 1024次阅读
    <b class='flag-5'>OpenHarmony</b>人形机器人创新<b class='flag-5'>挑战赛</b>来啦