HarmonyOS 鸿蒙Next:创建子窗口实现悬浮窗功能 窗口相关的事件监听都不支持

发布于 1周前 作者 sinazl 来自 鸿蒙OS

HarmonyOS 鸿蒙Next:创建子窗口实现悬浮窗功能 窗口相关的事件监听都不支持 想要实现侧滑手势关闭打开的悬浮框,一开始通过监听窗口事件来实现的,但不成功,大家有推荐方案吗?

2 回复

可以通过在页面onBackPress()生命周期中隐藏子窗口,参考代码:

在EntryAbility中创建子窗口:

showSubWindow() {
  // 1.创建应用子窗口。
  if (windowStage_ == null) {
    console.error('Failed to create the subwindow. Cause: windowStage_ is null');
  } else {
    windowStage_.createSubWindow("mySubWindow", (err: BusinessError, data) => {
      sub_windowClass = data;
      console.info('Succeeded in creating the subwindow. Data: ' + JSON.stringify(data));
      // 2.子窗口创建成功后,设置子窗口的位置、大小及相关属性等。
      sub_windowClass.moveWindowTo(300, 300);
      sub_windowClass.resize(500, 500);
      sub_windowClass.setWindowTouchable(true)
      // 3.为子窗口加载对应的目标页面。
      sub_windowClass.setUIContent("pages/Page");
      (sub_windowClass as window.Window).showWindow();
    })
  }
}

Page中使用onBackPress监听销毁子窗口:

import window from '@ohos.window'

@Entry
@Component
struct Page {
  @State message: string = 'Hello World'
  onBackPress() {
    console.log("被触发了");
    window.findWindow("mySubWindow").destroyWindow();
    return true;
  }
  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
      }
      .width('100%')
    }
    .height('100%')
    .backgroundColor(Color.Blue)
  }
}

更多关于HarmonyOS 鸿蒙Next:创建子窗口实现悬浮窗功能 窗口相关的事件监听都不支持的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS鸿蒙系统中,创建子窗口并实现悬浮窗功能时,如果窗口相关的事件监听都不支持,这通常意味着当前使用的API或框架版本可能未完全开放或支持所有窗口事件监听功能。

针对这一问题,你可以考虑以下几个方向进行排查和解决:

  1. 确认API版本:首先确保你使用的HarmonyOS SDK版本是最新的,因为新版本的SDK可能会修复旧版本中的问题,并增加新的功能支持。

  2. 查阅官方文档:详细查阅HarmonyOS的官方开发文档,了解当前版本是否支持悬浮窗的事件监听功能,以及是否有替代方案或工作区。

  3. 社区和论坛:参与HarmonyOS的开发者社区和论坛,看看其他开发者是否遇到并解决了类似的问题。社区中可能包含有用的代码示例或解决方案。

  4. 代码审查:仔细检查你的代码实现,确保没有遗漏或错误地实现了事件监听的相关代码。

  5. 功能限制:了解是否存在系统级的功能限制,导致无法监听悬浮窗事件。在某些情况下,出于安全或隐私考虑,系统可能限制了某些类型的事件监听。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部