---恢复内容开始---

MenuDrawer框架是一个可以实现上下左右滑动的框架,在使用中可以在xml文件中配置也可以在java代码中实现效果的配置

可以以jar的形式或依赖的形式存在      用依赖的形式存在是方便修改MenuDrawer的源码

在xml中配置

<net.simonvt.menudrawer.OverlayDrawer   //以覆盖的形式出现   即在侧滑时侧滑菜单滑动主界面不会发生改变
        android:id="@+id/drawer"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent
        android:orientation="vertical"
        app:mdContentBackground="@color/interface_background"//  设置内容区的背景银色
        app:mdDrawOverlay="false"      
        app:mdDropShadowColor="#55000000"     //设置阴影部分的颜色
        app:mdDropShadowEnabled="true"    
        app:mdDropShadowSize="5dp"     //设置 阴影部分的长度
        app:mdMenuSize="304dp"        //设置侧滑栏的宽度
        app:mdPosition="right">   //设置是从界面的右边滑出
        <!--304dp-->

代码

mMenuDrawer = MenuDrawer.attach(MainActivity.this,MenuDrawer.Overlay, Position.RIGHT);// 设置出现方式   和位置
        mMenuDrawer.setContentView(R.layout.main_acivity);

mMenuDrawer.setMenuView(R.layout.main_menu);//设置侧滑菜单的布局   这里可以用fragment将布局替换调  替不替换就看你自己的思路
        mMenuDrawer.setTouchMode(MenuDrawer.TOUCH_MODE_NONE);// 设置成不可滑动只可点击出现侧滑菜单     也可以设置其他

这个可以监听点击事件    mMenuDrawer.openMenu();
        mMenuDrawer.setDropShadow(R.drawable.shadow);// 设置阴影 渐变的绘图效果
        mMenuDrawer.setDropShadowSize(10);// 阴影长度
         mMenuDrawer.setMenuSize(size);//设置侧滑菜单出现的宽度
        mMenuDrawer.setMaxAnimationDuration(1000);

//这个方法比较重要
        mMenuDrawer.setOnDrawerStateChangeListener(this);

@Override
    public void onDrawerSlide(float openState, int arg1) {

}

// 状态改变
    @Override
    public void onDrawerStateChange(int outData, int newData) {

}

openState是0.0---1.0的数值变化

当侧滑完全打开时为1.0   完全关闭时0.0

newStatr是int值当完全关闭时为0,打开时为8(没弄明白,这个8是怎样出来的有时间再研究,如果有知道,求解,,,,,,)

在这个方法中我主要使用openState这个值来实现监听效果

例如有个效果  在点击条目时条目整体和侧滑菜单偏移

然后拉动侧滑菜单时整体条目随侧滑菜单来实现联动

这时这个openState值就比较重要了

这里我的实现方式是用到了 scrollBy()和openState值结合来实现的

//在这里比较不好搞定是:

在实现来侧滑并且侧滑时主界面不动的效果时,如果要求主界面和侧滑菜单的  listview都可以滑动且可点击时,这里需要修改下MenuDrawer的源码

(可以将MenuDrawer'作为依赖库    即源码加进来,)

在这里可以发现在MenuDrawer源码中有个  OverlayDrawer.java文件   由于选择的模式是覆盖,又想在覆盖时滑动主界面那么这里提供了修改的方法

在触摸事件判断是否拦截事件的方法  onInterceptTouchEvent(MotionEvent ev) 中的

562行  一般应该就是这行

if (isContentTouch(x, y)) {
                return true;
            }
        }

将这里的true修改为false

if (isContentTouch(x, y)) {
                return false;
            }
        }

即可实现那个比较牛逼的效果来.

完.

---恢复内容结束---

