Android_UI 仿QQ侧滑菜单效果的实现

 更新时间:2017年04月11日 09:19:07   作者:Checkiming  
相信大家对QQ侧滑菜单的效果已经不陌生了吧,侧滑进入个人头像一侧,进行对头像的更改,我的收藏,QQ钱包,我的文件等一系列的操作,下面小编给大家分享Android_UI 仿QQ侧滑菜单效果的实现,一起看看吧

相信大家对QQ侧滑菜单的效果已经不陌生了吧,侧滑进入个人头像一侧,进行对头像的更改,我的收藏,QQ钱包,我的文件等一系列的操作,今天呢,主要是实现进入侧滑菜单的这一效果原理进行分析.

这里写图片描述 

主要思路分析

1.首先写一个SlideMenu 继承一个帧布局FrameLayout ,因为如果继承自ViewGroup的话,需要我们自己来实现onMeasure方法,而该方法的实现一般比较麻烦且没有必要,所以选择继承系统的已有的控件FrameLayout,不用其他控件是因为FrameLayout最轻量级

2.在布局文件中给SlideMenu添加2个子布局,分别是菜单的布局和主界面的布局

3.移动View的方法总结

通过改变View的scroll的坐标来移动:
scrollTo(x,y);//滚动到指定位置
scrollBy(xOffset,yOffset);//滚动多少距离
通过改变View在父View中的布局的位置:
offsetLeftAndRight(offset);//同时更改view的left和right
offsetTopAndBottom(offset);//同时更改view的top和bottom
layout(l,t,r,b);

4.ViewDragHelper 类的介绍

谷歌在2013年I/O开发者大会上提出;

专门用于在ViewGroup中对子View进行拖拽处理;

在19(Android4.4)以及以上的v4包中;

本质是封装了对触摸事件的解析,包括触摸位置,触摸速度以及Scroller的封装,只需要我们在回调方法中指定是否移动,移动多少等等,但是需要注意的是:它只是一个触摸事件的解析类(如GestureDecetor),所以需要我们传递给它触摸事件,它才能工作;

开始创建ViewDragHelper对象

ViewDragHelper viewDragHelper = ViewDragHelper.create(this, callback);

dragHelper 只是触摸事件的解析类,需要将触摸事件传递给它才能工作

1)_触摸事件: 将触摸事件传递给VIewDragHelper 来解析

触摸事件

2)_判断是否需要拦截触摸事件

拦截触摸事件

3)_初始化子view的引用

初始化view

4)_初始化宽高.在onSizeChanged方法中初始化宽高,因为该方法在onMeasure之后执行

初始化宽高

其中这里调用getMeasureWidth() 方法与分别获取左侧菜单的宽,主页面的宽的作用是一样的.

实现ViewDragHelper.Callback 的监听事件

监视view的触摸事件,这里需要考虑到,当进行滑动的时候,可能会触碰到listview的滑动事件,所以这里通过了getViewHorizontalDragRange()方法进行强制横向滑动,当返回值大于0 的时候,即让它强制横向滑动,否则在某些情况下不能水平滑动

监视触摸事件

强制拦截水平,修正水平位置 

控制垂直方向的移动

控制垂直方向的移动

在onViewPositionChanged()方法中实现一些伴随移动的效果

此方法可以获取view移动的距离

如果当前移动的是main ,那么就让menu 进行伴随移动

移动main ,并限制main的移动

根据滑动的百分比的值,去执行伴随的动画 executeAnim()

对移动进行处理

松开手指进行回调,该方法会处理手指拾起的缓慢移动

松开手指进行回调 

执行动画

这里考虑到了给整个SlideMenu的背景添加阴影遮罩效果,通过getBackground对是否为空时进行添加阴影遮罩效果

根据百分比执行动画

//对main的移动进行限制了
 private int fixLeft(int newLeft) {
    if (newLeft > maxLeft) {
      newLeft = maxLeft;
    } else if (newLeft < 0) {
      newLeft = 0;
    }
    return newLeft;

需要定义接口回调,将SlideMenu 打开,让滑动和关闭的事件方法暴露

//定义接口回调,将SlideMenu 打开,,滑动和关闭的事件暴露给外界
  public interface onSwipeListener {
    void onOpen();
    void onClose();
    void onDragging(float fraction); //拖拽过程中的回调
  }

以上所述是小编给大家介绍的Android_UI 仿QQ侧滑菜单效果的实现,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • Android实现带有指示器的进度条

    Android实现带有指示器的进度条

    这篇文章主要介绍了Android实现带有指示器的进度条的示例代码,帮助大家更好的理解和学习使用Android开发,感兴趣的朋友可以了解下
    2021-05-05
  • Android 调用系统相机拍摄获取照片的两种方法实现实例

    Android 调用系统相机拍摄获取照片的两种方法实现实例

    这篇文章主要介绍了Android 调用系统相机拍摄获取照片的两种方法实现实例的相关资料,一种是通过Bundle来获取压缩过的照片,一种是通过SD卡获取的原图,需要的朋友可以参考下
    2016-11-11
  • Android给布局、控件加阴影效果的示例代码

    Android给布局、控件加阴影效果的示例代码

    本篇文章主要介绍了Android给布局、控件加阴影效果的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • 如何从外部浏览开启Android App

    如何从外部浏览开启Android App

    从浏览器中点击某个按钮,如果手机上装有相应的app,则直接开启app,并且到相对的页面。如果没有装该app,则会到相应的下载app的界面。这样的功能怎么实现呢,本文带着大家来看看如何实现。
    2021-06-06
  • Android WebView基础应用详解

    Android WebView基础应用详解

    这篇文章主要为大家介绍了Android中WebView这一控件的基础应用,例如:播放音乐,播放视频等,文中的示例代码讲解详细,对于我们了解WebView很有帮助,需要的同学可以学习一下
    2021-12-12
  • Android如何在App中启动系统闹钟

    Android如何在App中启动系统闹钟

    这篇文章主要为大家详细介绍了Android如何在App中启动系统闹钟,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Android布局技巧之合并布局

    Android布局技巧之合并布局

    这篇文章主要为大家详细介绍了Android布局技巧之合并布局,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • Android 桌面Widget开发要点解析(时间日期Widget)

    Android 桌面Widget开发要点解析(时间日期Widget)

    总的来说,widget主要功能就是显示一些信息。我们今天编写一个很简单的作为widget,显示时间、日期、星期几等信息。需要显示时间信息,那就需要实时更新,一秒或者一分钟更新一次
    2013-07-07
  • Android编程实现获得手机屏幕真实宽高的方法

    Android编程实现获得手机屏幕真实宽高的方法

    这篇文章主要介绍了Android编程实现获得手机屏幕真实宽高的方法,以两个实例形式分析了获取手机屏幕信息的相关技巧,需要的朋友可以参考下
    2015-10-10
  • 详解LeakCanary分析内存泄露如何实现

    详解LeakCanary分析内存泄露如何实现

    这篇文章主要为大家介绍了详解LeakCanary分析内存泄露如何实现,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12

最新评论