Android 使用Drawerlayout仿网易新闻客户端抽屉模式

本文介绍如何使用Android的DrawerLayout实现左右滑动抽屉效果,并提供代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文:http://blog.youkuaiyun.com/elinavampire/article/details/41477525

个人感觉网易的客户端比较前卫,有很多新鲜的东西,有时候模仿这些好的客户端能学到很多东西

开始今天的主要课题,下面是网易客户端抽屉模式实现的效果

其实有个Drawerlayout这个布局,你得问题就已经解决掉一大半了,Drawerlayout布局本身就提供了左划和右划的功能

先上代码,然后慢慢解答,看完这篇博客你就知道Drawerlayout怎么用了

首先上逐步局文件代码

[html]  view plain copy
  1. <android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:id="@+id/drawerlayout"  
  4.     android:layout_width="match_parent"  
  5.     android:layout_height="match_parent" >  
  6.   
  7.     <FrameLayout  
  8.         android:id="@+id/fragment_layout"  
  9.         android:layout_width="match_parent"  
  10.         android:layout_height="match_parent" >  
  11.     </FrameLayout>  
  12.   
  13.     <RelativeLayout  
  14.         android:id="@+id/left"  
  15.         android:layout_width="200dp"  
  16.         android:layout_height="match_parent"  
  17.         android:layout_gravity="left"   
  18.         android:background="@android:color/white">  
  19.   
  20.         <ListView  
  21.             android:id="@+id/left_listview"  
  22.             android:layout_width="match_parent"  
  23.             android:layout_height="match_parent" >  
  24.         </ListView>  
  25.     </RelativeLayout>  
  26.   
  27.     <RelativeLayout  
  28.         android:id="@+id/right"  
  29.         android:layout_width="260dp"  
  30.         android:layout_height="match_parent"  
  31.         android:layout_gravity="right"   
  32.         android:background="@android:color/holo_green_light">  
  33.   
  34.         <TextView  
  35.             android:id="@+id/right_textview"  
  36.             android:layout_width="match_parent"  
  37.             android:layout_height="match_parent"  
  38.             android:text="个人登陆页面" />  
  39.     </RelativeLayout>  
  40.   
  41. </android.support.v4.widget.DrawerLayout>  

Drawerlayout是Androidv4包里自带的,既然是自带的那么直接拿来用就可以了,当然前提是你得工程里有v4包

下面解释上面的布局文件,让你懂得Drawerlayout用法,首先Drawerlayout支持左划和右划,那他是如何控制的呢?不居中告诉你,以上布局分为三部分,一般情况下,第一部分是主步局,第二部分是左划的布局,第三部分是右划的布局,其实这里的左向滑动和右向滑动是通过gravity控制,左划界面android:layout_gravity="left" 当然这里的left也可以用start代替,右划界面就理所当然的是android:layout_gravity="right" ,同样right也可以用end代替,其余的应该明白了吧!不懂留言,我认真为你解答


下面在贴一下主界面的代码,你看懂Drawerlayout用法其余的就很简单了,妈妈再也不懂担心你的学习了

[java]  view plain copy
  1. package com.sdufe.thea.guo;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. import com.sdufe.thea.guo.adapter.ContentAdapter;  
  7. import com.sdufe.thea.guo.model.ContentModel;  
  8.   
  9. import android.os.Bundle;  
  10. import android.app.Activity;  
  11. import android.support.v4.widget.DrawerLayout;  
  12. import android.support.v4.widget.DrawerLayout.DrawerListener;  
  13. import android.view.Menu;  
  14. import android.view.MotionEvent;  
  15. import android.view.View;  
  16. import android.view.View.OnTouchListener;  
  17. import android.widget.ArrayAdapter;  
  18. import android.widget.ListView;  
  19. import android.widget.RelativeLayout;  
  20. import android.widget.TextView;  
  21.   
  22. public class MainActivity extends Activity {  
  23.       
  24.     private DrawerLayout drawerLayout;  
  25.     private RelativeLayout leftLayout;  
  26.     private RelativeLayout rightLayout;  
  27.     private List<ContentModel> list;  
  28.     private ContentAdapter adapter;  
  29.   
  30.     @Override  
  31.     protected void onCreate(Bundle savedInstanceState) {  
  32.         super.onCreate(savedInstanceState);  
  33.         setContentView(R.layout.activity_main);  
  34.           
  35.         drawerLayout = (DrawerLayout) findViewById(R.id.drawerlayout);  
  36.         leftLayout=(RelativeLayout) findViewById(R.id.left);  
  37.         rightLayout=(RelativeLayout) findViewById(R.id.right);  
  38.         ListView listView=(ListView) leftLayout.findViewById(R.id.left_listview);  
  39.           
  40.         initData();  
  41.         adapter=new ContentAdapter(this, list);  
  42.         listView.setAdapter(adapter);  
  43.     }  
  44.   
  45.     private void initData() {  
  46.         list=new ArrayList<ContentModel>();  
  47.           
  48.         list.add(new ContentModel(R.drawable.doctoradvice2, "新闻"));  
  49.         list.add(new ContentModel(R.drawable.infusion_selected, "订阅"));  
  50.         list.add(new ContentModel(R.drawable.mypatient_selected, "图片"));  
  51.         list.add(new ContentModel(R.drawable.mywork_selected, "视频"));  
  52.         list.add(new ContentModel(R.drawable.nursingcareplan2, "跟帖"));  
  53.         list.add(new ContentModel(R.drawable.personal_selected, "投票"));  
  54.     }  
  55.   
  56. }  

