一、硬件说明

Neptune OpenHarmony物联网IOT模组Wi-Fi&蓝牙双模开发板、超声波模块、蜂鸣器模块、杜邦线若干

开发板相关资料:https://gitee.com/hihope_iot/docs/tree/master/Neptune

实现效果

将水杯放到超声波传感器前,实现15分钟提示一次喝水。

二、项目开发流程

  1. 接线

  1. 编写C语言代码

    主要完成以下逻辑:

    (1)编写蜂鸣器、超声波测距的代码

    (2)不断获取水杯的位置

    (3)对获取到的水杯距离做判断

    (4)如果超过时间阈值,开始报警,否则关闭报警

task_drink_Water.h

 #ifndef _TASK_DRINK_WATER_H
#define _TASK_DRINK_WATER_H #include "los_compiler.h" #ifdef __cplusplus
#if __cplusplus
extern "C" {
#endif /* __cplusplus */
#endif /* __cplusplus */ VOID CreateDrinkWaterTask(VOID); #ifdef __cplusplus
#if __cplusplus
}
#endif /* __cplusplus */
#endif /* __cplusplus */ #endif /* _TASK_DRINK_WATER_H */

task_drink_water.c

 #include "task_drink_water.h"
#include "stdio.h"
#include "los_task.h"
#include "utils_file.h"
#include "wm_gpio.h" #define TASK_DRINK_WATER_PRIORITY 6 //喝水提醒任务的优先级 #define TRIG_GPIO WM_IO_PB_00 //超声波触发检测IO口,PB0
#define ECHO_GPIO WM_IO_PB_05 //超声波响应检测IO口,PB5,高电平时间就是超声波发送出去到被接收器接受的时间
#define BUZZER_GPIO WM_IO_PB_01 //蜂鸣器控制IO口,PB1 /**
* @brief 开启和关闭蜂鸣器,开启时提醒用户喝水
* @param[in] value : 1:开启,0:关闭
* @retval
*/
VOID RemindToDrinkWater(u8 value) {
tls_gpio_cfg(WM_IO_PB_01, WM_GPIO_DIR_OUTPUT, WM_GPIO_ATTR_PULLLOW);
tls_gpio_write(WM_IO_PB_01, value);
} /**
* @brief 通过超声波测距启动一次测距,返回测量的距离,单位mm
* @retval 返回单位mm
*/
INT64 GetDistanceMM(VOID) {
UINT64 checkStart;
UINT64 timeCount;
UINT64 waitStart; tls_gpio_cfg(TRIG_GPIO, WM_GPIO_DIR_OUTPUT, WM_GPIO_ATTR_PULLLOW); //设置触发脚为输出
tls_gpio_cfg(ECHO_GPIO, WM_GPIO_DIR_INPUT, WM_GPIO_ATTR_PULLLOW); //设置检测距离IO口为输入 //控制触发脚超过10us的方波启动检测
tls_gpio_write(TRIG_GPIO, 1);
(VOID)LOS_TaskDelay(10);
tls_gpio_write(TRIG_GPIO, 0); waitStart = LOS_SysCycleGet();
//等待ECHO IO口高电平
while (tls_gpio_read(ECHO_GPIO) == 0); //高电平后开始启动计时
checkStart = LOS_SysCycleGet(); //等待ECHO IO口低电平
while (tls_gpio_read(ECHO_GPIO) == 1); //计时结束
timeCount = LOS_SysCycleGet() - checkStart;
printf("timeCount = %lld\n", timeCount); //根据CPU的频率,将时钟周期转换成ns
timeCount = (timeCount / OS_SYS_CLOCK) * OS_SYS_NS_PER_SECOND +
(timeCount % OS_SYS_CLOCK) * OS_SYS_NS_PER_SECOND / OS_SYS_CLOCK; //计算距离 340 米/s * timeCount(ns) * 1000 / 1000000000 / 2
return (170 * timeCount / 1000000); }
/**
* @brief 喝水提醒任务主函数
* @retval 无
*/
VOID TaskDrinkWaterEntry(VOID) {
//UINT64 start = LOS_SysCycleGet();
UINT64 distance;
UINT64 lastTimeToDrink = 0;
UINT64 noDrinkingTimeCount;
u8 lastStatus = 0xFF; while (1) {
distance = GetDistanceMM();
if (distance > 50) { //杯子离开超声波检测范围超过50mm,当作喝水
lastTimeToDrink = LOS_SysCycleGet(); //记录上次喝水的时间(杯子离开超声波测距模块即将放回去的时间)
}
noDrinkingTimeCount = LOS_SysCycleGet() - lastTimeToDrink; //当前时间减去上次喝水的时间,算出未喝水的时间。 //将时间转换成ms
noDrinkingTimeCount = (noDrinkingTimeCount / OS_SYS_CLOCK) * 1000 +
(noDrinkingTimeCount % OS_SYS_CLOCK) * 1000 / OS_SYS_CLOCK; printf("noDrinkingTimeCount = %lld\n", noDrinkingTimeCount);
if (noDrinkingTimeCount > 10 * 1000) { //超过10秒未喝水进行提醒,时间可改,为了测试方便默认10s
if (lastStatus != 1) { //如果上次已经开启蜂鸣器,状态未变化的情况下不再开启蜂鸣器。
printf("Have a break and drink water!,tick = %lld\n", LOS_SysCycleGet());
RemindToDrinkWater(1); //提醒喝水
lastStatus = 1;
}
} else {
if (lastStatus != 0) {
RemindToDrinkWater(0); //杯子放回,关闭提醒。
lastStatus = 0;
} }
printf("distance = %lld\n", distance);
(VOID)LOS_TaskDelay(250); //适当延迟,给其他任务执行的机会
}
} /**
* @brief 创建喝水提醒任务
* @retval 无
*/
VOID CreateDrinkWaterTask(VOID) {
UINT32 ret;
UINT32 taskID1;
UINT32 taskID2;
TSK_INIT_PARAM_S stTask = {0}; printf("TaskSample: DrinkWaterTask create start...\n");
stTask.pfnTaskEntry = (TSK_ENTRY_FUNC)TaskDrinkWaterEntry;
stTask.uwStackSize = LOSCFG_BASE_CORE_TSK_DEFAULT_STACK_SIZE; //默认任务栈大小,根据需求配置,创建任务时,可以针对性设置
stTask.pcName = "DrinkWaterTask";
stTask.usTaskPrio = TASK_DRINK_WATER_PRIORITY;
ret = LOS_TaskCreate(&taskID1, &stTask);
if (ret != LOS_OK) {
printf("DrinkWaterTask create failed\n");
}
}

