android 实现抽屉效果

android的UI开发确实是一件很有趣的事情,也是一件很有挑战性的事情。


本文章是将自己在开发中的项目中使用到的比较好的抽屉效果的原理以及代码整理后写上来的,以备忘记后可以查阅

抽屉效果的原理很简单,就是给其一个事件监听(动作),然后对此动作所作出的反应(开 or 关);

在编写代码的时候要注意的几点如下:

1、 打开抽屉的图标(即触发抽屉的把手),打开后的界面都是布局在标签中

2、在标签中设置:android:handle="@+id/handle_layout" 用来指定抽屉的把手;设置:android:content="@+id/content_layout" 用来指定打开 抽屉后的View(即抽屉里面的内容)

3、 SlidingDrawer一共有三个监听事件(见代码)

注意:三者的执行顺序,总的原则是:滑动完成后,打开(或者关闭)抽屉

执行的顺序:
1 、setOnDrawerScrollListener(给把手一个动作)
2、 setOnDrawerOpenListener(打开抽屉)或 setOnDrawerCloseListener(关闭抽屉)

下面是代码:

activity_main.xml:





    

    

        

        
    


MainActivity.java 中主要的代码如下:

package com.example.exp_sliding;

import android.os.Bundle;
import android.app.Activity;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.SlidingDrawer;
import android.widget.SlidingDrawer.OnDrawerScrollListener;

@SuppressWarnings("deprecation")
public class MainActivity extends Activity {

	private GridView gridView;
	private SlidingDrawer slidingDrawer;
	private ImageView imageView;

	private int[] icons = { R.drawable.one, R.drawable.two, R.drawable.three,
			R.drawable.four, R.drawable.five, R.drawable.six, R.drawable.seven,
			R.drawable.eight, R.drawable.nine };
	private String[] items = { "one", "two", "three", "four", "five", "six",
			"seven", "eight", "nine" };

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		gridView = (GridView) findViewById(R.id.myContent);
		slidingDrawer = (SlidingDrawer) findViewById(R.id.sd);
		imageView = (ImageView) findViewById(R.id.iv);

		// 自定义MyAdapter来实现图标加item的显示效果
		MyAdapter adapter = new MyAdapter(this, items, icons);
		gridView.setAdapter(adapter);
		
		//滑动
		slidingDrawer.setOnDrawerScrollListener(new OnDrawerScrollListener() {
			   public void onScrollStarted() {
			       System.out.println("-------->  开始滑动"); 
			   }
			   public void onScrollEnded() {
			     System.out.println("-------->  滑动结束"); 
			   }
		});
		
		//开抽屉动作响应
		slidingDrawer.setOnDrawerOpenListener(new SlidingDrawer.OnDrawerOpenListener()
				{
					@Override
					public void onDrawerOpened() {
						imageView.setImageResource(R.drawable.close1);// 响应开抽屉事件
					}
				});
		
		//关抽屉动作响应
		slidingDrawer.setOnDrawerCloseListener(new SlidingDrawer.OnDrawerCloseListener() {
					@Override
					public void onDrawerClosed() {
						imageView.setImageResource(R.drawable.open1);// 响应关抽屉事件
					}
				});
	}
}


这是一个很基础的上下开关抽屉的例子,其中涉及的MyAdapter类是一个图片的收集器,这个相信大家有一定基础的都会写这个吧,由于时间关系,在这里就不贴出来了。



你可能感兴趣的:(android 实现抽屉效果)