【HarmonyOS】六脉神剑 | 元服务绝技之卡片刷新

2024-01-14 14:40

本文主要是介绍【HarmonyOS】六脉神剑 | 元服务绝技之卡片刷新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【关键字】

元服务卡片(简称卡片)、刷新

【背景介绍】

本文主要介绍元服务卡片(简称卡片)中Java卡片的刷新相关知识,首先我们需要对卡片中的角色有基本的了解,如下:

1、卡片提供方

提供卡片显示内容的HarmonyOS应用或原子化服务,控制卡片的显示内容、控件布局以及控件点击事件。

2、卡片使用方

显示卡片内容的宿主应用,控制卡片在宿主中展示的位置,最常见的使用方如:桌面服务中心

3、卡片管理服务

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

下文将主要介绍卡片的两种刷新模式:

1、主动刷新 2、周期性刷新。

【主动刷新】

主动刷新就是应用(卡片提供方)通过updateForm接口去刷新卡片,可以使用的场景也很多,例如在卡片上添加刷新按钮,通过事件触发刷新卡片。系统对主动刷新也没有限制,只要在卡片可见(HarmonyOS 3.0系统限制)的时候,都可以通过这种方式进行刷新操作。

【周期性刷新】

周期性刷新主要有三种方式。

1、  定点刷新,即在每天的某个时间点刷新

定点刷新的周期是每天一次,需要在config.json中配置scheduledUpdateTime,每天都会在固定的时间点进行刷新。

2、  定时刷新,即间隔固定的时间后刷新服务卡片

定时刷新通过config.json中配置updateDuration设置固定的时间间隔,间隔最低是30分钟一次,所以每天最多能刷新的次数在50次以下。

3、  动态定时刷新,可以让卡片提供方来设置下次相对的定时刷新时间。动态定时刷新的最小时间间隔是5分钟,每天最多刷新也是50次。动态定时刷新使用可以参考以下论坛帖:

【HarmonyOS】基于JS UI的Java服务卡片如何实现动态定时刷新-华为开发者论坛 | 华为开发者联盟 (huawei.com)

周期性刷新流程如下图:

cke_1026.png

卡片周期性刷新是由卡片管理服务控制的,所以在使用过程中要注意以下一些情况:

1、卡片是否可见: 当前卡片当前状态不可见的时候,不允许刷新(HarmonyOS 3.0系统限制)。如果满足了刷新时间,卡片不可见,那么卡片会在下次卡片可见的时候刷新

2、刷新次数是否大于等于50:满足了定时器的时间,默认为30分钟刷新一次,当刷新次数大于等于50时,将不会进行周期刷新

3、周期性刷新IPC过程中,提供方是否存活:周期性刷新前卡片提供方是否存活都不会影响卡片周期性刷新,因为卡片周期性刷新是由卡片管理服务控制的,在需要刷新时如果卡片提供方不活动,卡片管理服务将会拉起提供方。

提供方存活或者拉起提供方后,卡片管理服务会与提供方进行IPC通信,收到IPC消息后,提供方会在onUpdateForm()回调中使用updateForm实现周期性刷新。

如果在这个IPC通信过程中提供方被杀死,就卡片的使用方无法完成刷新。

4、卡片是否被省电精灵管控:当应用允许后台活动开关关闭时,省电精灵会根据应用类型,改变卡片的刷新周期。其中工具类型的卡片最多半小时刷新一次,邮件、闹钟等应用最多2小时刷新一次,其他应用最多一天刷新一次。此外省电精灵会检测功耗大的卡片,将卡片的刷新周期强制改成24小时一次。

        

【其他刷新方式】

1、监听广播刷新(仅限Harmony 2.0系统,无法在3.0上使用)

例如可以通过监听亮屏广播(FA卡片可以接收鸿蒙侧的广播,无法接收安卓侧的广播),在广播的接收后,主动调用updateform接口进行卡片刷新。但这种方式会引起功耗等相关问题,会被系统管控,方法仅供参考。

2、通过前台Service实现实时刷新