main.c

#include "devmgr_service_start.h"
#include "task_drink_water.h" void UserMain(void) {
printf("\n user task \n"); #if DEMO_CONSOLE
CreateDemoTask();
#endif
CreateDrinkWaterTask(); #if defined(LOSCFG_KERNEL_TEST_FULL) || defined(LOSCFG_KERNEL_TEST)
LosAppInit();
#else
if (DeviceManagerStart()) {
printf("[%s] No drivers need load by hdf manager!", __func__);
}
#endif
}
  1. 搭建软件开发环境,在Ubuntu下编译OpenHarmony系统源码

    在windows上写完代码后,在linux下中进行OpenHarmony代码编译

    (1)安装docker desktop,如果打开软件出现Docker Desktop stopping就需要安装 wsl_update_x64.msi

    (2)使用windows命令行,执行以下命令,以便在docker中准备一个集成好Neptune开发环境的Ubuntu(linux)系统

    路径替换成自己的!

    docker load -i D:\NeptuneOpenHarmony\software\neptune_openharmony_docker.tar

(3)将OpenHarmony源码包所在路径映射到linux下,路径替换成自己的!

docker run -it --rm -v D:\NeptuneOpenHarmony\software\Neptune:/home/Neptune
neptune_openharmony_docker:latest

(4)进入到/home/Neptune

cd /home/Neptune

(6)解压源码

tar -xvf openharmony_master.tar.gz

(7)将代码文件移动至如下位置

device\soc\winnermicro\wm800\board\app

(8)进入源码目录

