ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2022-08-05 09:33:55  阅读:160  来源: 互联网

标签:stringify console err HarmonyOS JSON UI ohos ARK data


参考资料

窗口

准备资料

权限配置
ohos.permission.SYSTEM_FLOAT_WINDOW
config.json配置

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

    "reqPermissions": [
    
      {
        "name": "ohos.permission.SYSTEM_FLOAT_WINDOW"
      }
    ],

在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 onStop() {
        super.onStop();
    }
}
创建框口

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

创建子窗口

参数

cke_2100.png

示例

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) => {
   });
})
加载内容

loadContent (BETA)7+

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

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

参数

cke_4772.png

示例

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));
});
窗口显示

show(callback: AsyncCallback): void

显示子窗口

参数

cke_8697.png

示例

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: '</span> + <span class="hljs-built_in">JSON</span>.stringify(data))
})</code></pre>
<img class="cke_reset cke_widget_mask" src="">

代码实现

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: '</span> + <span class="hljs-built_in">JSON</span>.stringify(data))
      })
    })

  }
  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Text(<span class="hljs-string">'创建一个window'</span>)
        .fontSize(<span class="hljs-number">50</span>)
        .fontWeight(FontWeight.Bold)
        .onClick(<span class="hljs-keyword">this</span>.onclick.bind(<span class="hljs-keyword">this</span>))

    }
    .width(<span class="hljs-string">'100%'</span>)
    .height(<span class="hljs-string">'100%'</span>)
  }
}</code></pre>
<img class="cke_reset cke_widget_mask" src="">

运行效果

a9fc08ad216ed4493626801dbc544647_739x985.gif%40900-0-90-f.gif

欲了解更多更全技术文章,欢迎访问https://developer.huawei.com/consumer/cn/forum/?ha_source=zzh

标签:stringify,console,err,HarmonyOS,JSON,UI,ohos,ARK,data
来源: https://www.cnblogs.com/developer-huawei/p/16553211.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有