【软通动力】HarmonyOS服务卡片-运动饮食健康卡片 原创 精华

软通动力HOS
发布于 2021-7-19 09:53
浏览
22收藏

引言

随着现代人生活节奏的加快,生活水平的不断提高,健康成为了眼下人们越来越关心的话题,尤其对于上班族,熬夜加班,晚睡早起,饮食不规律,缺乏锻炼,使得身体出现一定的亚健康问题。随着科技的发展,只有通过科学的方法了解身体的指标,给出合理的饮食,睡眠,运动等等建议,才能针对性的改善自身的健康问题,让我们每一个人回归健康,快乐的生活。

开发背景

人们对健康的要求越来越高,从单纯的健康饮食到健康运动,再到两者的结合。但是,饮食和运动之间的平衡一般人很难掌握,而我们这款APP将饮食、运动、以及自身身体状况(如体脂、体重、内脂等)有机结合起来。以体魄为根本,运动为支撑点,饮食为辅助,为每个人量身打造健康体魄,为实现健康中国努力。

需求分析

目前年轻人工作压力大,饮食基本靠外卖,锻炼就去健身房,无法将饮食和健身相结合,本APP旨在为每一位用户打造个性化的运动饮食计划。其功能主要分为两类:运动(包括如何运动、需要多大运动量)与饮食(早中晚餐吃什么,怎么制作等)。

主要功能介绍

健康+服务卡片主要包含三部分功能:

1、服务卡片(2*2)展示体脂仪主要测量数据(体重、身体年龄、BMI值);

  【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

点击该卡片,可以进入APP主页,查看更多指标数据。

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

2、服务卡片(4*4)展示体脂仪其他更为精准化的测量数据,并根据这些数据给出科学的饮食推荐;

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

点击“早餐推荐”或午餐推荐,可以跳转至推荐的饮食页面。

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

3、服务卡片(2*4)根据体脂仪测量的各项数据,给出合理化的,精准化的训练方案。

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

点击卡片右侧推荐的健身项目,进入对应的训练项目详解。

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

关键技术细节实现

一、创建“健康+”app工程

1、安装和配置DevEco Studio 2.1 Release

2、创建项目

1)打开DevEco Studio,File→New→New Project;

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

2)Choose your ability template,选择Empty Ability(Java),然后Next;

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

3)Configure your project,下列红色框中都是要填写或者选择的,其中Project Name,Package Name,Save Location可以自定义;Project Type注意选择Application;Compatible API Version注意选择最新SDK版本:SDK API Version 5;Device Type选择你使用的设备,我这里选择Phone。最后点击Finish,项目创建完成。

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

二、健康与饮食app服务卡片实现

第一步:卡片生成

1)在项目包名上右击,选择New→Service Widget

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

2)Choose a template for your service widget,选择Base的服务卡片,然后在Template下任意选择一种模版,点击Next

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

3)Configure Your Service Widget,其中Service Widget Name, Description可以自定义;Select Ability/New Ability使用默认的MainAbility; Type可以选择java或者js开发;SupportDimensions选择卡片样式(2*2、2*4以及4*4);点击Finish,完成服务卡片创建。

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

第二步:卡片布局的修改:

2*2服务卡片的布局

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

2*4服务卡片的布局

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

4*4服务卡片的布局

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

第三步:卡片信息创建、更新、删除

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

第四步、卡片在桌面的创建方式

长按app图标,弹出如下弹框

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

选择服务卡片,出现如下选择画面

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

选择添加到桌面,则桌面会出现对应的服务卡片

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

第五步:卡片的点击跳转实现

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

【软通动力】HarmonyOS服务卡片-运动饮食健康卡片-鸿蒙开发者社区

重难点解析

点击卡片中某个控件,跳转至指定页面

1)在MainAbility的创建卡片onCreateForm(Intent intent)方法中创建ComponentProvider对象

ComponentProvider componentProvider=new ComponentProvider();

2)然后调用componentProvider.setIntentAgent(int viewId,IntentAgent intent)

其中第一个参数为控件ID,第二个参数为跳转指定页面传入的intent;

