1 Star 4 Fork 1

TS_OHOS / EasyFloat

Create your Gitee Account
Explore and code with more than 12 million developers,Free private repositories !:)
Sign up
Clone or Download
contribute
Sync branch
Cancel
Notice: Creating folder will generate an empty file .keep, because not support in Git
Loading...
README

EasyFloat

本项目是基于开源项目EasyFloat进行harmonyos化的移植和开发的,可以通过项目标签以及github地址https://github.com/princekin-f/EasyFloat追踪到原项目版本

移植版本:2.0.2

项目介绍

项目名称: EasyFloat:浮窗从未如此简单

所属系列:harmonyos的第三方组件适配移植

功能:

  • 支持单页面浮窗,无需权限申请
  • 支持全局浮窗、应用前台浮窗,需要授权悬浮窗权限
  • 自动权限检测、自动跳转浮窗权限管理页、自动处理授权结果
  • 支持系统浮窗的页面过滤
  • 支持拖拽,支持各种状态的回调
  • 支持默认位置的设定,支持对齐方式和偏移量的设定
  • 支持创建多个单页面浮窗、多个系统浮窗,Tag进行区分
  • 支持出入动画的设定,有默认动画,可自行替换(策略模式)
  • 使用简单、链式调用、可轻松修改浮窗View

原项目Doc地址:https://github.com/princekin-f/EasyFloat

编程语言:java

安装教程

方式一:

  • 1.下载easyfloat/library的har包library.har(位于output文件夹下)。
  • 2.启动 DevEco Studio,将下载的har包,导入工程目录“entry->libs”下。
  • 3.在moudle级别下的build.gradle文件中添加依赖,在dependences标签中增加对libs目录下jar包的引用。
dependencies {
implementation fileTree(dir: 'libs', include: ['.jar', '.har'])
……
}

方式二:

allprojects {
    repositories {
        mavenCentral()
       
    }
}
implementation 'com.gitee.ts_ohos:EasyFloat:1.0.0'
  • 4.在导入的har包上点击右键,选择“Add as Library”对包进行引用,选择需要引用的模块,并点击“OK”即引用成功。

使用说明

easyfloat是harmonyos的可拖拽悬浮窗口,支持页面过滤、自定义动画,可设置单页面浮窗、前台浮窗、全局浮窗,浮窗权限按需自动申请, 申请Abliity浮窗需要在根部局传入resId

1.直接在xml布局使用拖拽控件:

            <com.lzf.easyfloat.widget.activityfloat.FloatingView
                ohos:id="$+id:floatingView"
                ohos:height="match_content"
                ohos:width="match_content"
                ohos:layout_alignment="center"
                ohos:left_margin="40vp">

                <Image
                    ohos:height="match_content"
                    ohos:width="match_content"
                    ohos:image_src="$media:ic_launcher_round"/>

            </com.lzf.easyfloat.widget.activityfloat.FloatingView>

2.完整使用示例:

EasyFloat.with(this)
 // 设置浮窗xml布局文件,并可设置详细信息
 .setLayout(R.layout.float_app, OnInvokeView { })
 // 设置浮窗显示类型,默认只在当前Activity显示,可选一直显示、仅前台显示、仅后台显示
 .setShowPattern(ShowPattern.ALL_TIME)
 // 设置吸附方式,共15种模式,详情参考SidePattern
 .setSidePattern(SidePattern.RESULT_HORIZONTAL)
 // 设置浮窗的标签,用于区分多个浮窗
 .setTag("testFloat")
 // 设置浮窗是否可拖拽,默认可拖拽
 .setDragEnable(true)
 // 系统浮窗是否包含EditText,仅针对系统浮窗,默认不包含
 .hasEditText(false)
 // 设置浮窗固定坐标,ps:设置固定坐标,Gravity属性和offset属性将无效
 .setLocation(100, 200)
 // 设置浮窗的对齐方式和坐标偏移量
 .setGravity(Gravity.END or Gravity.CENTER_VERTICAL, 0, 200)
 // 设置宽高是否充满父布局,直接在xml设置match_parent属性无效
 .setMatchParent(widthMatch = false, heightMatch = false)
 // 设置Activity浮窗的出入动画,可自定义,实现相应接口即可(策略模式),无需动画直接设置为null
 .setAnimator(DefaultAnimator())
 // 设置系统浮窗的出入动画,使用同上
 .setAppFloatAnimator(AppFloatDefaultAnimator())
 // 设置系统浮窗的不需要显示的页面
 .setFilter(MainActivity::class.java, SecondActivity::class.java)
 // 设置系统浮窗的有效显示高度(不包含虚拟导航栏的高度),基本用不到,除非有虚拟导航栏适配问题
 .setDisplayHeight(OnDisplayHeight { context -> DisplayUtils.rejectedNavHeight(context) })
 // 浮窗的一些状态回调,如:创建结果、显示、隐藏、销毁、touchEvent、拖拽过程、拖拽结束。
 .registerCallback {
 createResult { isCreated, msg, view -> }
 show { }
 hide { }
 dismiss { }
 touchEvent { view, motionEvent -> }
 drag { view, motionEvent -> }
 dragEnd { }
 }
 // 创建浮窗(这是关键哦)
 .show(int resId)

3.Abliity浮窗的相关API:

// 关闭浮窗
dismiss(activity: Activity? = null, floatTag: String? = null)
// 隐藏浮窗
hide(activity: Activity? = null, floatTag: String? = null)
// 显示浮窗
show(activity: Activity? = null, floatTag: String? = null)
// 设置是否可拖拽
setDragEnable(activity: Activity? = null, dragEnable: Boolean, floatTag: String? = null )
// 浮窗是否显示
isShow(activity: Activity? = null, floatTag: String? = null)
// 获取我们设置的浮窗View
getFloatView(activity: Activity? = null, tag: String? = null)
PS? = null 代表可选参数不填也行默认值为null下同

4.系统浮窗的相关API:

// 关闭浮窗
dismissAppFloat(tag: String? = null)
// 隐藏浮窗
hideAppFloat(tag: String? = null)
// 显示浮窗
showAppFloat(tag: String? = null)
// 设置是否可拖拽
appFloatDragEnable(dragEnable: Boolean, tag: String? = null)
// 浮窗是否显示
appFloatIsShow(tag: String? = null)
// 获取我们设置的浮窗View
getAppFloatView(tag: String? = null)
// 添加单个浮窗过滤页面
filterActivity(activity: Activity, tag: String? = null)
// 添加多个浮窗过滤页面
filterActivities(tag: String? = null, vararg clazz: Class<>)
// 移除单个浮窗过滤页面
removeFilter(activity: Activity, tag: String? = null)
// 移除多个浮窗过滤页面
removeFilters(tag: String? = null, vararg clazz: Class<>)
// 清空过滤页面
clearFilters(tag: String? = null)

版本迭代

  • v1.0.0 项目初次提交

License

Copyright 2019 Liu Zhenfeng.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Empty file

About

支持单页面浮窗,无需权限申请 支持全局浮窗、应用前台浮窗,需要授权悬浮窗权限 自动权限检测、自动跳转浮窗权限管理页、自动处理授权结果 支持系统浮窗的页面过滤 支持拖拽,支持各种状态的回调 支持默认位置的设定,支持对齐方式和偏移量的设定 支持创建多个单页面浮窗、多个系统浮窗,Tag进行区分 支持出入动画的设定,有默认动画,可自行替换(策略模式) 根据浮窗复杂度、重要性,可自主选择前后台Service 使用简单、链式调用,无侵入性 支持xml直接使用,满足拖拽控件的需求 支持解锁更多姿势,如:拖拽缩放、通知弹窗... expand collapse
Java
Cancel

Releases

No release

Contributors

All

Activities

Load More
can not load any more
Java
1
https://gitee.com/ts_ohos/easy-float.git
git@gitee.com:ts_ohos/easy-float.git
ts_ohos
easy-float
EasyFloat
master

Search