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

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

3天内不再提示

HarmonyOS 3.1上实现计步卡片

OpenHarmony技术社区 来源:OST开源开发者 2023-05-29 11:10 次阅读

本篇帖子是参考 Codelab 基于 Stage 模型 JS 服务卡片,使用最新 ArkTS 元服务开发的,实现带有卡片的计步应用,用于介绍卡片的开发及生命周期实现。

需要完成以下功能:

消息通知栏,通知用户今天所行走步数(行走步数是模拟的)。

元服务卡片,在桌面上添加 2x2 或 2x4 规格元服务卡片,能看到步数变化,也能看到当天所行走的进度。

关系型数据库,用于查询,添加用户行走的数据。

知识点

消息通知:提供通知管理的能力,包括发布、取消发布通知,创建、获取、移除通知通道,订阅、取消订阅通知,获取通知的使能状态、角标使能状态,获取通知的相关信息等。

关系型数据库:关系型数据库基于 SQLite 组件提供了一套完整的对本地数据库进行管理的机制,对外提供了一系列的增、删、改、查等接口,也可以直接运行用户输入的 SQL 语句来满足复杂的场景需要。

元服务卡片开发:卡片是一种界面展示形式,可以将应用的重要信息或操作前置到卡片,以达到服务直达、减少体验层级的目的。

卡片提供方:显示卡片内容,控制卡片布局以及控件点击事件。

卡片使用方:显示卡片内容的宿主应用,控制卡片在宿主中展示的位置。

卡片管理服务:用于管理系统中所添加卡片的常驻代理服务,包括卡片对象的管理与使用,以及卡片周期性刷新等。

软件要求:

DevEco Studio版本:DevEco Studio 3.1 Release及以上版本。

HarmonyOS SDK版本:API version 9及以上版本。

硬件要求:

设备类型:华为手机 3.1 系统或运行在 DevEco Studio 上的远程模拟器 API9。

HarmonyOS 系统:3.1.0 DeveloperRelease 及以上版本。

讲解

卡片更新逻辑和Codelabs是一样的,详情可以移步到 Stage 模型卡片(ArkTS)细看,这里主要讲解一下 ArKTS 开发服务卡片。

Codelabs 开发的是 JS 服务卡片,还有在把这个 JS 卡片改为用 ArkTS 过程中,需要注意的地方:

使用关系型数据库时,Codelabs 与使用最新版本 API 不同之处:

Codelabs 源码:

awaitDataRdb.getRdbStore(context,CommonConstants.RDB_STORE_CONFIG)
.then((rdbStore:DataRdb.RdbStore)=>{
本项目源码:
awaitDataRdb.getRdbStore(context,CommonConstants.RDB_STORE_CONFIG)
.then((rdbStore)=>{

②使用 Chart 组件和 Polyline 组件:

在 JS 服务卡片可以使用 Chart 组件来生成曲线图表:


在 ArkTS 服务卡片,使用不了 Chart 组件,用 Polyline 组件来代替:

Polyline().width('100%').height('100%').points(this.setPolyLine(this.datasets))

默认 EntryAbility.ts 和 EntryFormAbility.ts 两个文件的后辍都是 ts 的,其他文件后辍是 ets 的,当想在这两个文件 import 其它文件时,提示以下信息,于是我把这两个文件后辍都改为 ets 了。

ImportingArkTSfilestoJSandTSfilesisnotallowed.

服务卡片如何接收更新数据,卡片页面如何接收,后台如何更新。

卡片页面如何接收,比如步数参数如何定义:

letstorage=newLocalStorage();

@Entry(storage)
@Component
structWidgetCard{
@LocalStorageProp('steps')steps:number=0;

后台如何更新:

//创建卡片
letformData:FormData=newFormData();
formData.percent=0;
formData.steps=0;
returnFormBindingData.createFormBindingData(formData);
//更新卡片
FormProvider.updateForm(formData.formId,FormBindingData.createFormBindingData(formData))

2x2 卡片界面部分代码:

Stack(){
Image($r("app.media.icon_2x2_card_background"))
.width(this.FULL_WIDTH_PERCENT)
.height(this.FULL_HEIGHT_PERCENT)
.objectFit(ImageFit.Cover)

Progress({value:this.percent,total:100,type:ProgressType.Ring}).width(100).height(100)
.color(Color.White)//进度条前景色为灰色
.style({strokeWidth:12})//设置strokeWidth进度条宽度为12vp
Column(){
Text('步数')
.fontSize(10)
.fontColor($r('app.color.text_font_color'))
Text(this.steps.toString())
.fontSize(26)
.fontColor($r('app.color.text_font_color'))
Text('步')
.fontSize(10)
.fontColor($r('app.color.text_font_color'))
}
.width(this.FULL_WIDTH_PERCENT)
.height(this.FULL_HEIGHT_PERCENT)
.alignItems(HorizontalAlign.Center)
.justifyContent(FlexAlign.Center)
.padding($r('app.float.column_padding'))
}
.width(this.FULL_WIDTH_PERCENT)
.height(this.FULL_HEIGHT_PERCENT)
.onClick(()=>{
postCardAction(this,{
"action":"router",
"abilityName":"EntryAbility",
"params":{
"message":"adddetail"
}
});
})

2x4 卡片界面部分代码:

Stack(){
Image($r("app.media.icon_2x4_card_background"))
.width(this.FULL_WIDTH_PERCENT)
.height(this.FULL_HEIGHT_PERCENT)
.objectFit(ImageFit.Cover)
Row(){
Column(){
Text(`今天走了${this.mileage}米`)
.fontSize(16)
.fontWeight(400)
.opacity(0.9)
.fontColor($r('app.color.text_font_color'))
Row(){
Text(this.steps.toString())
.fontSize(40)
.fontWeight(700)
.fontColor($r('app.color.text_font_color'))
Text('步')
.fontSize(16)
.fontWeight(400)
.opacity(0.9)
.fontColor($r('app.color.text_font_color'))
.margin({left:5,bottom:-10})
}
.margin({top:10,bottom:10})
Text(`${this.percent}%`)
.fontSize(16)
.fontWeight(400)
.fontColor($r('app.color.text_font_color'))
Progress({value:this.percent,total:100,type:ProgressType.Linear})
.color('#FFFFFF')
.backgroundColor('#40FFFFFF')
.style({strokeWidth:6})
.margin({top:4})
}
.width('50%')
.height(this.FULL_HEIGHT_PERCENT)
.alignItems(HorizontalAlign.Start)
.justifyContent(FlexAlign.Center)
.padding($r('app.float.column_padding'))
Column(){
Polyline()
.width('100%').height('100%')
.points(this.setPolyLine(this.datasets))
.strokeDashOffset(-50)
.fillOpacity(0)
.strokeOpacity(0.5)
.stroke(Color.White)
.strokeWidth(3)
//设置折线拐角处为圆弧
.strokeLineJoin(LineJoinStyle.Round)
//设置折线两端为半圆
.strokeLineCap(LineCapStyle.Round)
}
.width('50%')
}

}
.width(this.FULL_WIDTH_PERCENT)
.height(this.FULL_HEIGHT_PERCENT)

总结

通过学习 Cabelabs 案例,我们可以快速学到实践知识,通过查看文档指南,我们可以了解到更细的知识点。

当我们脑子里有了一个应用的模型,所以通过 Codelabs 相似案例知识点,加上查看文档指南、API 参考,平常多看和参加学堂视频课程,有了一定的知识量,做项目或回答一些问题,就是这么简单了。

审核编辑:汤梓红

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

    关注

    7

    文章

    3750

    浏览量

    64207
  • 模型
    +关注

    关注

    1

    文章

    3097

    浏览量

    48624
  • SQlite
    +关注

    关注

    0

    文章

    78

    浏览量

    15882
  • HarmonyOS
    +关注

    关注

    79

    文章

    1964

    浏览量

    29942

原文标题:HarmonyOS 3.1上实现“计步卡片”

文章出处:【微信号:gh_834c4b3d87fe,微信公众号:OpenHarmony技术社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    HarmonyOS服务卡片跑AIGC

    我们认为基于 AIGC 能力类型的 HarmonyOS 元服务万能卡片应该通过 API 方式调用合规训练后的各具特色的模型与角色来服务用户,通过万能卡片、智能语音、手势动作等更加自然友好的方式来和用户交互。
    的头像 发表于 04-25 09:40 2215次阅读
    <b class='flag-5'>HarmonyOS</b>服务<b class='flag-5'>卡片</b>跑AIGC

    OpenHarmony开发案例:【计步器卡片

    基于Stage模型实现带有卡片应用,用于介绍卡片的开发及生命周期实现
    的头像 发表于 04-15 09:22 657次阅读
    OpenHarmony开发案例:【计步器<b class='flag-5'>卡片</b>】

    HarmonyOS服务卡片快速开发

    HarmonyOS服务卡片快速开发
    发表于 06-19 13:52

    一文看懂HarmonyOS服务卡片运行原理和开发方法

    :1. 配置config.json2. 实现生命周期回调方法3. 开发卡片界面元素4. 实现卡片界面交互1.配置config.jsonc
    发表于 07-27 17:21

    HarmonyOS服务卡片动手实验室资料

    本实验通过在电脑采用 DevEco Studio 搭建 HarmonyOS 服务卡片开发工程,并以三个应用场景实践作为演练,辅助理解掌握 HarmonyOS 服务
    发表于 07-31 19:23

    基于HarmonyOS Java UI 实现简易的时钟卡片应用

    1. 介绍服务卡片是FA的一种界面展示形式,将FA重要信息或操作前置到卡片,以此达到服务直达、减少层级体验的目的。本篇Codelab主要介绍如何在HarmonyOS开发一个时钟类FA
    发表于 08-18 10:47

    HarmonyOS卡片开发--服务卡片概述

    服务。 卡片提供方实例管理模块:由卡片提供方开发者实现,负责对卡片管理服务分配的卡片实例进行持久化管理。 通信适配层:由
    发表于 09-22 14:10

    HarmonyOS之服务卡片(Java)开发步骤

    ”是绑定组件的resultcode,当需要设置卡片多个组件的点击事件时,设置不同的resultcode即可。IntentAgentInfo paramsInfo = new
    发表于 07-26 16:17

    华为开发者HarmonyOS零基础入门:15分钟玩转harmonyOS服务卡片

    华为开发者HarmonyOS零基础入门:15分钟玩转harmonyOS服务卡片,服务卡片颜值高、拥有服务直达功能。
    的头像 发表于 10-23 11:40 2183次阅读
    华为开发者<b class='flag-5'>HarmonyOS</b>零基础入门:15分钟玩转<b class='flag-5'>harmonyOS</b>服务<b class='flag-5'>卡片</b>

    零基础入门HarmonyOS-部分卡片模板效果展示

    零基础入门HarmonyOS-部分卡片模板效果展示
    的头像 发表于 10-23 11:51 1144次阅读
    零基础入门<b class='flag-5'>HarmonyOS</b>-部分<b class='flag-5'>卡片</b>模板效果展示

    零基础入门HarmonyOS-卡片内容布局描述

    零基础入门HarmonyOS-卡片内容布局描述
    的头像 发表于 10-23 11:56 1649次阅读
    零基础入门<b class='flag-5'>HarmonyOS</b>-<b class='flag-5'>卡片</b>内容布局描述

    零基础入门HarmonyOS-绑定卡片数据展示

    零基础入门HarmonyOS-绑定卡片数据展示
    的头像 发表于 10-23 11:59 1281次阅读
    零基础入门<b class='flag-5'>HarmonyOS</b>-绑定<b class='flag-5'>卡片</b>数据展示

    零基础入门HarmonyOS-响应卡片交互事件

    2021 HDC2021华为开发者分论坛零基础入门HarmonyOS-响应卡片交互事件
    的头像 发表于 10-23 13:03 1319次阅读
    零基础入门<b class='flag-5'>HarmonyOS</b>-响应<b class='flag-5'>卡片</b>交互事件

    HarmonyOS服务卡片如何换肤

      关注HarmonyOS的小伙伴肯定对服务卡片已经很熟悉了。服务卡片(也简称为“卡片”)是FA(FeatureAbility,元服务)的一种界面展示形式,将FA的重要信息或操作前置到
    的头像 发表于 02-12 10:28 2763次阅读
    <b class='flag-5'>HarmonyOS</b>服务<b class='flag-5'>卡片</b>如何换肤

    用Java开发HarmonyOS服务卡片

    卡片服务:由卡片提供方开发者实现,开发者实现 onCreateForm、onUpdateForm 和 onDeleteForm 处理创建卡片
    的头像 发表于 04-26 11:04 1449次阅读