Design Support Library (I): Navigation View
Google I/O 2015 给 Android 开发者提供了一整套新工具,让 Android 开发更容易。 我会完成一个系列文章来介绍超级实用的 Design Support Library.
Github 上已经有一个很好的使用示例,不过我会通过完成一个App, 深入讲解每一个新特性。
在这次的文章中,我们先介绍 Navigation View。Material Design 发布以来, 我们只是知道 Navigation Drawer 应该长什么样。
想要完成自己实现一个又不是很容易。不过现在我们有了 navigation view, 这个工作就很轻松了。
你应该用它替换你之前 Drawer Layout 中自定义 View 的位置。 Navigation View 可以接受一些参数,一个可选的 header layout, 还有一个用来构建导航选项的 menu。然后你只需添加事件监听器就可以了。
首先,创建 menu。很简单,创建一个 group,设置同时只有一个 item 能被选中。
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<group
android:checkableBehavior="single">
<item
android:id="@+id/drawer_home"
android:checked="true"
android:icon="@drawable/ic_home_black_24dp"
android:title="@string/home"/>
<item
android:id="@+id/drawer_favourite"
android:icon="@drawable/ic_favorite_black_24dp"
android:title="@string/favourite"/>
...
<item
android:id="@+id/drawer_settings"
android:icon="@drawable/ic_settings_black_24dp"
android:title="@string/settings"/>
</group>
</menu>
理论上,你也可以像下面这样,在每个 item 中添加子 menu 实现带有分类的选项块:
<item
android:id="@+id/section"
android:title="@string/section_title">
<menu>
<item
android:id="@+id/drawer_favourite"
android:icon="@drawable/ic_favorite_black_24dp"
android:title="@string/favourite"/>
<item
android:id="@+id/drawer_downloaded"
android:icon="@drawable/ic_file_download_black_24dp"
android:title="@string/downloaded"/>
</menu>
</item>
这样会创建一个 divider 和 header,然后把 items 加到它的正下方。然而这样我们就没办法 判断哪个 item 被选中了。如果日后我知道怎样做我会更新这部分的。不过,我还是鼓励你去尝试 看看它的效果。
现在,我们可以把 navigation view 加到我们的 activity layout 里了,设置好 menu 和 header layout。 Header 可以是任意 view ,所以这里不做过多介绍,你可以到 Github 查看 header 部分代码。
<android.support.v4.widget.DrawerLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context=".MainActivity">
<FrameLayout
android:id="@+id/content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
...
</FrameLayout>
<android.support.design.widget.NavigationView
android:id="@+id/navigation_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
app:headerLayout="@layout/drawer_header"
app:menu="@menu/drawer"/>
</android.support.v4.widget.DrawerLayout>
接下来看看 Java 代码部分。首先你要启用 home as up
:
final Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
final ActionBar actionBar = getSupportActionBar();
if (actionBar != null) {
actionBar.setHomeAsUpIndicator(R.drawable.ic_menu_black_24dp);
actionBar.setDisplayHomeAsUpEnabled(true);
}
然后初始化 navigation drawer。当一个 item 被选中时,显示一个 Snackbar
(我会在下篇文章中介绍它),
选中被点击的 item,关闭 drawer:
drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
NavigationView view = (NavigationView) findViewById(R.id.navigation_view);
view.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
@Override public boolean onNavigationItemSelected(MenuItem menuItem) {
Snackbar.make(content, menuItem.getTitle() + " pressed", Snackbar.LENGTH_LONG).show();
menuItem.setChecked(true);
drawerLayout.closeDrawers();
return true;
}
});
最后,在 menu action 按下时打开 drawer :
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
drawerLayout.openDrawer(GravityCompat.START);
return true;
}
return super.onOptionsItemSelected(item);
}
创建一个满足 Material 设计准则的 navigation drawer 是如此简单!感谢 design support library 。 下篇文章会继续介绍其他好用的新控件。你可以到这(Github)查看我们所有的代码 。
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8