3)componentProvider.setIntentAgent(ResourceTable.Id_img_base2_4, startAbilityIntentAgent(ABILITY_NAME));

4)最后providerFormInfo.mergeActions(componentProvider);

5)startAbilityIntentAgent(ABILITY_NAME)参数为初入的ability名,字符串类型。

private IntentAgent startAbilityIntentAgent(String abilityName) {
  Intent intent = new Intent();
  Operation operation = new Intent.OperationBuilder()
      .withDeviceId("")
      .withBundleName("com.zel.health")
      .withAbilityName(abilityName)
      .build();
  intent.setOperation(operation);
  List<Intent> intentList = new ArrayList<>();
  intentList.add(intent);
  List<Flags> flags = new ArrayList<>();
  flags.add(Flags.UPDATE_PRESENT_FLAG);
  IntentAgentInfo paramsInfo = new IntentAgentInfo(200, IntentAgentConstant.OperationType.START_ABILITY, flags, intentList, null);
  IntentAgent intentAgent = IntentAgentHelper.getIntentAgent(this, paramsInfo);
  return intentAgent;
}

 

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
27
收藏 22
回复
举报
21条回复
按时间正序
/
按时间倒序
软通田可辉
软通田可辉

这个卡片我们程序员得多用用,多锻炼锻炼

1
回复
2021-7-19 10:00:56
软通小精灵
软通小精灵

程序员也需要养生呀!!

回复
2021-7-19 10:24:08
芒果爱学习
芒果爱学习

教你运动教你吃饭,双管齐下

回复
2021-7-19 10:40:04
粉粉gg
粉粉gg

好实用的卡片哦

回复
2021-7-19 10:46:05
Whyalone
Whyalone

很详细,也很实用

回复
2021-7-19 11:03:40
芳芳爱学习
芳芳爱学习

体脂数据什么的怎么获取

回复
2021-7-19 11:06:57
浩然兄弟
浩然兄弟

好想体验一下

回复
2021-7-19 11:44:22
Anzia
Anzia

等着上架!

回复
2021-7-19 12:48:53
chaoxiaoshu
chaoxiaoshu

感谢分享

另外提个建议哈

代码可否不要用图片,太小看不太清,除非我下载下来,那样就有点麻烦了

最好直接用插入代码的方式

回复
2021-7-19 13:00:36
软通动力HOS
软通动力HOS 回复了 chaoxiaoshu
感谢分享 另外提个建议哈 代码可否不要用图片,太小看不太清,除非我下载下来,那样就有点麻烦了 最好直接用插入代码的方式

好的,下次我们注意这个问题。

回复
2021-7-19 14:08:58
爱吃土豆丝的打工人
爱吃土豆丝的打工人

放个Keep的教程功能进去就更完美了~

1
回复
2021-7-19 17:28:03
软通动力HOS
软通动力HOS 回复了 爱吃土豆丝的打工人
放个Keep的教程功能进去就更完美了~

后续会完善的

回复
2021-7-19 19:00:54
鸿联
鸿联

好好学习一下

回复
2021-7-19 20:24:49
软通动力HOS
软通动力HOS 回复了 鸿联
好好学习一下

感谢支持

回复
2021-7-20 08:56:13
longlong899
longlong899

鸿蒙卡片,真的棒!

回复
2021-7-20 09:56:03
软通动力HOS
软通动力HOS 回复了 longlong899
鸿蒙卡片,真的棒!

感谢支持

回复
2021-7-22 10:51:54
亮亮大叔
亮亮大叔

健康关乎于每一个人的幸福

回复
2021-8-13 14:56:56
小发哥哥
小发哥哥

国民大健康,幸福你我他

回复
2021-8-13 15:02:13
入门大师小波哥
入门大师小波哥 回复了 鸿联
好好学习一下

66666666

回复
2021-8-22 00:22:17
入门大师小波哥
入门大师小波哥 回复了 longlong899
鸿蒙卡片,真的棒!

66666

回复
2021-8-22 00:38:48
回复
    相关推荐