diff --git a/samples/ApiDemos/res/menu/actions.xml b/samples/ApiDemos/res/menu/actions.xml index d148ac915..9f0440c72 100644 --- a/samples/ApiDemos/res/menu/actions.xml +++ b/samples/ApiDemos/res/menu/actions.xml @@ -18,7 +18,7 @@ android:icon="@android:drawable/ic_menu_search" android:title="@string/action_bar_search" android:showAsAction="ifRoom" - android:onClick="onSearch" /> + android:actionViewClass="android.widget.SearchView" /> @@ -30,15 +30,19 @@ android:icon="@android:drawable/ic_menu_share" android:title="@string/action_bar_share" android:showAsAction="ifRoom" /> - - + + diff --git a/samples/ApiDemos/res/values/strings.xml b/samples/ApiDemos/res/values/strings.xml index c7fdf70e4..02b6beda0 100644 --- a/samples/ApiDemos/res/values/strings.xml +++ b/samples/ApiDemos/res/values/strings.xml @@ -624,8 +624,9 @@ Add Edit Share - Zoom - Save + Sort + Alphabetically + By size App/Action Bar/Display Options DISPLAY_HOME_AS_UP diff --git a/samples/ApiDemos/src/com/example/android/apis/app/ActionBarUsage.java b/samples/ApiDemos/src/com/example/android/apis/app/ActionBarUsage.java index 698005080..a61a5827f 100644 --- a/samples/ApiDemos/src/com/example/android/apis/app/ActionBarUsage.java +++ b/samples/ApiDemos/src/com/example/android/apis/app/ActionBarUsage.java @@ -16,9 +16,14 @@ package com.example.android.apis.app; import android.app.Activity; +import android.graphics.drawable.Drawable; +import android.os.Bundle; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; +import android.widget.SearchView; +import android.widget.SearchView.OnQueryChangeListener; +import android.widget.TextView; import android.widget.Toast; import com.example.android.apis.R; @@ -29,14 +34,35 @@ import com.example.android.apis.R; * menu data itself. If you'd like to see how these things work under the hood, see * ActionBarMechanics. */ -public class ActionBarUsage extends Activity { +public class ActionBarUsage extends Activity implements OnQueryChangeListener { + TextView mSearchText; + int mSortMode = -1; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + mSearchText = new TextView(this); + setContentView(mSearchText); + } + @Override public boolean onCreateOptionsMenu(Menu menu) { MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.actions, menu); + SearchView searchView = (SearchView) menu.findItem(R.id.action_search).getActionView(); + searchView.setOnQueryChangeListener(this); return true; } + @Override + public boolean onPrepareOptionsMenu(Menu menu) { + if (mSortMode != -1) { + Drawable icon = menu.findItem(mSortMode).getIcon(); + menu.findItem(R.id.action_sort).setIcon(icon); + } + return super.onPrepareOptionsMenu(menu); + } + @Override public boolean onOptionsItemSelected(MenuItem item) { Toast.makeText(this, "Selected Item: " + item.getTitle(), Toast.LENGTH_SHORT).show(); @@ -46,7 +72,24 @@ public class ActionBarUsage extends Activity { // This method is specified as an onClick handler in the menu xml and will // take precedence over the Activity's onOptionsItemSelected method. // See res/menu/actions.xml for more info. - public void onSearch(MenuItem item) { - Toast.makeText(this, "Searching...", Toast.LENGTH_SHORT).show(); + public void onSort(MenuItem item) { + mSortMode = item.getItemId(); + // Request a call to onPrepareOptionsMenu so we can change the sort icon + invalidateOptionsMenu(); + } + + // The following callbacks are called for the SearchView.OnQueryChangeListener + // For more about using SearchView, see src/.../view/SearchView1.java and SearchView2.java + @Override + public boolean onQueryTextChanged(String newText) { + newText = newText.isEmpty() ? "" : "Query so far: " + newText; + mSearchText.setText(newText); + return true; + } + + @Override + public boolean onSubmitQuery(String query) { + Toast.makeText(this, "Searching for: " + query + "...", Toast.LENGTH_SHORT).show(); + return true; } }