ok,就是这么简单啦!


优快云代码下载:http://download.youkuaiyun.com/detail/elinavampire/8195349

github代码下载:https://github.com/zimoguo/DrawerMode


................................................源码.....................................................................

首先看Drawerlayout,他继承自ViewGroup,这里主要看一下它里面的方法,方便以后使用

[java]  view plain copy
  1. /** 
  2.      * Listener for monitoring events about drawers. 
  3.      */  
  4.     public interface DrawerListener {  
  5.         /** 
  6.          * Called when a drawer's position changes. 
  7.          * @param drawerView The child view that was moved 
  8.          * @param slideOffset The new offset of this drawer within its range, from 0-1 
  9.          */  
  10.         public void onDrawerSlide(View drawerView, float slideOffset);  
  11.   
  12.         /** 
  13.          * Called when a drawer has settled in a completely open state. 
  14.          * The drawer is interactive at this point. 
  15.          * 
  16.          * @param drawerView Drawer view that is now open 
  17.          */  
  18.         public void onDrawerOpened(View drawerView);  
  19.   
  20.         /** 
  21.          * Called when a drawer has settled in a completely closed state. 
  22.          * 
  23.          * @param drawerView Drawer view that is now closed 
  24.          */  
  25.         public void onDrawerClosed(View drawerView);  
  26.   
  27.         /** 
  28.          * Called when the drawer motion state changes. The new state will 
  29.          * be one of {@link #STATE_IDLE}, {@link #STATE_DRAGGING} or {@link #STATE_SETTLING}. 
  30.          * 
  31.          * @param newState The new drawer motion state 
  32.          */  
  33.         public void onDrawerStateChanged(int newState);  
  34.     }  

上面主要是监听事件的接口,通常回调的时候回用到它,里面的方法有四个,分别是onDrawerSlide(View drawerView, float slideOffset);onDrawerOpened(View drawerView);onDrawerClosed(View drawerView);onDrawerStateChanged(int newState);

onDrawerSlide(View drawerView, float slideOffset)抽屉改变时使用

onDrawerOpened(View drawerView);打开抽屉

onDrawerClosed(View drawerView)关闭抽屉

onDrawerStateChanged(int newState);改变抽屉的状态

[java]  view plain copy
  1. /** 
  2.      * Set a simple drawable used for the left or right shadow. 
  3.      * The drawable provided must have a nonzero intrinsic width. 
  4.      * 
  5.      * @param shadowDrawable Shadow drawable to use at the edge of a drawer 
  6.      * @param gravity Which drawer the shadow should apply to 
  7.      */  
  8.     public void setDrawerShadow(Drawable shadowDrawable, int gravity) {  
  9.         /* 
  10.          * TODO Someone someday might want to set more complex drawables here. 
  11.          * They're probably nuts, but we might want to consider registering callbacks, 
  12.          * setting states, etc. properly. 
  13.          */  
  14.   
  15.         final int absGravity = GravityCompat.getAbsoluteGravity(gravity,  
  16.                 ViewCompat.getLayoutDirection(this));  
  17.         if ((absGravity & Gravity.LEFT) == Gravity.LEFT) {  
  18.             mShadowLeft = shadowDrawable;  
  19.             invalidate();  
  20.         }  
  21.         if ((absGravity & Gravity.RIGHT) == Gravity.RIGHT) {  
  22.             mShadowRight = shadowDrawable;  
  23.             invalidate();  
  24.         }  
  25.     }  

上面这个方法是为了设置用于左或右阴影的简单可拉伸。所提供的可拉伸必须有一个非零固有宽度。

[java]  view plain copy
  1. public void setScrimColor(int color) {  
  2.         mScrimColor = color;  
  3.         invalidate();  
  4.     }  

设置用于该掩盖的主要内容,而抽屉打开网眼织物的颜色。

[java]  view plain copy
  1. public void setDrawerLockMode(int lockMode, int edgeGravity) {  
  2.         final int absGravity = GravityCompat.getAbsoluteGravity(edgeGravity,  
  3.                 ViewCompat.getLayoutDirection(this));  
  4.         if (absGravity == Gravity.LEFT) {  
  5.             mLockModeLeft = lockMode;  
  6.         } else if (absGravity == Gravity.RIGHT) {  
  7.             mLockModeRight = lockMode;  
  8.         }  
  9.         if (lockMode != LOCK_MODE_UNLOCKED) {  
  10.             // Cancel interaction in progress  
  11.             final ViewDragHelper helper = absGravity == Gravity.LEFT ? mLeftDragger : mRightDragger;  
  12.             helper.cancel();  
  13.         }  
  14.         switch (lockMode) {  
  15.             case LOCK_MODE_LOCKED_OPEN:  
  16.                 final View toOpen = findDrawerWithGravity(absGravity);  
  17.                 if (toOpen != null) {  
  18.                     openDrawer(toOpen);  
  19.                 }  
  20.                 break;  
  21.             case LOCK_MODE_LOCKED_CLOSED:  
  22.                 final View toClose = findDrawerWithGravity(absGravity);  
  23.                 if (toClose != null) {  
  24.                     closeDrawer(toClose);  
  25.                 }  
  26.                 break;  
  27.             // default: do nothing  
  28.         }  
  29.     }  

启用或禁用了所有的抽屉互动。


其他的很少用到了,就先介绍这么多,如果上面的内容不能满足你,可以去看源码,源码是最好的老师


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值