1# 卡片使用方 2 3## 介绍 4 5本示例展示了一个卡片使用方应用,实现了以下几点功能: 6 71.查询所有卡片信息,并选择显示某一张卡片。 8 92.监听所有应用安装、卸载、升级事件,监听的回调为重新获取所有卡片信息。 10 113.提供了卡片的更新、删除等功能。 12 13## 相关概念 14 15卡片使用方:显示卡片内容的宿主应用,控制卡片在宿主中展示的位置,当前仅系统应用可以作为卡片使用方。 16 17卡片管理服务:用于管理系统中所添加卡片的常驻代理服务,提供formProvider和formHost的接口能力,同时提供卡片对象的管理与使用以及卡片周期性刷新等能力。 18 19## 效果预览 20 21| 卡片使用方 | 选择添加卡片 | formHost接口 | 更新展示 | 22|--------|--------------|---------------|-----| 23| |  |  |  | 24 25## 使用说明 26 271. 点击查询卡片按钮,将查询所有卡片信息显示到选择添加卡片列表中;点击选择添加卡片,会弹出可选卡片列表;在选择框选择一张卡片点击确定,将卡片添加到界面上。 28 292. 添加卡片后,在卡片下方的选择列表可以对当前卡片进行操作。 30 删除卡片:删除当前卡片。 31 更新卡片:请求卡片更新。 32 卡片可见:向卡片框架发送通知以使指定的卡片可见。 33 卡片不可见:向卡片框架发送通知以使指定的卡片不可见。 34 不可更新:向卡片框架发送通知以使当前的卡片不可以更新。 35 可以更新:向卡片框架发送通知以使当前的卡片可以更新。 36 37> **注意事项:** 38> 39> 1. 卡片的可见和不可见选项,并不是界面上的可见与否,而是卡片使用方设定的属性,在本示例中可以通过formObserver.on接口的回调日志中来确定是否改变了可见属性。 40> 2. 添加下一张卡片时,需要删除当前卡片才可添加成功。 41 42## 工程目录 43 44``` 45entry/src/main/ets/ 46├── entryability 47│ └── EntryAbility.ets 48└── pages 49 └── Index.ets //卡片使用方页面 50 51``` 52 53## 具体实现 54 55* 卡片组件 56 * 使用卡片组件FormComponent (系统能力:SystemCapability.ArkUI.ArkUI.Full),展示卡片提供方提供的卡片内容。 57 * 源码参考:[Index.ets](./entry/src/main/ets/pages/Index.ets) 58 * 参考:[FromComponent组件](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-arkui/arkui-ts/ts-basic-components-formcomponent-sys.md) 59 60* formHost接口 61 * 使用formHost接口(系统能力:SystemCapability.Ability.Form),对使用方同一用户下安装的卡片进行删除、更新、获取卡片信息、状态等操作。 62 * 源码参考:[Index.ets](./entry/src/main/ets/pages/Index.ets) 63 * 接口参考:[@ohos.app.form.formHost](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-form-kit/js-apis-app-form-formHost-sys.md) 64 65* 应用事件监听 66 * 使用bundle模块的bundleMonitor.on监听到应用的安装,卸载,更新(系统能力:SystemCapability.BundleManager.BundleFramework.Core),应用的安装、卸载、更新时重新获取全部卡片信息。 67 * 源码参考:[Index.ets](./entry/src/main/ets/pages/Index.ets) 68 * 接口参考:[@ohos.bundle.bundleMonitor](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-ability-kit/js-apis-bundleMonitor-sys.md) 69 70## 依赖 71 72卡片提供方 [FormProvider](../FormProvider/) 73 74## 相关权限 75 76| 权限名 | 权限说明 | 级别 | 77| ------------------------------------------ | ------------------------------------------------ | ------------ | 78| [ohos.permission.GET_BUNDLE_INFO_PRIVILEGED](https://docs.openharmony.cn/pages/v4.0/zh-cn/application-dev/security/permission-list.md#ohospermissiongetbundleinfoprivileged) | 允许应用查询其他应用的信息。 | system_basic | 79| [ohos.permission.LISTEN_BUNDLE_CHANGE](https://docs.openharmony.cn/pages/v4.0/zh-cn/application-dev/security/permission-list.md#ohospermissionlistenbundlechange) | 允许应用监听其他应用安装、更新、卸载状态的变化。 | system_basic | 80| [ohos.permission.REQUIRE_FORM](https://docs.openharmony.cn/pages/v4.0/zh-cn/application-dev/security/permission-list.md#ohospermissionrequireform) | 允许应用获取Ability Form。 | system_basic | 81| [ohos.permission.OBSERVE_FORM_RUNNING](https://docs.openharmony.cn/pages/v4.0/zh-cn/application-dev/security/permission-list.md#ohospermissionobserveformrunning) | 允许应用监听卡片运行状态 | system_basic | 82 83## 约束与限制 84 851. 本示例支持标准系统上运行,支持设备:RK3568; 862. 本示例支持API14版本SDK,版本号:5.0.2.57; 873. 本示例已支持使DevEco Studio 5.0.1 Release (构建版本:5.0.5.306,构建 2024年12月12日)编译运行; 884. 本示例需要使用系统权限的系统接口,需要使用Full SDK编译。使用Full SDK时需要手动从镜像站点获取,并在DevEco Studio中替换,具体操作可参考[替换指南](https://docs.openharmony.cn/pages/v4.1/zh-cn/application-dev/faqs/full-sdk-switch-guide.md); 895. 本示例所配置的权限为system_basic或system_core级别(权限级别请参考[权限定义列表](https://gitee.com/openharmony/docs/blob/OpenHarmony-5.0.1-Release/zh-cn/application-dev/security/AccessToken/permissions-for-system-apps.md)),需要配置对应级别的权限签名(可查看[自动化签名方案](https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ohos-auto-configuring-signature-information-0000001271659465)); 906. 本示例类型为系统应用,需要手动配置对应级别的应用类型("app-feature": "hos_system_app")。具体可参考profile配置文件[bundle-info对象内部结构]( https://gitee.com/openharmony/docs/blob/eb73c9e9dcdd421131f33bb8ed6ddc030881d06f/zh-cn/application-dev/security/app-provision-structure.md#bundle-info%E5%AF%B9%E8%B1%A1%E5%86%85%E9%83%A8%E7%BB%93%E6%9E%84 ); 91 92## 下载 93 94如需单独下载本工程,执行如下命令: 95 96```git 97git init 98git config core.sparsecheckout true 99echo code/DocsSample/Form/FormHost/ > .git/info/sparse-checkout 100git remote add origin https://gitee.com/openharmony/applications_app_samples.git 101git pull origin master 102``` 103