ActionBar除可提供Tab导航支持之外,还提供了下拉式(DropDown)导航方式。下拉式导航的ActionBar在顶端生成下拉列表框,当用户单击某个列表项时,系统根据用户单击事件导航指定Fragment。
为了使用ActionBar实现Tab导航,按如下步骤进行即可。
- 调用ActionBar的actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST)方法设置使用下拉列表的导航方式。
- 调用ActionBar的setListNavigationCallbacks(SpinnerAdapter adapter,ActionBar.OnNavigationListenter callback)()添加多个列表项,并为每个列表项设置事件监听器。其中第一个参数Adapter负责提供多个列表项,第二个参数为事件监听器。
实例:ActionBar结合Fragment实现下拉式导航
下面的实例的布局文件与前面介绍的Tab导航实例的布局文件完全相同。
该布局文件如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" > </LinearLayout>
该Activity的Java代码如下:
package org.crazyit.helloworld; import android.os.Bundle; import android.app.ActionBar; import android.app.ActionBar.OnNavigationListener; import android.app.Activity; import android.app.Fragment; import android.app.FragmentTransaction; import android.view.Menu; import android.widget.ArrayAdapter; public class ActionBar_DropDownNav extends Activity implements OnNavigationListener { private static final String SELECTED_ITEM="selected_item"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.action_bar__drop_down_nav); final ActionBar actionBar=getActionBar(); //设置ActionBar是否显示标题 actionBar.setDisplayShowTitleEnabled(true); //设置导航模式,使用List导航 actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST); //为actionBar安装ArrayAdapter actionBar.setListNavigationCallbacks(new ArrayAdapter<String>(ActionBar_DropDownNav.this,android.R.layout.simple_list_item_1 ,android.R.id.text1,new String[]{"第一页","第二页","第三页"}), this); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.action_bar__drop_down_nav, menu); return true; } @Override protected void onSaveInstanceState(Bundle outState) { // TODO Auto-generated method stub //super.onSaveInstanceState(outState); //将当前选中的Fragmnet页的索引保存到Bundle中 outState.putInt(SELECTED_ITEM, getActionBar().getSelectedNavigationIndex()); } @Override protected void onRestoreInstanceState(Bundle savedInstanceState) { // TODO Auto-generated method stub //super.onRestoreInstanceState(savedInstanceState); if(savedInstanceState.containsKey(SELECTED_ITEM)) { //选中前面保存的索引对应的Fragment页 getActionBar().setSelectedNavigationItem(savedInstanceState.getInt(SELECTED_ITEM)); } } //当导航项被选中时激发该方法 @Override public boolean onNavigationItemSelected(int position, long itemId) { //创建一个新的Fragment对象 Fragment fragment=new DummyFragment(); //创建一个Bundle对象,用于向Fragment传入参数 Bundle args=new Bundle(); args.putInt(DummyFragment.ARG_SECTION_NUMBER,position+1); //向fragment传入参数 fragment.setArguments(args); //获取FragmentTransaction对象 FragmentTransaction ft=getFragmentManager().beginTransaction(); //使用fragment代替该Activity中的container组件 ft.replace(R.id.container, fragment); //提交事务 ft.commit(); // TODO Auto-generated method stub return true; } }
上面程序中第一段粗体字代码就是为ActionBar启用下拉导航支持的关键代码,这段代码做了上面介绍的两件事情:先调用ActionBar的setNavigationMode(ActionBar.NAVIGATION_MODE_LIST)启用下拉列表导航支持;然后为ActionBar传入ArrayAdapter(当然也可以使用SimpleAdapter或扩展BaseAdapter的对象)和监听器即可。
当用户选中指定的导航项时,将会激发该监听器的onNavigationItemSelected(),该方法的处理逻辑与前面Tab导航实例中的onTabSelected()处理方法的处理逻辑完全相同,该实例所使用的DummyFragment与前面的Fragment类的代码页完全相同。
运行该代码将出现以下界面效果。