鸿蒙原生开发手记:02-服务卡片开发

本文涉及的产品
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
性能测试 PTS,5000VUM额度
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 服务卡片是桌面小组件,分为静态和动态两类。本文介绍如何在 DevEco 中创建静态服务卡片,并实现点击事件传参和参数接收。创建时需选择支持的卡片大小,使用 FormLink 实现跳转,参数在 `entryability` 的生命周期方法中接收。注意:服务卡片不支持热重载。

介绍

服务卡片是一直桌面小组件,可以放置在桌面上等位置,一触即达。

服务卡片分为静态卡片和动态卡片两类。本文介绍静态卡片。

创建

回到 DevEco,在目录entry右键,点击创建 Service Widget,选择 Static Widget, 点击 Next。

image.png

输入名称,选择支持的卡片大小,点击确定创建卡片。

其中 22 代表 2行2列,12 代表1行2列。

image.png

编写卡片界面

交互

点击事件传参

这里使用 ArkUI 编写界面,不过不能使用点击事件,转而应该使用 FormLink,相关的事件在 formability 侧接受,通过不同的参数,调用 router.push 打开不同的页面。

FormLink({
  action: this.ACTION_TYPE,
  abilityName: this.ABILITY_NAME,
  params: {
    action: this.MESSAGE
  }
}) {
...
}

参数接收

entryability 中的 onCreateonNewWant 生命周期中,来接收参数

  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
   

    if(want?.parameters?.params) {
   
      let params: Record<string, Object> = JSON.parse(want.parameters.params as string);
      this.selectPage = params.action as string;
      console.log("selectPage", this.selectPage);
    }
  }

  onNewWant(want: Want, launchParam: AbilityConstant.LaunchParam): void {
   
    console.log('onNewWant');
    if (want?.parameters?.params) {
   
      // want.parameters.params 对应 postCardAction() 中 params 内容
      let params: Record<string, Object> = JSON.parse(want.parameters.params as string);
      this.selectPage = params.action as string;
      hilog.info(DOMAIN_NUMBER, TAG, `onNewWant selectPage: ${
     this.selectPage}`);
    }
    if (this.currentWindowStage !== null) {
   
      this.onWindowStageCreate(this.currentWindowStage);
    }
  }

注意事项

1.运行时,请使用正常模式,服务卡片不支持 HotReload ,而且热重载模式下卡片无法正常显示。

参考资料

  • [服务卡片文档]
目录
相关文章
|
2天前
|
前端开发 JavaScript 开发工具
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
31 5
【04】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-正确安装鸿蒙SDK-结构目录介绍-路由介绍-帧动画(ohos.animator)书写介绍-能够正常使用依赖库等-ArkUI基础组件介绍-全过程实战项目分享-从零开发到上线-优雅草卓伊凡
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI六
本文介绍了颜色渐变(线性渐变和径向渐变)与阴影效果的应用,通过具体代码示例展示了如何在组件中实现这些视觉效果,帮助开发者提升界面美观度。君志所向,一往无前,欢迎一起探索! 简介字数:239
HarmonyOS NEXT开发-ArkUI六
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI八
本文介绍了Harmony OS开发中的线性布局技巧,包括交叉轴对齐、自适应缩放及综合实践案例,帮助开发者轻松掌握相关技能。每天学习一个知识点,一起加油!
10 0
HarmonyOS NEXT开发-ArkUI八
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI十二
网格布局(Grid)适用于由多行列组成的复杂界面,支持固定行列、合并单元格及滚动效果。其应用场景广泛,如文件管理、购物列表等。通过设置`columnsTemplate`和`rowsTemplate`可定义行列比例,使用`GridItem`组件实现内容展示。此外,还能通过自定义滚动条优化用户体验。代码示例展示了如何创建固定行列、合并单元格以及实现滚动效果的网格布局。 关注程序员Feri,了解更多实用技术与搞钱技巧,一起在编程道路上不断前行!
12 0
HarmonyOS NEXT开发-ArkUI十二
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI十一
本文介绍Swiper组件,它用于滑动轮播显示,支持自动播放、纵向滑动、自定义导航点等特性。通过设置尺寸、内容及属性,可实现丰富的轮播效果。示例代码展示了基本用法和综合实践,帮助开发者快速上手。
17 0
HarmonyOS NEXT开发-ArkUI十一
|
2天前
|
人工智能 前端开发 Java
HarmonyOS NEXT开发-ArkUI十
本文介绍了布局实践、定位(绝对与相对)、通用属性(多态样式和动画)及图形变换(平移、缩放、旋转),帮助开发者掌握前端布局技巧和交互效果优化。君志所向,一往无前!
17 0
HarmonyOS NEXT开发-ArkUI十
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI九
本文介绍了弹性布局(Flex)、商品列表展示及层叠布局(StackLayout)的基本概念与实际应用,通过代码示例详细讲解了这些布局方式的使用方法和效果。希望在搞钱的路上有你相伴!君志所向,一往无前!
HarmonyOS NEXT开发-ArkUI九
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI七
本文介绍了ArkUI中的布局概念,包括组件区域、内容区和布局边界,并详细讲解了线性布局(Row/Column)的使用方法,如间距设置和对齐方式。通过实例代码展示了如何创建美观且功能丰富的页面布局。关注Feri,一起探索HarmonyOS开发!
HarmonyOS NEXT开发-ArkUI七
|
2天前
|
人工智能 Java 程序员
HarmonyOS NEXT开发-ArkUI五
本文介绍了边框属性、圆角设置、综合使用案例和背景属性(包括背景色、背景图及缩放)的详细代码示例,帮助开发者快速掌握ArkUI框架,持续更新HarmonyOS开发技巧。君志所向,一往无前!
10 0
HarmonyOS NEXT开发-ArkUI五
|
2天前
|
存储 人工智能 Java
HarmonyOS NEXT开发-ArkUI四
本文介绍了HarmonyOS图标库的使用方法,涵盖下载、命名规范及Image组件的应用,并详细讲解了布局属性如padding和margin的设置技巧,助你在开发路上更进一步。君志所向,一往无前!
HarmonyOS NEXT开发-ArkUI四