DrawerLayout 抽屉效果

像这样的抽屉菜单效果,google 谷歌在2013年宣布里一个很好用的drawerlayout,操作如下:

1 XML布局:

 

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"                 
    android:layout_width="match_parent"
    android:layout_height="match_parent" 
    android:id="@+id/dl">

    <!-- 主界面 -->

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/hello_world" />
    </LinearLayout>
    <!-- 抽屉 可以滑动 -->

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_gravity="left"
        android:background="#ff0000" >
    </RelativeLayout>

</android.support.v4.widget.DrawerLayout>

2 java代码:

	private DrawerLayout dLayout;
	private ActionBarDrawerToggle drawerToggle;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		dLayout = (DrawerLayout) findViewById(R.id.dl);

		// a2 actionbar 可以显示抽屉按钮的图标
		ActionBar actionBar = getActionBar();
		actionBar.setDisplayHomeAsUpEnabled(true);
		actionBar.setHomeButtonEnabled(true);

		// a1建立抽屉和按钮间的联系
		// 抽屉在actionbar上的按钮图片
		drawerToggle = new ActionBarDrawerToggle(this, dLayout,
				R.drawable.ic_drawer_am, R.string.drawer_open,
				R.string.drawer_closed) {

			@Override
			public void onDrawerClosed(View drawerView) {
				super.onDrawerClosed(drawerView);
				Toast.makeText(MainActivity.this, "close", 0).show();
			}

			@Override
			public void onDrawerOpened(View drawerView) {
				super.onDrawerOpened(drawerView);
				Toast.makeText(MainActivity.this, "open", 0).show();
			}

		};
		dLayout.setDrawerListener(drawerToggle);
		// a3让开关和actionbar建立关系
		drawerToggle.syncState();
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		getMenuInflater().inflate(R.menu.main, menu);
		SearchView searchView = (SearchView) menu.findItem(R.id.action_search)
				.getActionView();
		searchView.setOnQueryTextListener(this);

		return true;
	}

	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		switch (item.getItemId()) {
		case R.id.action_search:
			openSearch();
			return true;
		case R.id.action_settings:
			openSettings();
			return true;
		default:
			// a4 点击actionbar 按钮图标可以打开抽屉
			return drawerToggle.onOptionsItemSelected(item)
					| super.onOptionsItemSelected(item);
		}
	}

	private void openSettings() {
		Toast.makeText(MainActivity.this, "我是 setting", 0).show();
	}

	private void openSearch() {

		Toast.makeText(MainActivity.this, "我是 search", 0).show();
	}

	// 搜索提交的时候
	@Override
	public boolean onQueryTextSubmit(String query) {
		return true;
	}

	// 当搜索的文本发生变化
	@Override
	public boolean onQueryTextChange(String newText) {
		return false;
	}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值