package com.pinecone.technology.mcommerce.learning.android.chapter10.search; import java.util.ArrayList; import android.app.Activity; import android.database.Cursor; import android.os.Bundle; import android.os.Handler; import android.view.View; import android.widget.AdapterView; import android.widget.ListView; import android.widget.SearchView; import android.widget.SimpleCursorAdapter; import android.widget.Toast; public class MainActivity extends Activity implements SearchView.OnQueryTextListener, SearchView.OnCloseListener { private ListView myList; private SearchView searchView; private SearchHelper mDbHelper; private MyCustomAdapter defaultAdapter; private ArrayList<String> nameList; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); nameList = new ArrayList<String>(); // for simplicity we will add the same name for 20 times to populate the // nameList view for (int i = 0; i < 20; i++) { nameList.add("Diana" + i); } // relate the listView from java to the one created in xml myList = (ListView) findViewById(R.id.list); // show the ListView on the screen // The adapter MyCustomAdapter is responsible for maintaining the data // backing this nameList and for producing // a view to represent an item in that data set. defaultAdapter = new MyCustomAdapter(MainActivity.this, nameList); myList.setAdapter(defaultAdapter); // prepare the SearchView searchView = (SearchView) findViewById(R.id.search); // Sets the default or resting state of the search field. If true, a // single search icon is shown by default and // expands to show the text field and other buttons when pressed. Also, // if the default state is iconified, then it // collapses to that state when the close button is pressed. Changes to // this property will take effect immediately. // The default value is true. searchView.setIconifiedByDefault(false); searchView.setOnQueryTextListener(this); searchView.setOnCloseListener(this); mDbHelper = new SearchHelper(this); mDbHelper.open(); // Clear all names mDbHelper.deleteAllNames(); // Create the list of names which will be displayed on search for (String name : nameList) { mDbHelper.createList(name); } } @Override protected void onDestroy() { super.onDestroy(); if (mDbHelper != null) { mDbHelper.close(); } } @Override public boolean onClose() { myList.setAdapter(defaultAdapter); return false; } @Override public boolean onQueryTextSubmit(String query) { displayResults(query + "*"); return false; } @Override public boolean onQueryTextChange(String newText) { if (!newText.isEmpty()) { displayResults(newText + "*"); } else { myList.setAdapter(defaultAdapter); } return false; } /** * Method used for performing the search and displaying the results. This * method is called every time a letter is introduced in the search field. * * @param query * Query used for performing the search */ private void displayResults(String query) { Cursor cursor = mDbHelper.searchByInputText((query != null ? query : "@@@@")); if (cursor != null) { String[] from = new String[] { SearchHelper.COLUMN_NAME }; // Specify the view where we want the results to go int[] to = new int[] { R.id.search_result_text_view }; // Create a simple cursor adapter to keep the search data SimpleCursorAdapter cursorAdapter = new SimpleCursorAdapter(this, R.layout.result_search_item, cursor, from, to); myList.setAdapter(cursorAdapter); // Click listener for the searched item that was selected myList.setOnItemClickListener(new AdapterView.OnItemClickListener() { public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // Get the cursor, positioned to the corresponding row in // the result set Cursor cursor = (Cursor) myList.getItemAtPosition(position); // Get the state's capital from this row in the database. String selectedName = cursor.getString(cursor .getColumnIndexOrThrow("name")); Toast.makeText(MainActivity.this, selectedName, 0).show(); // Set the default adapter myList.setAdapter(defaultAdapter); // Find the position for the original list by the selected // name from search for (int pos = 0; pos < nameList.size(); pos++) { if (nameList.get(pos).equals(selectedName)) { position = pos; break; } } // Create a handler. This is necessary because the adapter // has just been set on the list again and // the list might not be finished setting the adapter by the // time we perform setSelection. Handler handler = new Handler(); final int finalPosition = position; handler.post(new Runnable() { @Override public void run() { myList.setSelection(finalPosition); } }); searchView.setQuery("", true); } }); } } }