145 Star 1.4K Fork 1.6K

OpenHarmony/applications_app_samples

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

数据代理卡片(数据库刷新)

介绍

本示例主要展示了数据代理卡片的功能,使用@ohos.application.DataShareExtensionAbility@ohos.data.dataShare@ohos.data.dataSharePredicates等接口,实现了修改卡片订阅信息后,当rdb数据库中的数据发生变化时,卡片中对应信息也发生相应变化的功能。

效果预览

应用主界面 修改订阅条件 发布数据 卡片样式
mainInterface modifySubscriptionConditions dataRelease cardStyle

使用说明

1.长按应用图标弹出菜单,点击"服务卡片"选项可以添加服务卡片至桌面;

2.长按数据卡片弹出菜单,点击"移除"可以将已添加至桌面的数据卡片从桌面上移除;

3.点击"修改订阅条件"按键,界面将跳转至修改订阅条件界面,对应选择想要发布的数据完成对订阅条件的修改;

4.在应用中点击"发布数据"按键,界面将跳转至数据发布界面,对应选择想要发布的数据并点击"发布数据"完成数据发布;

工程目录

entry/src/main/
|---common
|  └---Logger.ts
|---ets
|  └---dataShare
|  | └---DataShare.ts
|  |---entryability
|  |  └---EntryAbility.ts
|  |---entryformability
|  |  └---EntryFormAbility.ts
|  |---pages
|  |  |---Index.ets                          // EntryAbility页面
|  |  |---ModifyConditionIndex.ets           // 修改订阅条件页面
|  |  └---PublishIndex.ets                   // 发布数据页面
|  └---widget
|     └---pages
|        └---WidgetCard.ets                  // ArkTS卡片
|---js
|  |---common
|  |---i18n
|  └---widgetJS
|     └---pages
|        └---index
|           |---index.css                       // JS卡片样式
|           |---index.hml                       // JS卡片
|           └---index.json                      // JS卡片默认值
|---resources                                   // 资源信息

具体实现

  • 修改数据卡片的订阅条件的功能封装在ModifyConditionIndex.ets中,源码参考:ModifyConditionIndex.ets
    • 使用modifyCondition来获取所有已经建立出的卡片对象。
    • 修改订阅条件:使用updateCardDisplayContent遍历所有卡片对象,并根据界面获取的订阅条件数据修改订阅条件。
  • 发布数据的功能封装在PublishIndex.ets中,源码参考:PublishIndex.ets
    • 使用updateRDB来修改rdb数据库中的对应数据。
  • 在dataShare模块中,建立rdb数据库,并提供对应update方法。
    • 在onCreate中初始化数据库中的数据。
    • 在update中实现对应的数据更新方法。

相关权限

ohos.permission.START_ABILITIES_FROM_BACKGROUND

ohos.permission.START_INVISIBLE_ABILITY

ohos.permission.GET_BUNDLE_INFO_PRIVILEGED

ohos.permission.GET_BUNDLE_INFO

ohos.permission.REQUIRE_FORM

依赖

本测试demo需要安装在仿桌面应用上进行测试。launcher应用地址:Launcher

约束与限制

1.本示例仅支持标准系统上运行,支持设备:RK3568。

2.本示例已适配API version 10版本SDK,版本号:4.0.8.5,镜像版本号:OpenHarmony_4.0.8.5。

3.本示例需要使用DevEco Studio 3.1 Beta2 (Build Version: 3.1.0.400 构建 2023年4月7日)才可编译运行。

4.本示需要使用Full SDK编译。使用Full SDK时需要手动从镜像站点获取,并在DevEco Studio中替换,具体操作可参考替换指南

5.本示例所配置的权限为system_core级别(相关权限级别可通过权限定义列表查看),需要手动配置对应级别的权限签名(具体操作可查看自动化签名方案)。

6.本示例中使用到DataShareExtensionAbility,需要将本实例加入到白名单中再进行安装。

下载

如需单独下载本工程,执行如下命令:

git init
git config core.sparsecheckout true
echo code/SystemFeature/ApplicationModels/PersistentProxyForm > .git/info/sparse-checkout
git remote add origin https://gitee.com/openharmony/applications_app_samples.git
git pull origin master
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/openharmony/applications_app_samples.git
git@gitee.com:openharmony/applications_app_samples.git
openharmony
applications_app_samples
applications_app_samples
OpenHarmony-4.0-Beta2

搜索帮助