| Name | Date | Size | #Lines | LOC | ||
|---|---|---|---|---|---|---|
| .. | - | - | ||||
| AppScope/ | 06-May-2025 | - | 36 | 33 | ||
| entry/ | 06-May-2025 | - | 858 | 710 | ||
| hvigor/ | 06-May-2025 | - | 8 | 8 | ||
| screenshots/device/ | 06-May-2025 | - | ||||
| .gitignore | D | 06-May-2025 | 56 | 5 | 5 | |
| README_zh.md | D | 06-May-2025 | 4.7 KiB | 86 | 56 | |
| build-profile.json5 | D | 06-May-2025 | 1.1 KiB | 43 | 42 | |
| hvigorfile.js | D | 06-May-2025 | 168 | 2 | 1 | |
| hvigorw | D | 06-May-2025 | 1.4 KiB | 49 | 28 | |
| hvigorw.bat | D | 06-May-2025 | 2.1 KiB | 80 | 60 | |
| oh-package.json5 | D | 06-May-2025 | 210 | 12 | 11 | |
| ohosTest.md | D | 06-May-2025 | 533 | 8 | 6 |
README_zh.md
1# 窗口 2 3### 介绍 4 5本示例主要展示了在子窗口中以悬浮窗模式拉起悬浮应用,并对新的应用设置窗口缩放比例,窗口以设置的比例进行缩放,并在界面显示窗口当前的宽度和高度。 6 7本实例使用[@ohos.window](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/apis-arkui/js-apis-window.md) 8 9### 效果预览 10 11本示例拉起悬浮应用并设置窗口比例,按照设置的窗口比例缩放窗口并监听窗口大小。效果图如下: 12 13| 拉起悬浮应用 | 设置窗口比例 | 监听窗口大小 | 14| ---------------------------------------- | ------------------------------------------ | ----------------------------------------- | 15|  |  |  | 16 17使用说明 18 191.安装[WindowRatio](/code/SystemFeature/WindowManagement/WindowRatio)工程hap包(即本示例)和[WindowManage](/code/SystemFeature/WindowManagement/WindowManage)工程hap包 20 212.打开WindowManage应用sample,点击**窗口预览**进入视频播放页面,点击主窗口后拉起子窗口。 22 232.点击**拉起悬浮应用**按钮后,将以悬浮窗模式拉起应用WindowRatio 。 24 253.点击悬浮应用中的下拉框,选择窗口缩放比例,点击**确定**按钮,以新的宽度/比例计算得到窗口宽高,监听到窗口缩放比例发生变化,窗口以设置的比例改变大小,窗口监听到大小发生变化,在页面上显示当前窗口的宽度和高度。另外,窗口不具备记忆之前位置大小的能力,当前sample所调用的接口展示结果不居中,若要使得窗口居中,则需调用resize接口指定成想要的大小。 26 27### 工程目录 28 29``` 30entry/src/main/ets/ 31|---Application 32|---MainAbility 33| |---MainAbility.ts // 设置窗口模式,监听窗口大小等窗口管理的文件 34|---pages 35| |---index.ets // 首页,设置 36``` 37 38### 具体实现 39 40- 设置窗口缩放比例的功能接口封装在Index,源码参考:[Index](entry/src/main/ets/pages/index.ets) 41 - 使用windows.setAspectRatio来设置窗口缩放比例; 42- 设置以悬浮窗模式显示窗口和设置监听窗口大小接口的功能封装在MainAbility,源码参考:[MainAbility](entry/src/main/ets/MainAbility/MainAbility.ts) 43 - 使用windows.setWindowMode来设置窗口为悬浮窗模式; 44 - 使用windows.on('windowSizeChange', (data))来监听窗口大小信息; 45 46### 相关权限 47 48本示例需要在module.json5中配置如下权限: 49 50允许应用使用悬浮窗的能力:[ohos.permission.SYSTEM_FLOAT_WINDOW](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/security/AccessToken/permissions-for-system-apps.md#ohospermissionsystem_float_window) 51 52此外,因为本示例使用了系统能力的接口,还需在SDK/10/toolchains/lib目录下的UnsgnedReleasedProfileTemplate.json中修改以下配置权限: 53 54``` 55"bundle-info":{ 56 ... 57 "apl":"system_core", 58 "app-feature":"ohos_system_app" 59} 60``` 61 62### 依赖 63 64本示例需要依赖[WindowManage](/code/SystemFeature/WindowManagement/WindowManage) sample,[WindowManage](/code/SystemFeature/WindowManagement/WindowManage) sample会在子窗口中拉起本应用,然后在本应用中设置窗口缩放比例并监听本应用的窗口大小。 65 66### 约束与限制 67 681.本示例仅支持在标准系统上运行,仅支持设备:RK3568。 69 702.本示例为Stage模型,仅支持API10版本SDK,SDK版本号(API Version 10 Release),镜像版本号(4.0Release);本示例涉及使用系统接口:@ohos.window中的WindowMode属性,需要手动替换Full SDK才能编译通过,具体操作可参考[替换指南](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/faqs/full-sdk-switch-guide.md)。 71 723.本示例所配置的权限ohos.permission.SYSTEM_FLOAT_WINDOW为system_basic级别(相关权限级别可通过[权限定义列表](https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/security/AccessToken/permissions-for-system-apps.md)查看),需要手动配置对应级别的权限签名(具体操作可查看[自动化签名方案](https://docs.openharmony.cn/pages/v4.0/zh-cn/application-dev/security/hapsigntool-overview.md))。 73 744.本示例需要使用DevEco Studio 版本号(4.0Release)及以上版本才可编译运行。 75 76### 下载 77 78如需单独下载本工程,执行如下命令: 79``` 80git init 81git config core.sparsecheckout true 82echo code/SystemFeature/WindowManagement/WindowRatio/ > .git/info/sparse-checkout 83git remote add origin https://gitee.com/openharmony/applications_app_samples.git 84git pull origin master 85 86```