【JAVA UI】HarmonyOS的悬浮框实现
参考资料
鸿蒙支持悬浮窗吗? WindowManager 的addComponent 不生效吗?
代码实现
1、准备工作
权限设置,我们需要在config.json文件上添加如下权限,代码如下
"reqPermissions": [
{"name": "ohos.permission.SYSTEM_FLOAT_WINDOW"}
],
2、绘画Xml布局
我们MianAbilitySlice的xml的布局,一个Text显示悬浮框,代码如下
<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout
xmlns:ohos="http://schemas.huawei.com/res/ohos"
ohos:height="match_parent"
ohos:width="match_parent"
ohos:alignment="center"
ohos:orientation="vertical">
<Text
ohos:id="$+id:text_helloworld"
ohos:height="match_content"
ohos:width="match_content"
ohos:background_element="$graphic:background_ability_main"
ohos:layout_alignment="horizontal_center"
ohos:text="显示悬浮框"
ohos:text_size="40vp"
/>
</DirectionalLayout>
我们在绘画一个悬浮框的xml布局,命名为float_window.xml,然后在悬浮框中text组件用于显示悬浮的内容,代码如下
<?xml version="1.0" encoding="utf-8"?>
<DirectionalLayout
xmlns:ohos="http://schemas.huawei.com/res/ohos"
ohos:height="match_parent"
ohos:width="match_parent"
ohos:alignment="center"
ohos:background_element="#20000000"
ohos:orientation="vertical">
<Text
ohos:height="match_content"
ohos:width="match_content"
ohos:layout_alignment="horizontal_center"
ohos:text="这个是一个悬浮框"
ohos:text_size="40vp"
/>
</DirectionalLayout>
3、java 代码实现
text组件实现点击的事件,判断是否存在应用层显示权限,如果存在的话显示悬浮框,如果不存在的话关闭界面,代码如下
package com.aispeech.mileohos.slice;
import com.aispeech.mileohos.ResourceTable;
import ohos.aafwk.ability.AbilitySlice;
import ohos.aafwk.content.Intent;
import ohos.agp.components.Component;
import ohos.agp.components.ComponentContainer;
import ohos.agp.components.LayoutScatter;
import ohos.agp.window.service.Window;
import ohos.agp.window.service.WindowManager;
import ohos.sysappcomponents.settings.AppSettings;
import ohos.utils.net.Uri;
public class MainAbilitySlice extends AbilitySlice {
private Window window;
@Override
public void onStart(Intent intent) {
super.onStart(intent);
super.setUIContent(ResourceTable.Layout_ability_main);
//todo 设置点击事件
findComponentById(ResourceTable.Id_text_helloworld).setClickedListener(new Component.ClickedListener() {
@Override
public void onClick(Component view) {
//todo 判断是否有在应用界面上显示的权限
if (AppSettings.canShowFloating(MainAbilitySlice.this)) {
//todo 如果存在的话 显示悬浮框
show();
} else {
//todo 如果不存在的话 添加设置界面进行设置
Intent intent2 = new Intent();
intent2.setAction("android.settings.action.MANAGE_OVERLAY_PERMISSION");
Uri parse = Uri.parse("package:" + getBundleName());
intent2.setUri(parse);
startAbilityForResult(intent2, 1000);
}
}
});
}
@Override
protected void onAbilityResult(int requestCode, int resultCode, Intent resultData) {
boolean b = AppSettings.canShowFloating(this);
System.out.println("songy 不给授权"+b);
if (requestCode == 1000) {
if (AppSettings.canShowFloating(this)) {
show();
}else {
// todo 没授权 关闭界面
terminateAbility();
}
}
}
/**
* 悬浮框的实现
*/
private void show(){
//todo 加载悬浮框的布局
ComponentContainer componentContainer = (ComponentContainer) LayoutScatter.getInstance(MainAbilitySlice.this).parse(ResourceTable.Layout_float_window,null,false);
window=WindowManager.getInstance().
addComponent(componentContainer,MainAbilitySlice.this,WindowManager.LayoutConfig.MOD_APPLICATION_OVERLAY);
window.setTransparent(true);
window.setMovable(true);
WindowManager.LayoutConfig layoutConfig=new WindowManager.LayoutConfig();
//todo layoutConfig属性设置
layoutConfig.width=900;
layoutConfig.height=900;
int flags = WindowManager.LayoutConfig.MARK_TOUCH_MODAL_IMPOSSIBLE |
WindowManager.LayoutConfig.MARK_FOCUSABLE_IMPOSSIBLE |
WindowManager.LayoutConfig.MARK_ALLOW_LAYOUT_COVER_SCREEN;
layoutConfig.flags = flags;
window.setLayoutConfig(layoutConfig);
}
}
运行效果
欲了解更多更全技术文章,欢迎访问https://developer.huawei.com/consumer/cn/forum/?ha_source=zzh