最近在做项目中需要做一个右侧侧滑的效果,经过百度一番,准备使用DrawerLayout,Android自带的一个控件,属于V4包下的。
直接上代码
<pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/drawerLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<LinearLayout
android:id="@+id/ll_chartview"
android:layout_width="match_parent"
android:layout_height="@dimen/height_top_bar"
android:orientation="vertical" >
<RelativeLayout
android:id="@+id/top_bar"
android:layout_width="match_parent"
android:layout_height="@dimen/height_top_bar"
android:background="@color/blue"
android:gravity="center_vertical" >
<include layout="@layout/commom_back_btn" />
<TextView
android:id="@+id/name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="考勤统计"
android:textColor="#ffffff"
android:textSize="20sp" />
<RelativeLayout
android:id="@+id/container_remove"
android:layout_width="50dp"
android:layout_height="match_parent"
android:layout_alignParentRight="true"
android:background="@drawable/common_tab_bg" >
<TextView
android:id="@+id/tv_filter"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="9dp"
android:text="筛选"
android:textColor="#ffffff"
android:textSize="20sp" />
</RelativeLayout>
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#cccccc"
android:orientation="horizontal" >
<TextView
android:id="@+id/tv_year"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:gravity="center"
android:text="本年"
android:textSize="20sp" />
<TextView
android:id="@+id/tv_month"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginLeft="5dp"
android:layout_weight="1"
android:gravity="center"
android:text="本月"
android:textSize="20sp" />
<TextView
android:id="@+id/tv_week"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginLeft="5dp"
android:layout_weight="1"
android:gravity="center"
android:text="本周"
android:textSize="20sp" />
</LinearLayout>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<com.ubisys.ubisyssafety.utils.chartview.BarChart03View
android:id="@+id/bar_chart_view"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</com.ubisys.ubisyssafety.utils.chartview.BarChart03View>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerInParent="true"
android:layout_marginBottom="5dp"
android:text="学校总数(10000)"
android:textSize="10sp" />
</RelativeLayout>
</LinearLayout>
<span style="color:#ff0000;"> <LinearLayout
android:id="@+id/right"
android:layout_width="240dp"
android:layout_height="match_parent"
android:layout_gravity="right"
android:background="@android:color/white"
android:orientation="vertical" ></span>
<span style="color:#ff0000;"><LinearLayout
android:layout_width="match_parent"
android:layout_height="@dimen/height_top_bar"
android:background="@color/blue"
android:orientation="horizontal" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:layout_marginLeft="90dp"
android:layout_marginTop="15dp"
android:text="筛选"
android:textColor="#ffffff"
android:textSize="20sp" />
<TextView
android:id="@+id/tv_cancel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:paddingLeft="50dp"
android:text="取消"
android:textColor="#ffffff"
android:textSize="18sp" />
</LinearLayout>
<ListView
android:id="@+id/left_drawer"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:divider="@android:color/transparent"
android:dividerHeight="0dp" /> 红色是右侧侧滑的布局
</LinearLayout></span>
<!--
android:choiceMode 选中状态 跟itemclick没有冲突
none 值为0,表示无选择模式;
singleChoice 值为1,表示最多可以有一项被选中;
multipleChoice 值为2,表示可以多项被选中。
android:layout_gravity left或right left或start right或end 表示在抽屉里的效果是从左到右还是从右到左出现
-->
</android.support.v4.widget.DrawerLayout>
drawerLayout = (DrawerLayout) findViewById(R.id.drawerLayout); 在代码中找个这个控件的id,调用打开和关闭抽屉就可以
drawerLayout.closeDrawers(); 关闭抽屉
drawerLayout.openDrawer(GravityCompat.END); 打开抽屉
<pre name="code" class="html">@Override
public void onDrawerClosed(View arg0) {
LogUtils.showLog(TAG, "onDrawerClosed is closed-----");
}
@Override
public void onDrawerOpened(View arg0) {
LogUtils.showLog(TAG, "onDrawerOpened is opend-----");
}
@Override
public void onDrawerSlide(View arg0, float arg1) {
LogUtils.showLog(TAG, "onDrawerSlide is slide-----");
}
@Override
public void onDrawerStateChanged(int arg0) {
LogUtils.showLog(TAG, "onDrawerStateChanged is changed-----");
}
四个回调方法,看方法名称就知道什么时候调用。。