• Home
Name Date Size #Lines LOC

..--

AppScope/06-May-2025-3633

entry/06-May-2025-858710

hvigor/06-May-2025-88

screenshots/device/06-May-2025-

.gitignoreD06-May-202556 55

README_zh.mdD06-May-20254.7 KiB8656

build-profile.json5D06-May-20251.1 KiB4342

hvigorfile.jsD06-May-2025168 21

hvigorwD06-May-20251.4 KiB4928

hvigorw.batD06-May-20252.1 KiB8060

oh-package.json5D06-May-2025210 1211

ohosTest.mdD06-May-2025533 86

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| ![](screenshots/device/startAbility.png) | ![](screenshots/device/setWindowRatio.png) | ![](screenshots/device/getWindowSize.png) |
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```