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类的代码页完全相同。
运行该代码将出现以下界面效果。