欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

Android使用DrawerLayout仿QQ6.6版侧滑效果

时间:2021-03-08 11:40:44|栏目:Android代码|点击:

一讲到侧滑菜单,我相信大家都会想到一个开源控件SlidingMenu,在google还没有出来DrawerLayout的时候几乎都是使用Slidingmenu来实现侧滑效果,可以说是效果很不错,自从google出了Drawerlayout以后很多公司就使用了Drawerlayout比如 滴滴打车等等。那么今天我们利用drawerlayout来实现qq6.6最新的侧滑效果。首先来看看Drawerlayout默认的效果:


和目前最新版的qq的侧滑还是不一样的区别就是内容页面没有跟随向右滑动,而是菜单直接覆盖在内容上,来看一张QQ的样式图


这样大家可以看到区别了,其实我们只要在滑动左面菜单的时候让内容页面跟随滑动就行了,首先我们看看DrawerLayout有没有给我们监听滑动的监听,哈哈,翻了一下源码我们找到了这个方法 onDrawerSize方法;只要实现setDrawerListener回调就行了代码如下:

drawer.setDrawerListener(new DrawerLayout.DrawerListener() { 
      @Override 
      public void onDrawerSlide(View drawerView, float slideOffset) { 
        //获取屏幕的宽高 
        WindowManager manager = (WindowManager) getSystemService(Context.WINDOW_SERVICE); 
        Display display = manager.getDefaultDisplay(); 
        //设置右面的布局位置 根据左面菜单的right作为右面布局的left  左面的right+屏幕的宽度(或者right的宽度这里是相等的)为右面布局的right 
        right.layout(left.getRight(), 0, left.getRight() + display.getWidth(), display.getHeight()); 
      } 
      @Override 
      public void onDrawerOpened(View drawerView) { 
         
      } 
      @Override 
      public void onDrawerClosed(View drawerView) { 
         
      } 
      @Override 
      public void onDrawerStateChanged(int newState) { 
         
      } 
    }); 

然后在看看我们改变的效果吧:


是不是有那么点意思了呢,哈哈,今天就开到这里了。

最后附上源码:https://github.com/dalong982242260/DrawLayoutMenu

上一篇:浅谈Android获取ImageView上的图片,和一个有可能遇到的问题

栏    目:Android代码

下一篇:android RecyclerView实现条目Item拖拽排序与滑动删除

本文标题:Android使用DrawerLayout仿QQ6.6版侧滑效果

本文地址:http://www.codeinn.net/misctech/76883.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有