android actionbar的簡單使用

 先來看效果圖


圖上的黑色部分是actionbar的內容。

1.如何去掉actionbar中的應用圖標和應用名稱。

protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		// requestWindowFeature(Window.FEATURE_NO_TITLE);//不顯示Actiobar

		actionBar = getActionBar();
		actionBar.setDisplayShowHomeEnabled(false);
//		actionBar.setBackgroundDrawable(getResources().getDrawable(
//				R.drawable.actionbar_bg));//修改actionbar的背景圖片
		setContentView(R.layout.activity_main);

		getOverflowMenu();

		initView();

		fragmentManager = getFragmentManager();
		if (savedInstanceState == null) {
			setTabSelect(0);
		}
	}
actionBar是我定義的一個全局變量,actionBar.setDisplayShowHomeEnabled(false);即是不顯示應用圖標的語句,應用名稱product不顯示也有類似的方法。當然我們也可對圖標和名稱進行修改,在AndroidManifest.xml配置文件中進行設置,不過我沒試,就不說了。

2.如何添加product前邊那個回退箭頭。

activity中複寫下面這個方法

// actionbar中顯示回退按鈕< 配合android.R.id.home finish();使用
	@Override
	protected void onStart() {
		// TODO Auto-generated method stub
		super.onStart();
		ActionBar actionBar = getActionBar();
		actionBar.setDisplayHomeAsUpEnabled(true);
	}
然後在onOptionsItemSelected(MenuItem item)方法中添加一個case

case android.R.id.home:

      finish();

@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		// Handle action bar item clicks here. The action bar will
		// automatically handle clicks on the Home/Up button, so long
		// as you specify a parent activity in AndroidManifest.xml.
		switch (item.getItemId()) {
		case android.R.id.home:// 當點擊回退時推出應用
			finish();
			break;

		default:
			break;
		}
		return super.onOptionsItemSelected(item);
	}
重新運行就會有back箭頭了,點擊後會退出應用.

3.其他菜單項的顯示。

3.1 在layout下的menu文件夾下新建一個.xml文件。我建的是一個名爲actionbar_menu的文件

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:id="@+id/action_serach"
        android:actionViewClass="android.widget.SearchView"
        android:icon="@drawable/serach"
        android:showAsAction="always"
        android:title="">
    </item>
    <item
        android:id="@+id/action_delete"
        android:icon="@drawable/icon_delete"
        android:showAsAction="ifRoom|withText"
        android:title="刪除">
    </item>
    <item
        android:id="@+id/action_add"
        android:icon="@drawable/icn_add"
        android:showAsAction="never"
        android:title="增加"/>
    <item
        android:id="@+id/action_setting"
        android:icon="@drawable/icon_setting"
        android:showAsAction="never"
        android:title="設置"/>

</menu>
這裏需要注意的就是第一項item所添加的actionViewClass="android.widget.SearchView" 。這個選擇項使菜單欄有了搜索欄目。

還有就是androidLshowAsAction的不同選項,never就是從不在actionbar外邊顯示,隱藏在overflow中;還有就是ifRoom,有空了顯示;always就是一直顯示

3.2,複寫 onCreateOptionsMenu(Menu menu)

@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.actionbar_menu, menu);
		return true;
	}
3.3 overflow的顯示,也就是actionbar中的三個點。

// 顯示Overflow
	private void getOverflowMenu() {
		try {
			ViewConfiguration config = ViewConfiguration.get(this);
			Field menuKeyField = ViewConfiguration.class
					.getDeclaredField("sHasPermanentMenuKey");
			if (menuKeyField != null) {
				menuKeyField.setAccessible(true);
				menuKeyField.setBoolean(config, false);
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
同時要在onCreate()中加上  getOverflowMenu();

如果還想overflow同時顯示圖片

// overflow 同時顯示圖標
		@Override
		public boolean onMenuOpened(int featureId, Menu menu) {
			// TODO Auto-generated method stub
			if (featureId == Window.FEATURE_ACTION_BAR && menu != null) {
				if (menu.getClass().getSimpleName().equals("MenuBuilder")) {
					try {
						Method m = menu.getClass().getDeclaredMethod(
								"setOptionalIconsVisible", Boolean.TYPE);
						m.setAccessible(true);
						m.invoke(menu, true);
					} catch (Exception e) {
					}
				}
			}

			return super.onMenuOpened(featureId, menu);
		}

主要就這些了,本人也是初學android的菜鳥,如有錯誤之處還請大神們指正。之所以把這些簡單東西分享出來,是因爲敲完過一段時間後找那些敲代碼好難找到,所以就乾脆記錄到博客裏,一來可以與博友分享,二來也可以在以後忘記的時候方便複習查看。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章