Android AppCompatActivity的ActionBar之SearchView、ShareActionProvider以及menu
Android早期推出的ActionBarActivity被Android谷歌官方廢棄,推薦使用AppCompatActivity替代ActionBarActivity。在實際的開發中現在也基本上不再怎麼使用ActionBar,而是使用最新的Toolbar替代ActionBar了,但是ActionBar也有其自身比較有特點的地方,比如ActionBar自身對SearchView,ShareActionProvider的良好支援,使得ActionBar在某些應用開發場景中依然有其用武之地。
現在給出一個例子說明如何在一個ActionBar中實作SearchView和ShareActionProvider。
先把完整的代碼實作給出,然後結合代碼加以說明。
測試用的主Activity,MainActivity.java:
package zhangphil.toolbar;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.view.MenuItemCompat;
import android.support.v4.view.MenuItemCompat.OnActionExpandListener;
import android.support.v7.app.ActionBar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.SearchView;
import android.support.v7.widget.SearchView.OnQueryTextListener;
import android.support.v7.widget.ShareActionProvider;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActionBar ab = this.getSupportActionBar();
ab.setDisplayHomeAsUpEnabled(true);
}
private Intent getMyIntent() {
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setType("text/plain");
intent.putExtra(Intent.EXTRA_SUBJECT, "主題");
intent.putExtra(Intent.EXTRA_TEXT, "我的文字内容,zhangphil text");
return intent;
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
MenuItem searchItem = menu.findItem(R.id.search);
SearchView searchView = (SearchView) MenuItemCompat.getActionView(searchItem);
searchView.setOnQueryTextListener(new OnQueryTextListener() {
@Override
public boolean onQueryTextChange(String queryText) {
Toast.makeText(getApplicationContext(), "onQueryTextChange:" + queryText, Toast.LENGTH_SHORT).show();
return true;
}
@Override
public boolean onQueryTextSubmit(String queryText) {
Toast.makeText(getApplicationContext(), "onQueryTextSubmit:" + queryText, Toast.LENGTH_SHORT).show();
return true;
}
});
OnActionExpandListener expandListener = new OnActionExpandListener() {
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
Toast.makeText(getApplicationContext(), "onMenuItemActionCollapse", Toast.LENGTH_SHORT).show();
return true;
}
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
Toast.makeText(getApplicationContext(), "onMenuItemActionExpand", Toast.LENGTH_SHORT).show();
return true;
}
};
MenuItemCompat.setOnActionExpandListener(searchItem, expandListener);
MenuItem shareItem = menu.findItem(R.id.share);
ShareActionProvider shareActionProvider = (ShareActionProvider) MenuItemCompat.getActionProvider(shareItem);
shareActionProvider.setShareIntent(getMyIntent());
return super.onCreateOptionsMenu(menu);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.share:
Toast.makeText(getApplicationContext(), "分享", Toast.LENGTH_SHORT).show();
return true;
case R.id.setting:
Toast.makeText(getApplicationContext(), "設定", Toast.LENGTH_SHORT).show();
return true;
case R.id.about:
Toast.makeText(getApplicationContext(), "關于", Toast.LENGTH_SHORT).show();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
}
在本例中,MainActivity.java不依賴任何布局檔案,隻是需要加載menu菜單,是以需要在res/menu/目錄下寫一個menu菜單的XML檔案,定義menu的item,此代碼檔案在本例中稱之為main.xml:
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools" >
<item
android:id="@+id/search"
android:title="搜尋"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="ifRoom|collapseActionView"/>
<item
android:id="@+id/share"
android:title="分享"
app:actionProviderClass="android.support.v7.widget.ShareActionProvider"
app:showAsAction="ifRoom|withText"/>
<item
android:id="@+id/setting"
android:title="設定"
app:showAsAction="never"/>
<item
android:id="@+id/about"
android:title="關于"
app:showAsAction="ifRoom"/>
</menu>
在MainActivity.java中的一個方法體中,重寫:
public boolean onCreateOptionsMenu(Menu menu);
方法将依據res/menu/main.xml檔案建立菜單。在這個方法中,為id為search的menu item建立響應搜尋事件。同時,附帶的為搜尋item綁定了展開和收縮事件:
OnActionExpandListener expandListener = new OnActionExpandListener() {
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
Toast.makeText(getApplicationContext(), "onMenuItemActionCollapse", Toast.LENGTH_SHORT).show();
return true;
}
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
Toast.makeText(getApplicationContext(), "onMenuItemActionExpand", Toast.LENGTH_SHORT).show();
return true;
}
};
MenuItemCompat.setOnActionExpandListener(searchItem, expandListener);
對于菜單中分享菜單share item,則為其設定了ShareActionProvider,提供分享事件的資料和動作支援:
MenuItem shareItem = menu.findItem(R.id.share);
ShareActionProvider shareActionProvider = (ShareActionProvider) MenuItemCompat.getActionProvider(shareItem);
shareActionProvider.setShareIntent(getMyIntent());
其他次要普通的菜單選擇事件則放在
public boolean onOptionsItemSelected(MenuItem item);
中完成。
圖1是代碼運作後,點選分享icon切換到微信的ActionBar狀态:
圖2則是點選了搜尋item時候的ActionBar狀态: