使用ActionBar实现下拉式导航

      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类的代码页完全相同。

     运行该代码将出现以下界面效果。

    

原文地址:https://www.cnblogs.com/wolipengbo/p/3402320.html