ViewDragHelper (三)- 打造仿陌陌视频播放页(深入篇)

本文介绍了如何利用ViewDragHelper打造一个可下拉拖拽关闭、左右滑动切换的视频播放页面,类似陌陌APP的效果。通过事件分发拦截、回调监听处理,实现滑动方向限制、平移动画、缩放及背景透明度变化等关键功能。
摘要由CSDN通过智能技术生成

本篇为该系列的第三篇,将通过一个实际的业务需求来讲述ViewDragHelper的实际运用。

目录

ViewDragHelper 的介绍以及初步使用请阅读这篇:
ViewDragHelper (一)- 介绍及简单用例(入门篇)
ViewDragHelper 的源码以及Callback的详情介绍请阅读这篇:
ViewDragHelper (二)- 源码及原理解读(进阶篇)
利用DrageHelper 打造仿陌陌APP视频播放页的demo请阅读这篇:
ViewDragHelper (三)- 打造仿陌陌视频播放页(深入篇)

介绍

首先,系统的DrawerLayout 抽屉想必大家都不陌生,它的侧重点在于左右滑动。鉴于已经有很多大牛写过类似的,咱们就不再过多地讲述这个了,有兴趣的朋友可以自行查找相关的文章。本篇文章主要讲解如何利用ViewDragHelper来打造一个可以下拉拖拽关闭以及左右滑动切换的功能。

效果演示

1. QZone

QQ空间视频播放页也有这个下拉关闭的功能,效果图如下:

QZone.gif

若想要的功能仅仅只是它,那么可以直接参考第一篇文章的代码,会简洁很多,文章链接:ViewDragHelper (一)- 介绍及简单用例(入门篇)

2. 陌陌播放页

陌陌播放页的效果图:

Momo.gif

3. 实际效果

下面是本项目的效果图:

draggableView.gif

真机展示的效果可能会好点儿

horiztonal.gif
vertical.gif

正文

本文主要讲解的点有如下几个:

  1. 滑动方向判定。
  2. 如何限制为单个方向的拖拽。
  3. 事件分发以及拦截。
  4. 平移动画问题。
  5. 下拉时缩放及背景透明处理。
  6. 背景高斯图片替换处理。
  7. 嵌套ScrollView / RecyclerView事件冲突处理。
  8. 多点触控 Invalid pointerId 问题解决。
初始化

首先, 我们还是和第一篇文章一样,创建一个DragView(继承自ViewGroup),以及一个CallBack(继承自 ViewDragHelper.Callback)。
然后进行相关初始化操作。
1. 初始化ViewDragHelper。
2. 初始化CallBack ,用于监听ViewDragHelper相关事件,回调给DraggableView。
3. 初始化DraggableListener,用于回调给外部。

具体代码可参考demo,项目地址贴在文章底部。

事件分发拦截处理

代码总篇幅太长,就不贴完整源代码了,用伪代码描述大致实现思路。有需要完整代码的朋友可以自行下载GitHub 上面的demo。

onInterceptTouchEvent 方法里面判断了手势方向,以及滑动冲突,多点触控导预防处理。伪代码如下:

@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {

    if (!isEnabled()) {
            return false;
        }

    switch(event) {
    case ACTION_DOWN:
          if (activePointerId == INVALID_POINTER) {
            
介绍:用ViewDragHelper实现的activity切换动画。运行效果:使用说明: 你可以将这个库当成view来用:将DraggerView添加到root layout,并且在里面加入两个layout。<com.github.library.DraggerView     android:layout_width="match_parent"     android:layout_height="match_parent"     dragger_layout:drag_view_id="@ id/drag_view"     dragger_layout:shadow_view_id="@ id/shadow_view"     dragger_layout:drag_position="top">       <FrameLayout           android:id="@ id/shadow_view"           android:layout_width="match_parent"           android:layout_height="match_parent"           android:background="@color/transparent"           android:visibility="invisible"/>         <LinearLayout           android:id="@ id/drag_view"           android:layout_width="match_parent"           android:layout_height="match_parent"/>   </com.github.library.DraggerView>style文件中这样设置<style name="YourTheme" parent="Theme.AppCompat.Light.DarkActionBar">     <item name="android:windowIsTranslucent">true</item>       <item name="android:windowBackground">@android:color/transparent</item>       <item name="android:windowNoTitle">true</item>       <item name="windowActionBar">false</item>       <item name="android:windowAnimationStyle">@null</item> </style>manifest中<activity     android:name="com.github.dragger.BaseActivity"     android:theme="@style/YourTheme"/>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值