因为后台服务会被系统回收,所以想要实现长时间实时刷新需要绑定前台Service,然后再Service中通过updateForm进行服务卡片刷新。(参考示例: Codelabs: 分享知识与见解,一起探索HarmonyOS的独特魅力。 - Gitee.com)

但是这种刷新方式功耗很大被系统管控,目前暂无办法保证卡片服务不被系统销毁,不过可以通过以下方式去改善被销毁的情况:

  • 进入手机管家 > 应用启动管理 >“您的应用”> 关闭自动管理按钮,关闭后会弹框显示手动管理界面,将手动管理三项管理允许自启动、允许关联启动、允许后台活动都选择开启;
  • 进入手机设置,在顶部搜索框搜索电池优化,左上角下拉选择所有应用,找到“您的应用”,设置为不允许;

需要说明的是这些操作都需要用户手动点击完成,并且通过这种方法只能改善被系统销毁的情况。如果因为功耗等相关问题被系统管控,服务还是会被杀死。

元服务的卡片刷新不难实现,总结来说有六种方式,可归纳为刷新绝技的六脉神剑

少商剑:主动刷新

商阳剑:周期性刷新-定点刷新

中冲剑:周期性刷新-定时刷新

关冲剑:周期性刷新-动态定时刷新

少冲剑:监听广播刷新

少泽剑:前台Service实时刷新

大侠绝技练成,即可闯荡江湖。

【参考】

一文看懂HarmonyOS服务卡片运行原理和开发方法-华为开发者论坛 | 华为开发者联盟 (huawei.com)

时钟卡片(Java) (huawei.com)

 欲了解更多更全技术文章,欢迎访问https://developer.huawei.com/consumer/cn/forum/?ha_source=zzh

这篇关于【HarmonyOS】六脉神剑 | 元服务绝技之卡片刷新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/605521

相关文章

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

基于SpringBoot的宠物服务系统+uniapp小程序+LW参考示例

系列文章目录 1.基于SSM的洗衣房管理系统+原生微信小程序+LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统+LW参考示例 3.基于SpringBoot+Vue的企业人事管理系统+LW参考示例 4.基于SSM的高校实验室管理系统+LW参考示例 5.基于SpringBoot的二手数码回收系统+原生微信小程序+LW参考示例 6.基于SSM的民宿预订管理系统+LW参考示例 7.基于

Golang支持平滑升级的HTTP服务

前段时间用Golang在做一个HTTP的接口,因编译型语言的特性,修改了代码需要重新编译可执行文件,关闭正在运行的老程序,并启动新程序。对于访问量较大的面向用户的产品,关闭、重启的过程中势必会出现无法访问的情况,从而影响用户体验。 使用Golang的系统包开发HTTP服务,是无法支持平滑升级(优雅重启)的,本文将探讨如何解决该问题。 一、平滑升级(优雅重启)的一般思路 一般情况下,要实现平滑

Golang服务平滑重启

与重载配置相同的是我们也需要通过信号来通知server重启,但关键在于平滑重启,如果只是简单的重启,只需要kill掉,然后再拉起即可。平滑重启意味着server升级的时候可以不用停止业务。 我们先来看下Github上有没有相应的库解决这个问题,然后找到了如下三个库: facebookgo/grace - Graceful restart & zero downtime deploy for G

Java后端微服务架构下的API限流策略:Guava RateLimiter

Java后端微服务架构下的API限流策略:Guava RateLimiter 大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿! 在微服务架构中,API限流是保护服务不受过度使用和拒绝服务攻击的重要手段。Guava RateLimiter是Google开源的Java库中的一个组件,提供了简单易用的限流功能。 API限流概述 API限流通过控制请求的速率来防止

【微服务】Ribbon(负载均衡,服务调用)+ OpenFeign(服务发现,远程调用)【详解】

文章目录 1.Ribbon(负载均衡,服务调用)1.1问题引出1.2 Ribbon负载均衡1.3 RestTemplate整合Ribbon1.4 指定Ribbon负载均衡策略1.4.1 配置文件1.4.2 配置类1.4.3 定义Ribbon客户端配置1.4.4 自定义负载均衡策略 2.OpenFeign面向接口的服务调用(服务发现,远程调用)2.1 OpenFeign的使用2.1 .1创建