1. ActionBar下拉列表概述
可以提供不同模式供用户方便选择
适用范围:当内容改变很重要,但是不是很频繁的时候(频繁的话用tab)
2. ActionBar下拉列表创建步骤
1). 创建SpinnerAdapter,来提供下拉列表的内容
2). 实现ActionBar.OnNavigationListener接口,响应用户点击列表项时
3). 通过setNavigationMode(NAVIGATION_MODE_LIST)来激活此项功能
4). 设置下拉列表的回调
3. 示例
可以提供不同模式供用户方便选择
适用范围:当内容改变很重要,但是不是很频繁的时候(频繁的话用tab)
2. ActionBar下拉列表创建步骤
1). 创建SpinnerAdapter,来提供下拉列表的内容
2). 实现ActionBar.OnNavigationListener接口,响应用户点击列表项时
3). 通过setNavigationMode(NAVIGATION_MODE_LIST)来激活此项功能
4). 设置下拉列表的回调
actionBar.setListNavigationCallbacks(mSpinnerAdapter, mNavigationCallback);
3. 示例
package com.wind.actionbar;
import android.annotation.SuppressLint;
import android.app.ActionBar;
import android.app.ActionBar.OnNavigationListener;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentTransaction;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.SpinnerAdapter;
import android.widget.TextView;
@SuppressLint("ValidFragment")
public class HelloActionBarActivity extends Activity{
private static final String TAG = "HelloActionBarActivity";
public final static int TAB_INDEX_1 = 0;
public final static int TAB_INDEX_2 = 1;
public final static int TAB_INDEX_3 = 2;
public final static int TAB_COUNT = 3;
private ActionBar actionBar;
private OnNavigationListener mOnNavigationListener;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.v(TAG, "onCreate");
setContentView(R.layout.main);
actionBar = getActionBar();
//设置AcitonBar的操作模型
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_LIST);
SpinnerAdapter mSpinnerAdapter = ArrayAdapter.createFromResource(this, R.array.action_list,
android.R.layout.simple_spinner_dropdown_item);
mOnNavigationListener = new OnNavigationListener() {
// Get the same strings provided for the drop-down's ArrayAdapter
String[] strings = getResources().getStringArray(R.array.action_list);
@Override
public boolean onNavigationItemSelected(int position, long itemId) {
// Create new fragment from our own Fragment class
ListContentFragment newFragment = new ListContentFragment();
FragmentTransaction ft = getFragmentManager().beginTransaction();
// Replace whatever is in the fragment container with this fragment
// and give the fragment a tag name equal to the string at the position selected
ft.replace(R.id.context, newFragment, strings[position]);
// Apply changes
ft.commit();
return true;
}
};
actionBar.setListNavigationCallbacks(mSpinnerAdapter, mOnNavigationListener);
}
public class ListContentFragment extends Fragment{
private String mText;
@Override
public void onAttach(Activity activity) {
// This is the first callback received; here we can set the text for
// the fragment as defined by the tag specified during the fragment transaction
super.onAttach(activity);
mText = getTag();
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// This is called to define the layout for the fragment;
// we just create a TextView and set its text to be the fragment tag
TextView text = new TextView(getActivity());
text.setText(mText);
return text;
}
}
}