自己做悬浮拖拽按钮依赖

Posted cmusketeer

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自己做悬浮拖拽按钮依赖相关的知识,希望对你有一定的参考价值。

PS:悬浮拖拽按钮的使用也是非常广的,就比如说上一个网站的时候就会弹出一个对话框,对话框可以随意拖动,那么安卓手机上可以实现吗,答案是可以的,这就用到了自定义view的按压点击等事件,本文的例子比较简单是继承FloatingActionButton,这个控件本身就做的很好了,点击效果,按压出的投影等都是可以调节的,所以继承他就可以省去写很多细节代码。网上也是有很多博友写了有关的文章,讲了原理也是很清楚的,写的都很好,也有很多写的代码基本上差不多,再怎么变MotionEvent方法的DOWN、MOVE、UP等是不会变的,里面无非是写了一些不兼容的问题,当时我写这个的时候也是有一些问题,比如说,锤子手机就不能用,或者华为手机5.0以上的不行等,在网上看了一些博友的文章借鉴,在这里首先感谢博客这个平台可以分享技术,其次就是博友的技术思路分享。煽情的话就到这了,这里就稍微说一下制作思路:

思路:

  • 继承FloatingActionButton
  • onTouchEvent()的重写
  • MotionEvent.ACTION_DOWN:
  • MotionEvent.ACTION_MOVE:
  • MotionEvent.ACTION_UP:

当手指按下的时候记住悬浮按钮屏幕所在位置作为起始位置,当滑动的时候再次获取所在位置并且判断所滑动的不能超过屏幕(不判断有时会导致一半按钮在外,一半在内的现象),当超过时,就让它等于屏幕的最小值或者最大值,至于UP就是动画了,当手指抬起后判断在屏幕的哪边,左边就把x=0;右边 x=屏幕最大值。下面有我整理完后,做了一个AS依赖库,直接就可以用,想搞明白这一块的知识可以去查查别的资料,也可以直接拿着用。

效果:

技术分享图片

1:添加依赖

自己做了一个依赖:根目录build.gradle中

    allprojects {
        repositories {
            ...
            maven { url ‘https://jitpack.io‘ }
        }
    }

在build.gradle中添加

    dependencies {
            implementation ‘com.github.hahage001:LZTmusketeer:v1.0.0‘
    }

2:使用

添加依赖的地址和本文的有所不同。(mus.cn.suspendbutton.DragFloatActionButton)

    <mus.cn.suspendbutton.DragFloatActionButton
        android:layout_width="200px"
        android:layout_height="200px"
        android:src="@mipmap/ic_launcher"
        app:backgroundTint="#253aac"
        app:rippleColor="#33728dff"
        app:elevation="6dp"
        app:pressedTranslationZ="12dp"
        android:clickable="true"
        android:focusable="true"
    />

 

 

 

以上是关于自己做悬浮拖拽按钮依赖的主要内容,如果未能解决你的问题,请参考以下文章

Android事件冲突解决-悬浮窗拖拽处理

android可拖拽悬浮控件和Kotlin的可拖拽悬浮控件/可拖拽悬浮按钮带Demo附件

android可拖拽悬浮控件和Kotlin的可拖拽悬浮控件/可拖拽悬浮按钮带Demo附件

vue里怎么实现右侧悬浮,并且能上下拖拽的按钮功能?

vue里怎么实现右侧悬浮,并且能上下拖拽的按钮功能?

js仿苹果悬浮可拖拽按钮,并且点击展开效果