搜索ListView

时间:2012-04-22 06:59:18

标签: android sqlite listview cursor simplecursoradapter

这是我的自定义适配器:

public View getView(int position, View convertView, ViewGroup parent) {

    View row = super.getView(position, convertView, parent);


    Cursor cursbbn  = getCursor();



    if (row == null)

    {

        LayoutInflater inflater = (LayoutInflater) localContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        row = inflater.inflate(R.layout.listtype, null);
    }


    String Title = cursbbn.getString(2);
    String Readyin = cursbbn.getString(4);
    String Faovoites=cursbbn.getString(8);


    TextView titler=(TextView)row.findViewById(R.id.listmaintitle);
    TextView readyinr=(TextView)row.findViewById(R.id.listreadyin);

     int colorPos = position % colors.length;
     row.setBackgroundColor(colors[colorPos]);

    titler.setText(Title);
    readyinr.setText(Readyin);

    ImageView picture = (ImageView) row.findViewById(R.id.imageView1);
    Bitmap bitImg = BitmapFactory.decodeResource(localContext.getResources(), R.drawable.seafood);

    if(Title.contentEquals("Fajita Raps"))
        picture.setImageBitmap(getRoundedCornerImage(bitImg));


    if (Faovoites.contentEquals("YES")) {

        ImageView star = (ImageView) row.findViewById(R.id.favoritesicon);
        star.setVisibility(View.VISIBLE);

    }

    return row;
}

这是我的Search Edittext aftertextchanged事件

public void afterTextChanged(final Editable s) {

            final String[] columns = new String[] {

            "_id", COL_SanID, COL_SanTitle, COL_SanCat, COL_SanReadyin,

            COL_SandServing, COL_SandIngred, COL_SandDirect, COL_SandFavor };

            Bundle extrass = getIntent().getExtras();

            final String Type = extrass.getString("CategoryType");

            mAdapter.setFilterQueryProvider(new FilterQueryProvider() {
                public Cursor runQuery(CharSequence constraint) {

                    String value = "%" + constraint + "%";
                    String Type2 = "%" + Type + "%";

                    curs = mDb.query(TABLE_NAME, columns, COL_SanTitle
                            + " LIKE ? And " + COL_SanCat + " LIKE ?",
                            new String[] { value, Type2 }, null, null,
                            COL_SanTitle + " ASC");

                    return curs;

                }
            });

和最后:Logcat异常

  

04-26 18:56:50.310:E / AndroidRuntime(878):致命异常:主要   04-26 18:56:50.310:E / AndroidRuntime(878):android.database.CursorIndexOutOfBoundsException:请求索引-1,大小为1   04-26 18:56:50.310:E / AndroidRuntime(878):在android.database.AbstractCursor.checkPosition(AbstractCursor.java:580)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:214)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:41)   04-26 18:56:50.310:E / AndroidRuntime(878):at master.chef.mediamaster.Interface.onItemClick(Interface.java:781)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.widget.AdapterView.performItemClick(AdapterView.java:284)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.widget.ListView.performItemClick(ListView.java:3513)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.widget.AbsListView $ PerformClick.run(AbsListView.java:1812)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.os.Handler.handleCallback(Handler.java:587)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.os.Handler.dispatchMessage(Handler.java:92)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.os.Looper.loop(Looper.java:123)   04-26 18:56:50.310:E / AndroidRuntime(878):在android.app.ActivityThread.main(ActivityThread.java:3683)   04-26 18:56:50.310:E / AndroidRuntime(878):at java.lang.reflect.Method.invokeNative(Native Method)   04-26 18:56:50.310:E / AndroidRuntime(878):at java.lang.reflect.Method.invoke(Method.java:507)   04-26 18:56:50.310:E / AndroidRuntime(878):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:839)   04-26 18:56:50.310:E / AndroidRuntime(878):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)   04-26 18:56:50.310:E / AndroidRuntime(878):at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:1)

getView()致电localCursor.moveToPosition(position);时,您会收到java.lang.IllegalStateException: attempt to re-open an already-closed object: android.database.sqlite.SQLiteQuery

为什么会这样?因为一旦过滤已应用于列表视图,则关闭旧游标并改为使用新游标。您可以通过调用getCursor()而不是跟踪初始光标来获取当前的基础光标。摆脱Cursor localCursor并改为使用getCursor()