私は数日(実際には夜;)ウェブを検索してきましたが、現時点では問題の解決策を見つけるのに非常に行き詰まっています。基本的に私が欲しいのは、フィルターと重要なことを備えたSQLiteのリストビューです。リスト行の結果をSQLite行の結果と一致させることです。
私は基本的なリストビューから簡単に始めましたが、SQLite行とフィルターされたリストビューの間の一貫性を保つことができませんでした。次に、simplecursorに移動しましたが、フィルター処理された結果が得られず、完全なSQLiteリストのみが表示されています。
SimpleCursorAdapterにフィルタリングで更新するように指示する方向に何かが欠けていると思います。いくつかのコードを含むページをたくさん見つけましたが、自分のコードでそれを実装できないようです。これは次のことと関係があります:setFilterQueryProvider(私は思う)また、このSimpleCursorAdapterは廃止され、ローダーに移動することを読みましたか?これを一度に1ステップずつ取得できるので、少しの助けを借りて、このフィルタリングをローダーに移行させることができれば幸いです。
時間を割いて私のコードを読んでいただきありがとうございます。今は朝5時近くになっているので、英語がまだ大丈夫だといいのですが:)
public class MainActivity extends Activity {
String TAG = "MainActivity"; // for logging purposes
private ArrayList<String> data; // location which receives all products to display in the list
static int ProductCursorPosition; // the id which will returned by pressing the listview
private ListView listView_Products; // define the listview variabele
SimpleCursorAdapter adapter;
EditText inputSearch;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.act_main);
Log.v(TAG, "onCreate");
// Worker dbworker = new Worker(this.getApplicationContext());
// Log.v(TAG,"Open database");
// dbworker.open();
// Log.v(TAG,"Get database entry's");
// data = dbworker.getProductListView();
// dbworker.close();
}
@Override
protected void onResume() {
super.onResume();
Log.v(TAG, "onResume");
displayListView(); // show me the products in the listview
aantalbestellingen(); // update the total numbers of bread waiting in order
}
// display the listview with products
public void displayListView() {
Log.v(TAG,"Select database");
Worker dbworker = new Worker(this.getApplicationContext());
Log.v(TAG,"Open database");
dbworker.open();
String[] columns = new String[]{ Worker.KEY_ROWID, Worker.KEY_PRODUCT};
String[] from = new String[]{Worker.KEY_PRODUCT};
int [] to = {R.id.text1};
final Cursor cursor = Worker.ourDatabase.query(true, // isdistinct
Worker.DB_TABLE_PROD, // table name
columns,// select clause
null, // where cluase
null, // where clause parameters
null, // group by
null, // having
null, // nogwat
null);// limit
startManagingCursor(cursor);
adapter = new SimpleCursorAdapter(this, R.layout.lv_customlayout01, cursor, from, to);
// find the view for the listview and connect the listView_Products to it
listView_Products = (ListView) findViewById(R.id.lvProducts);
// Shows the adapter content in the listview
listView_Products.setAdapter(adapter);
dbworker.close();
/**
* Enabling Search Filter
* */
inputSearch = (EditText) findViewById(R.id.etSearchbar);
inputSearch.addTextChangedListener(new TextWatcher() {
@Override
public void onTextChanged(CharSequence cs, int arg1, int arg2, int arg3) {
// When user changed the Text
Log.v(TAG,"Filter: onTextChanged");
Log.v(TAG,"Filterstring: " + cs);
Log.v(TAG,"adapter: " + adapter);
adapter.getFilter().filter(cs);
// adapter.getFilter().filter(cs.toString());
}
@Override
public void beforeTextChanged(CharSequence arg0, int arg1, int arg2,
int arg3) {
Log.v(TAG,"Filter: beforeTextChanged");
// TODO Auto-generated method stub
}
@Override
public void afterTextChanged(Editable arg0) {
// TODO Auto-generated method stub
Log.v(TAG,"Filter: afterTextChanged");
// adapter.notifyDataSetChanged();
}
});
listView_Products.setOnItemClickListener( new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
// TODO Auto-generated method stub
Log.v(TAG, "Pressed the listview\n" +
"View arg2 = " + arg2 + "\n" +
"int arg3 = " + arg3 + "\n");
}
});
}
}
わかりました。コードを少し変更しました。これで、フィルター結果を含むリストビューが表示されます。
// display the listview with products
public void displayListView() {
Log.v(TAG,"DB select");
Worker dbworker = new Worker(this.getApplicationContext());
Log.v(TAG,"DB open");
dbworker.open();
// SQLite get cursor from Worker
final Cursor ItemCursor = Worker.cursorsetup01();
// Start managing the cursor
startManagingCursor(ItemCursor);
// Columns to be bound to the adapter
String[] FROMcolumns = new String[]{Worker.KEY_PRODUCT, Worker.KEY_INFO };
// THE XML DEFINED VIEWS WHICH THE DATA WILL BE BOUND TO
int[] ToXMLView = new int[] {R.id.tvProduct, R.id.tvProductInfo};
// CREATE THE ADAPTER USING THE CURSOR POINTING TO THE DESIRED DATA AS WELL AS THE LAYOUT INFORMATION
Log.v(TAG,"CREATE THE ADAPTER");
adapter = new SimpleCursorAdapter(this, R.layout.lv_customlayout01, ItemCursor, FROMcolumns, ToXMLView);
// find the view for the listview and connect the listView_Products to it
listView_Products = (ListView) findViewById(R.id.lvProducts);
// SET THIS ADAPTER AS YOUR LISTACTIVITY'S ADAPTER
listView_Products.setAdapter(adapter);
adapter.setFilterQueryProvider(new FilterQueryProvider() {
public Cursor runQuery(final CharSequence substring) {
String[] dbquerycolumns = new String[]{Worker.KEY_PRODUCT, Worker.KEY_INFO, Worker.KEY_ROWID };
Worker dbworker = new Worker(getApplicationContext());
Log.v(TAG,"Open database");
dbworker.open();
return Worker.ourDatabase.query(
Worker.DB_TABLE_PROD, // TABLE
dbquerycolumns,// COLUMNS
"product LIKE '%" + substring.toString() + "%'" , // SELECTION
null, // SELECTION ARGS
null, // GROUP BY
null, // HAVING
"_id LIMIT 100");// ORDER BY (limit the results to 100)
}
});
// Connect the textedit searchbar to a change listener and action upon changes
mySearchText = (EditText)findViewById (R.id.etSearchbar);
mySearchText.addTextChangedListener (new TextWatcher() {
@Override
public void afterTextChanged (Editable s) {
Log.v(TAG,"Textchanged: AfterTextChanged: " + s);
adapter.getFilter().filter(s.toString());
startManagingCursor(ItemCursor);
}