服务器君一共花费 7.828 ms 进行了 4 次数据库查询,努力地为您提供了这个页面。
在这个专题里面,我们重点来研究一下Android抽屉导航 NavigationDrawer。先来感性认识一下这种效果吧:
看了很多应用,觉得这种侧滑的抽屉效果的菜单很好。不用切换到另一个页面,也不用去按菜单的硬件按钮,直接在界面上一个按钮点击,菜单就滑出来,而且感觉能放很多东西。
最简单就是用官方的抽屉导航 NavigationDrawerLayout 来实现。DrawerLayout这个类是在Support Library里的,需要加上android-support-v4.jar这个包。然后程序中用时在前面导入import android.support.v4.widget.DrawerLayout;
如果找不到这个类,首先用SDK Manager更新一下Android Support Library,然后在Android SDK\extras\android\support\v4路径下找到android-support-v4.jar,复制到项目的libs路径,将其Add to Build Path.
当你新建一个 Android 项目的时候,你可以选择使用 NavigationDrawer:
我们来简要看看代码,首先是 NavigationDrawerFragment.java 这个类,加载了哪些布局文件。
02 |
public View onCreateView(LayoutInflater inflater, ViewGroup container, |
03 |
Bundle savedInstanceState) { |
05 |
mDrawerListView = (ListView) inflater.inflate( |
06 |
R.layout.fragment_navigation_drawer, container, false); |
08 |
mDrawerListView.setOnItemClickListener(newAdapterView.OnItemClickListener() { |
10 |
public void onItemClick(AdapterView<?> parent, View view, intposition, long id) { |
16 |
mDrawerListView.setAdapter(new ArrayAdapter<String>( |
17 |
getActionBar().getThemedContext(), |
18 |
android.R.layout.simple_list_item_activated_1, |
21 |
getString(R.string.title_section1), |
22 |
getString(R.string.title_section2), |
23 |
getString(R.string.title_section3), |
24 |
getString(R.string.title_section4), |
25 |
getString(R.string.title_section5), |
30 |
mDrawerListView.setItemChecked(mCurrentSelectedPosition, true); |
32 |
return mDrawerListView; |
NavigationDrawer 主要是一个 ListView,这个 ListView 使用了 fragment_navigation_drawer.xml:
3 |
android:layout_width="match_parent" |
4 |
android:layout_height="match_parent" |
5 |
android:background="@color/image_bg_green" |
6 |
android:choiceMode="singleChoice" |
7 |
android:divider="@color/image_bg_lightgreen" |
8 |
android:dividerHeight="1dp" |
9 |
tools:context="net.nowamagic.magicapp_v7.NavigationDrawerFragment" /> |
这个 ListView 就是抽屉导航直观上看到的那个 ListView。同时 ListView 里面每个格子都由一个相对布局填充,其 XML 为 fragment_main.xml:
03 |
android:layout_width="match_parent" |
04 |
android:layout_height="match_parent" |
05 |
android:paddingBottom="@dimen/activity_vertical_margin" |
06 |
android:paddingLeft="@dimen/activity_horizontal_margin" |
07 |
android:paddingRight="@dimen/activity_horizontal_margin" |
08 |
android:paddingTop="@dimen/activity_vertical_margin" |
09 |
tools:context="net.nowamagic.magicapp_v7.MainActivity$PlaceholderFragment"> |
12 |
android:id="@+id/section_label" |
13 |
android:layout_width="wrap_content" |
14 |
android:layout_height="wrap_content" /> |
新建一个基于 NavigationDrawer 的项目,大概效果如下:
当然这个 NavigationDrawerFragment.java 还有很多内容,后面再慢慢详谈。