MenuDrawer的使用的更多相关文章

  1. 【开源项目5】测滑菜单MenuDrawer的使用以及解析

    在安卓中左右侧滑菜单的使用用的比ios多得多,可能是谷歌带的头吧,几乎所有的谷歌应用都有侧滑菜单.谷歌没有开放这个源码,在一个成熟的开源代码出现之前,大家都是各自为战,偶尔能看到一个勉强实现了的.Me ...

  2. Android开源--MenuDrawer

    开放的源地址:https://github.com/SimonVT/android-menudrawer 简单介绍:menudrawer是跟sliderMenu差点儿相同的一种框架,常被应用做设置界面 ...

  3. Android滑动菜单使用(MenuDrawer和SlidingMenu)

    项目地址: https://github.com/gokhanakkurt/android-menudrawer   https://github.com/jfeinstein10/SlidingMe ...

  4. 【开源项目6】介绍MenuDrawer这个牛x的控件,实现左右出菜单,上下出菜单

    现在很多应用都很潇洒的从左边屏幕手势一划出个左边的隐藏菜单,右边一划出个隐藏菜单,上边一划出个隐藏菜单,下边一划出个隐藏菜单.或者像android的API16左右的激活列表项的功能.很多人肯定都很着迷 ...

  5. 【转】GitHub 排名前 100 的安卓、iOS项目简介

    GitHub Android Libraries Top 100 简介 排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果, 然后过滤了跟 Android 不 ...

  6. android 官方DrawerLayout的介绍和使用

    南尘:爱编程,爱安卓,每天进步一点点. drawerLayout是Support Library包中实现了侧滑菜单效果的控件,可以说drawerLayout是因为第三方控件如MenuDrawer等的出 ...

  7. Android高手速成--第一部分 个性化控件(View)

    第一部分 个性化控件(View) 主要介绍那些不错个性化的View,包括ListView.ActionBar.Menu.ViewPager.Gallery.GridView.ImageView.Pro ...

  8. 据说年薪30万的Android程序员必须知道的帖子

    Android中国开发精英 目前包括: Android开源项目第一篇--个性化控件(View)篇       包括ListView.ActionBar.Menu.ViewPager.Gallery.G ...

  9. Android开源项目分类汇总

    目前包括: Android开源项目第一篇——个性化控件(View)篇   包括ListView.ActionBar.Menu.ViewPager.Gallery.GridView.ImageView. ...

随机推荐

  1. 月薪10K必备--C#下拉框联动

                   下拉框联动 很多网站上都用到下拉框联动,就是第一个下拉框没有选择任何项,第二个下拉框就没有选项.这样的做法更加谨慎,更加紧密. 下面我就教大家怎么做下拉框联动: 首先在窗 ...

  2. 流形(Manifold)初步【转】

    转载自:http://blog.csdn.net/wangxiaojun911/article/details/17076465 欧几里得几何学(Euclidean Geometry) 两千三百年前, ...

  3. JS中关于clientWidth offsetWidth srollWidth等的含义

    网页可见区域宽: document.body.clientWidth;网页可见区域高: document.body.clientHeight;网页可见区域宽: document.body.offset ...

  4. 从网页psd到html的开发

    从网上下载了一张psd的网页设计稿,初学html+css,所以记录一下我的学习过程.原图是这个样子:             原图                                   ...

  5. 用Django搭建个人博客—(2)

    今日任务: 1 blog的数据库模型定义 2 简单的注册登录功能的实现 项目的源文件已经推送到git@oschina.net. 所以,如果想要参阅源码的请移步 (Fork) http://git.os ...

  6. [转]IoC框架

    1 IoC理论的背景     我们都知道,在采用面向对象方法设计的软件系统中,它的底层实现都是由N个对象组成的,所有的对象通过彼此的合作,最终实现系统的业务逻辑.   图1:软件系统中耦合的对象 如果 ...

  7. 学习Swift -- 继承

    继承 一个类可以继承另一个类的方法(methods),属性(properties)和其它特性.当一个类继承其它类时,继承类叫子类,被继承类叫超类(父类). 在 Swift 中,子类可以调用和访问父类的 ...

  8. matlab的常用快捷键

    ctrl+shift+d:控制窗口嵌入还是非嵌入

  9. HTML文档模式与盒模型

    HTML文档根据文档顶部的doctype声明来决定渲染模式,有标准模式(Standards Mode)与怪异模式(Quirks mode,或叫做混杂模式)两种模式. IE5及以前默认总是表现为怪异模式 ...

  10. 优先级和lisp式前缀表达式

    if(f(a,b) > 0) # 1 if(f(a, b>0)) # 2 上面在调用f的时候,1使用括号表明了参数的优先级,不然会出现2这样的情况. 而使用lisp式的前缀表达式则不会有不 ...