3

私は数日(実際には夜;)ウェブを検索してきましたが、現時点では問題の解決策を見つけるのに非常に行き詰まっています。基本的に私が欲しいのは、フィルターと重要なことを備えた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);
        }
4

2 に答える 2

1

テキストをフィルターするための独自のメソッドを作成しました。

/** For Filter City **/
@SuppressWarnings("deprecation")
private SimpleCursorAdapter getAdapter(String city)
{
    dbHelper.open();
    if(city.equals(null))
    {
        cityCursor = dbHelper.getComapnyArea(city);
    }
    else
    {
        cityCursor = dbHelper.getComapnyArea(city);
    }

    if (cityCursor != null) {
        String columns[] = new String[] { DatabaseHelper.CA_NAME };

        int to[] = new int[] { R.id.listTextView };

        cityAdapter = new SimpleCursorAdapter(context, R.layout.list_textview, cityCursor, columns, to);
        listView.setAdapter(cityAdapter);
    }
    dbHelper.close();

    return cityAdapter;
}

これは SearchView で次のように使用されます。

/** For Filter City **/
@SuppressWarnings("deprecation")
private SimpleCursorAdapter getAdapter(String city)
{
    dbHelper.open();
    if(city == null)
    {
        cityCursor = dbHelper.getComapnyArea();
    }
    else
    {
        cityCursor = dbHelper.getComapnyArea(city);
    }

    if (cityCursor != null) {
        String columns[] = new String[] { DatabaseHelper.CA_NAME };

        int to[] = new int[] { R.id.listTextView };

        cityAdapter = new SimpleCursorAdapter(context, R.layout.list_textview, cityCursor, columns, to);
    }

    return cityAdapter;
}
于 2013-06-04T06:27:39.480 に答える
0

あなたに役立ついくつかのこと

  1. 一貫性の問題を解決するためのローダー (またはサポートから提供されたもの)
  2. EditText で発生する更新を管理および維持するための、事前にパッケージ化されたものではなく、カスタム アダプターの完全な実装

ここで、既存のコードを修正しなければならないことがいくつかあります。

  1. データベースからロードされたデータの古いインスタンスを維持します-チェックバックするために常にそれを使用する必要があります-Collection1
  2. カスタム アダプタを通じて UI に表示される同様のコレクションを維持します。Collection2
  3. EditText のテキストが変更された場合 - (A) のエントリを削除Collection2し、新しいフィルタを使用して再作成します (b) 最新のコレクション 2 を使用してアダプタの新しいインスタンスを作成します (c) この新しいインスタンスを listView に設定します (d) をリサイクルします最適化のための古いインスタンス

これにより、更新がユーザーに対して瞬時に行われ、現在の問題や発生する可能性のある問題の解決を完全に制御できます.

于 2012-11-10T04:52:27.730 に答える