开发背景
人们对健康的要求越来越高,从单纯的健康饮食到健康运动,再到两者的结合。但是,饮食和运动之间的平衡一般人很难掌握,而我们这款 APP 将饮食、运动、以及自身身体状况(如体脂、体重、内脂等)有机结合起来。
以体魄为根本,运动为支撑点,饮食为辅助,为每个人量身打造健康体魄,为实现健康中国努力。
需求分析
目前年轻人工作压力大,饮食基本靠外卖,锻炼就去健身房,无法将饮食和健身相结合,本 APP 旨在为每一位用户打造个性化的运动饮食计划。
其功能主要分为两类:运动(包括如何运动、需要多大运动量)与饮食(早中晚餐吃什么,怎么制作等)。
主要功能介绍
健康+服务卡片主要包含三部分功能:
①服务卡片(2*2)展示体脂仪主要测量数据(体重、身体年龄、BMI 值)。
data:image/s3,"s3://crabby-images/20a35/20a357bbe220dcc8cb9b5977143818440fd35f82" alt=""
点击该卡片,可以进入 APP 主页,查看更多指标数据。
data:image/s3,"s3://crabby-images/e8247/e8247687505bc651c48ba89346468ff694718546" alt=""
②服务卡片(4*4)展示体脂仪其他更为精准化的测量数据,并根据这些数据给出科学的饮食推荐。
data:image/s3,"s3://crabby-images/14198/14198573a4cc26f19a9167ed44478366f65e0e5e" alt=""
点击"早餐推荐"或午餐推荐,可以跳转至推荐的饮食页面。
data:image/s3,"s3://crabby-images/83464/83464aa62e7dd25dd1a69390e0fc37f7686c5ff3" alt=""
③服务卡片(2*4)根据体脂仪测量的各项数据,给出合理化的,精准化的训练方案。
data:image/s3,"s3://crabby-images/d75ca/d75ca9e26bd4683edfb9ee5ed8b004b6808e1272" alt=""
点击卡片右侧推荐的健身项目,进入对应的训练项目详解。
data:image/s3,"s3://crabby-images/de71c/de71ccc49f54d56732acf90d3a768dd04e9b5fef" alt=""
关键技术细节实现
①创建"健康+"app 工程
安装和配置 DevEco Studio 2.1 Release,并创建项目。
打开 DevEco Studio,File→New→New Project:
data:image/s3,"s3://crabby-images/bb19a/bb19adca66e951b02d56862853361bb8d8fb2b2e" alt=""
Choose your ability template,选择 Empty Ability(Java),然后 Next:
data:image/s3,"s3://crabby-images/d2801/d28013a9ea4c86b600fe92ff706080d93866497d" alt=""
Configure your project,下列红色框中都是要填写或者选择的,其中 Project Name,Package Name,Save Location 可以自定义。
Project Type 注意选择 Application;Compatible API Version 注意选择最新 SDK 版本:SDK API Version 5;Device Type 选择你使用的设备,我这里选择 Phone。
最后点击 Finish,项目创建完成:
data:image/s3,"s3://crabby-images/9990c/9990c3e565f4435729878127ba73b9d57c585f32" alt=""
②健康与饮食 app 服务卡片实现
第一步:卡片生成
在项目包名上右击,选择 New→Service Widget:
data:image/s3,"s3://crabby-images/8b116/8b116559272492972a4fe28afa30e1b6fd771047" alt=""
Choose a template for your service widget,选择 Base 的服务卡片,然后在 Template 下任意选择一种模版,点击 Next:
data:image/s3,"s3://crabby-images/02981/02981c4984c1562ef9bfc1cd7ce5ad5deec574e4" alt=""
Configure Your Service Widget,其中 Service Widget Name, Description 可以自定义。
Select Ability/New Ability 使用默认的 MainAbility;Type 可以选择 java 或者 js 开发;SupportDimensions 选择卡片样式(2*2、2*4 以及 4*4)。
点击 Finish,完成服务卡片创建:
data:image/s3,"s3://crabby-images/6a8fd/6a8fd33abbc425e515308dcf458ca3526b69fa44" alt=""
第二步:卡片布局的修改
2*2 服务卡片的布局:
data:image/s3,"s3://crabby-images/4e126/4e126428167ad3a19a0ebed88391ea055c133a7f" alt=""
2*4 服务卡片的布局:
data:image/s3,"s3://crabby-images/be95a/be95a6e92413a58d90d24901c67e3b4b72847987" alt=""
4*4 服务卡片的布局:
data:image/s3,"s3://crabby-images/87362/87362c7fced1b7bbf278f1de3ab667b57af10f9c" alt=""
第三步:卡片信息创建、更新、删除
代码如下:
data:image/s3,"s3://crabby-images/5270a/5270a176ee1e44ff82e4d80d1a9fae54209ef202" alt=""
data:image/s3,"s3://crabby-images/da9bc/da9bcaf052bae3ee25f346195e22a1f14976420c" alt=""
第四步、卡片在桌面的创建方式
长按 app 图标,弹出如下弹框:
data:image/s3,"s3://crabby-images/b0194/b01943dd45d768f572e14e888e49ff1055bcad16" alt=""
选择服务卡片,出现如下选择画面:
data:image/s3,"s3://crabby-images/79237/7923785694721d930fbf954e9cfddc36a59c47a8" alt=""
选择添加到桌面,则桌面会出现对应的服务卡片:
data:image/s3,"s3://crabby-images/a363d/a363d61978ec396ee6ded8cbfcbec24ecaa066ef" alt=""
第五步:卡片的点击跳转实现
代码如下:
data:image/s3,"s3://crabby-images/ee848/ee8482a53a8643a9a4132c124979ff7bd9cf271d" alt=""
data:image/s3,"s3://crabby-images/901f0/901f0d6fe6e0f4bf1109b0f0430ebc965159c0aa" alt=""
重难点解析
点击卡片中某个控件,跳转至指定页面:
①在 MainAbility 的创建卡片 onCreateForm(Intent intent) 方法中创建 ComponentProvider 对象。
ComponentProvider componentProvider=new ComponentProvider();
②然后调用componentProvider.setIntentAgent(int viewId,IntentAgent intent);其中第一个参数为控件 ID,第二个参数为跳转指定页面传入的 intent。
③componentProvider.setIntentAgent(ResourceTable.Id_img_base2_4, startAbilityIntentAgent(ABILITY_NAME));
④最后 providerFormInfo.mergeActions(componentProvider);
⑤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;
}
最后
如果你想快速提升鸿蒙技术,那么可以直接领取这份包含了:【OpenHarmony多媒体技术、Stage模型、ArkUI多端部署、分布式应用开发、音频、视频、WebGL、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战】等技术知识点。
鸿蒙Next全套VIP学习资料←点击领取!(安全链接,放心点击)
1.鸿蒙核心技术学习路线
data:image/s3,"s3://crabby-images/81de6/81de667123a90225903d3d148b5d97ba13c28fd2" alt=""
2.大厂面试必问面试题
data:image/s3,"s3://crabby-images/7dd73/7dd73b258c1b220a54365bb45b537bda72be0f34" alt=""
3.鸿蒙南向开发技术
data:image/s3,"s3://crabby-images/d85b3/d85b36bb6b1b1c1111d38949aeee64c655e570da" alt=""
4.鸿蒙APP开发必备
data:image/s3,"s3://crabby-images/805ad/805ad69514a47241066935aefcba9c6b2264f83f" alt=""
5.HarmonyOS Next 最新全套视频教程
data:image/s3,"s3://crabby-images/1ae59/1ae5919b71cf15f52f84e2bc65fad728d2aae4c9" alt=""
6.鸿蒙生态应用开发白皮书V2.0PDF
data:image/s3,"s3://crabby-images/fe621/fe6217b70ed73df56b057b556a39166db32848cb" alt=""