cd /home/Neptune/openharmony_master`

(9)启动编译

hb build -f

  1. 烧写代码到Neptune开发板

    烧写
  2. 编译好的文件会被存放在如下目录

    out/neptune100/neptune_iotlink_demo/bin/hihope_neptune100.fls
  3. 将开发板连接到电脑上
  4. 打开Upgrade_Tools_V1.4.13下载工具
  5. 做好配置,开始烧写步骤

基于OpenHarmony的智能喝水提醒器的更多相关文章

  1. 基于Linux的智能家居的设计(3)

    2  硬件设计 本课题的硬件设计包含主控制器.传输数据设计.数据採集设计.控制驱动设计.显示设计.门禁设计. 2.1  主控制器 依据方案三选择S3C6410主控芯片,S3C6410是由Samsung ...

  2. 基于Linux的智能家居的设计(2)

    1  系统整体设计方案 智能家居系统的是一个实时查询家庭的温湿度.照明控制.自己主动控制的设定.集家庭娱乐.智能安防为一体,大量数据快处理.可靠的系统,因此在硬件和软件上都有非常大的要求,因此在这里进 ...

  3. 毕业设计——基于ZigBee的智能窗户控制系统的设计与实现

    题目:基于物联网的智能窗户控制系统的设计与实现 应用场景:突降大雨,家里没有关窗而进水:家中燃气泄漏,不能及时通风,威胁人身安全,存在火灾的隐患:家中窗户没关,让坏人有机可乘.长时间呆在人多.封闭的空 ...

  4. 基于ESP32的智能家居管理系统的设计与实现

    基于ESP32的智能家居管理系统的设计与实现 ESP32的智能家居管理系统访问链接: https://www.cnblogs.com/easyidea/p/13101165.html 一.需求分析 1 ...

  5. 超级简单!CentOS-8 安装 MySQL 8.0,比喝水还简单

    中国人不骗中国人 果然是系统和MySQL的版本越高安装越便利了 在阿里云的 CentOS-8 比喝开水还简单的安装 MySQL 8.0,开始~ 1.以 root 用户通过 CentOS 软件包管理器来 ...

  6. C语言基于GTK+Libvlc实现的简易视频播放器

    小编心语:现下,各种视频播放软件层出不穷,竞争也越演越烈,不知道大家有木有这个想法,小编有时在想能不能做一款属于自己的视频播放器呢~小编特意去实验楼,整理出了这篇关于如何实现简易视频播放器的博文.简易 ...

  7. 基于注解风格的Spring-MVC的拦截器

    基于注解风格的Spring-MVC的拦截器 Spring-MVC如何使用拦截器,官方文档只给出了非注解风格的例子.那么基于注解风格如何使用拦截器呢? 基于注解基本上有2个可使用的定义类,分别是Defa ...

  8. FZYZOJ-1569 喝水

    P1569 -- 喝水 时间限制:2000MS      内存限制:131072KB 状态:Accepted      标签:    无   无   无 Description GH的N个妹子要喝水, ...

  9. Clipboard Action for Mac(智能剪贴板历史管理器)破解版安装

    1.软件简介    Clipboard Action 是 macOS 系统上一款智能剪贴板历史管理器,它允许剪贴板历史中的每一段内容执行操作.使用 AppleScript 或 Automator 工作 ...

随机推荐

  1. 《ASP.NET Core 6框架揭秘》样章[200页/5章]

    作为<ASP.NET Core 3 框架揭秘>的升级版,<ASP.NET Core 6框架揭秘>不仅针对ASP.NET Core 6的新特性进行了修订,并添加了若干原来没有的内 ...

  2. Kafka Topic Partition Offset 这一长串都是啥?

    摘要:Offset 偏移量,是针对于单个partition存在的概念. 本文分享自华为云社区<Kafka Topic Partition Offset 这一长串都是啥?>,作者: gent ...

  3. Python网页解析库:用requests-html爬取网页

    Python网页解析库:用requests-html爬取网页 1. 开始 Python 中可以进行网页解析的库有很多,常见的有 BeautifulSoup 和 lxml 等.在网上玩爬虫的文章通常都是 ...

  4. 二分法求最长子序列长度(STL)(nlogn)

    声明: 正如标题所说,只是求长度,应对题目要求,请自行判断,用错代码概不负责! 本蒟蒻的代码可能有错,有错误还请各位dalao请指出 运用了upper_bound()和lower_bound()函数 ...

  5. ASP.NET Core 6.0 基于模型验证的数据验证

    1 前言 在程序中,需要进行数据验证的场景经常存在,且数据验证是有必要的.前端进行数据验证,主要是为了减少服务器请求压力,和提高用户体验:后端进行数据验证,主要是为了保证数据的正确性,保证系统的健壮性 ...

  6. 聊聊如何用 Redis 实现分布式锁?

    作者:小林coding 计算机八股文网站:https://xiaolincoding.com 哈喽,我是小林. 今天跟大家聊聊两个问题: 如何用 Redis 实现分布式锁? Redis 是如何解决集群 ...

  7. 重写并自定义依赖的原生的Bean方法

    转载请注明出处: 在项目开发过程中,往往是直接应用很多jar包中依赖且声明好的Bean,拿来即用,但很多场景也需要对这些原生的Bean 进行自定义,定制化封装,这样在项目使用的过程中,可以使用自定义的 ...

  8. React报错之Property 'X' does not exist on type 'HTMLElement'

    正文从这开始~ 总览 在React中,当我们试图访问类型为HTMLElement 的元素上不存在的属性时,就会发生Property 'X' does not exist on type 'HTMLEl ...

  9. Apache Dolphinscheduler3.0.0-beta-1 版本发布,新增FlinkSQL、Zeppelin任务类型

    导读:近日,Apache Dolphin Scheduler 迎来了 3.0.0-beta-1 版本的正式发布.新版本主要针对 3.0.0-alpha 进行了代码和文档的修复,并引入了部分的功能,如支 ...

  10. 原生js也可以自定义组件

    Web Components 是一套不同的技术,允许您创建可重用的定制元素(它们的功能封装在您的代码之外)并且在您的web应用中使用它们. 它由三项主要技术组成,它们可以一起使用来创建封装功能的定制元 ...