天天看点

【HarmonyOS】【ARK UI】怎么实现一个悬浮框

参考资料

​​窗口​​

准备资料

权限配置
ohos.permission.SYSTEM_FLOAT_WINDOW      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框
config.json配置

config.json配置权限,代码如下

"reqPermissions": [
    
      {
        "name": "ohos.permission.SYSTEM_FLOAT_WINDOW"      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框

在mianAbility进行配置,代码如下

package com.harmony.alliance.myapplication;

import ohos.ace.ability.AceAbility;
import ohos.aafwk.content.Intent;

public class MainAbility extends AceAbility {
    @Override
    public void onStart(Intent intent) {
        String[] permissions = {
                "ohos.permission.WRITE_USER_STORAGE",
                "ohos.permission.READ_USER_STORAGE",
                "ohos.permission.SYSTEM_FLOAT_WINDOW"};
        requestPermissionsFromUser(permissions, 0);
        super.onStart(intent);
    }

    @Override
    public void      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框
创建框口

create(id: string, type: WindowType, callback: AsyncCallback): void

创建子窗口

参数

【HarmonyOS】【ARK UI】怎么实现一个悬浮框

示例

var windowClass = null; 
window.create("first", 1, (err, data) => {
    windowClass = data;
    if (err) {
        console.error('Failed to create the subWindow. Cause: ' + JSON.stringify(err));
        return;
    }
    console.info('SubWindow created. Data: ' + JSON.stringify(data))
    windowClass.resetSize(500, 1000);
    windowClass.setOutsideTouchable(true);
    windowClass.loadContent("pages/index/index", (err, data) => {
   });
})      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框
加载内容

loadContent (BETA)7+

loadContent(path: string, callback: AsyncCallback): void

子窗口加载具体页面内容。

参数

【HarmonyOS】【ARK UI】怎么实现一个悬浮框

示例

windowClass.loadContent("pages/page2/page2", (err, data) => {
   if (err) {
         console.error('Failed to load the content. Cause:' + JSON.stringify(err));
         return;
   }
  console.info('Succeeded in loading the content. Data:' + JSON.stringify(data));
});      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框
窗口显示

show(callback: AsyncCallback): void

显示子窗口

参数

【HarmonyOS】【ARK UI】怎么实现一个悬浮框

示例

windowClass.show((err, data) => {
    if (err) {
        console.error('Failed to show the subwindow. Cause: ' + JSON.stringify(err));
        return;
    }
    console.info('Succeeded in showing the subwindow. Data: ' + JSON.stringify(data))
})      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框

代码实现

import router from '@system.router';
import window from '@ohos.window';
@Entry
@Component
struct MywindowPage {
  public onclick(){
    console.log("####===onclick")
    window.create("first", 2038, (err, data) => {
      if (err) {
        console.log('#####===>Failed to create the subWindow. Cause: ' + JSON.stringify(err));
        return;
      }
      console.info('#####===>SubWindow created. Data: ' + JSON.stringify(data))
      data.resetSize(500, 1000);
      data.setOutsideTouchable(true);
      data.loadContent("pages/index", (err, data) => {
        if(err){
          console.log("#####===>加载失败")
        }
        console.log("#####===>加载成功")
      });
      data.show((err, data) => {
        if (err) {
          console.error('#####===>Failed to show the subwindow. Cause: ' + JSON.stringify(err));
          return;
        }
        console.log('#####===>Succeeded in showing the subwindow. Data: ' + JSON.stringify(data))
      })
    })

  }
  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Text('创建一个window')
        .fontSize(50)
        .fontWeight(FontWeight.Bold)
        .onClick(this.onclick.bind(this))

    }
    .width('100%')
    .height('100%')
  }
}      
【HarmonyOS】【ARK UI】怎么实现一个悬浮框

运行效果

继续阅读