Форум программистов, компьютерный форум, киберфорум
Наши страницы
Программирование Android
Войти
Регистрация
Восстановить пароль
 
leonardo666
3 / 3 / 0
Регистрация: 16.09.2016
Сообщений: 141
1

Фильтрация в кастомном SimpleCursorAdapter

15.03.2017, 12:22. Просмотров 274. Ответов 1
Метки нет (Все метки)

Здравствуйте.

вот Активити

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
public class MainActivity extends AppCompatActivity {
 
    SQLiteDatabase database;
    DBHelper dbHelper;
  //  SimpleCursorAdapter scAdapter;
    ListView testList;
    TestAdapter testAdapter;
    Cursor testcursor;
    String imei;
 
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
 
        dbHelper = new DBHelper(this);
        database = dbHelper.getWritableDatabase();
 
        testList = (ListView) findViewById(R.id.testList);
 
        testcursor = database.query(DBHelper.TABLE_TEST, null, null, null, null, null, null);
      //  testcursor.close();
 
        String[] from = new String[]{DBHelper.KEY_NAME, DBHelper.KEY_ID};
        int[] to = new int[]{R.id.nm, R.id.id};
 
        // создаем адаптер и настраиваем список
        //   notesList = (ListView) findViewById(R.id.noteslistView);
 
        testAdapter = new TestAdapter(this, R.layout.testitem, testcursor, from, to, 0);
     //   scAdapter = new SimpleCursorAdapter(this, R.layout.test_item, notescursor, from, to, 0);
 
        testList.setAdapter(testAdapter);
 
        testList.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
 
 
 
      final   EditText edcrdsrch = (EditText)  findViewById(R.id.search);
 
        edcrdsrch.addTextChangedListener(new TextWatcher() {
            @Override
            public void afterTextChanged(Editable s) {
                // Прописываем то, что надо выполнить после изменения текста
 
 
            }
 
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
 
 
            }
 
            @Override
            public void onTextChanged(CharSequence s, int start, int before, int count) {
               // String text = edcrdsrch.getText().toString();
                testAdapter.getFilter().filter(s.toString());
              //  crdscAdapter.notifyDataSetChanged();
                //
                //  crdscAdapter.getFilter().filter(text);
 
 
 
            }
 
        });
 
 
        // устанавливаем провайдер фильтрации
        testAdapter.setFilterQueryProvider(new FilterQueryProvider() {
            @Override
            public Cursor runQuery(CharSequence constraint) {
 
 
 
                if (constraint == null || constraint.length() == 0) {
 
                    return
 
                            database.query("testBase", null, null, null, null, null, null);
 
 
 
                } else {
 
 
                    return
 
                            database.query("testBase", null, "name like ?", new String[]{"%"+constraint.toString()+"%"},null, null,
                                    null);
 
 
                }
 
 
            }
 
 
        });
 
 
 
    }
 
    public void nrec (View v) {
 
        SQLiteDatabase database = dbHelper.getWritableDatabase(); //орпределение разрешений для базы
        ContentValues contentValues = new ContentValues();  //клас добавление строк в таблицу
 
        EditText nmsv = (EditText) findViewById(R.id.nmEdit);
 
        contentValues.put(DBHelper.KEY_NAME, nmsv.getText().toString());
 
        database.insert(DBHelper.TABLE_TEST, null, contentValues);
        
dbHelper.close();
 
 
 
    }
 
 
   
 
 
}

Сам кастомный SimpleCursorAdapter
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
public class TestAdapter extends SimpleCursorAdapter {
 
    private LayoutInflater inflater;
    private Cursor cursor;
    //   ViewHolder holder;
    SQLiteDatabase database;
 
 
    public TestAdapter(Context context, int layout, Cursor c, String[] from, int[] to, int flags) {
        super(context, layout, c, from, to, flags);
        inflater = LayoutInflater.from(context);
 
        this.cursor=c;
 
 
    }
 
    @Override
    public Object getItem(int position) {
        return position;
    }
 
    @Override
    public long getItemId(int position) {
        return position;
    }
 
    static final class ViewHolder {
        // CheckBox crdcheckbox;
        TextView testName, test_id;
 
        int testNamecolumn, testIdCrtcolumn;
 
    }
 
    @Override
    public View newView(Context context, Cursor cursor, ViewGroup parent) {
        return super.newView(context, cursor, parent);
 
    }
 
    @Override
    public View getView(final int position, View convertView, final ViewGroup parent) {
        super.getView(position, convertView, parent);
 
        if (convertView == null) {
 
            convertView = inflater.inflate(R.layout.testitem, parent, false);
 
            ViewHolder viewHolder = new ViewHolder();
 
            viewHolder.testName = (TextView) convertView.findViewById(R.id.nm);
            viewHolder.test_id = (TextView) convertView.findViewById(R.id.id);
 
            viewHolder.testNamecolumn = cursor.getColumnIndexOrThrow("name");
            viewHolder.testIdCrtcolumn = cursor.getColumnIndexOrThrow("_id");
 
            convertView.setTag(viewHolder);
 
        }
 
        ViewHolder holder = (ViewHolder) convertView.getTag();
 
 
        cursor.moveToPosition(position);
 
        holder.testName.setText(cursor.getString(holder.testNamecolumn));
        holder.test_id.setText(cursor.getString(holder.testIdCrtcolumn));
 
     
 
        return  convertView;
    }
 
 
}
И при попытке поиска вылетает с ошибкой
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.03.2017, 12:22
Ответы с готовыми решениями:

SimpleCursorAdapter
Почему то ругаетсяв строке new SimpleCursorAdapter()... Что не так делаю? Cursor cursor =...

Получение данных с SimpleCursorAdapter
Скопировал себе в приложение пример из библиотеки шерлок, с табами. оно работает хорошо, но мне...

OnClickListner на кастомном listview
Здравствуйте такой вопрос есть кастомный список его код: <?xml version="1.0"...

SimpleCursorAdapter не хочет работать
Добрый день. Вобщем такая ситация. Нажимаю на MainActivity кнопку и по интенту грузится вторая...

SetBackgroundColor в кастомном ListView
В кастомном ListView подсвечиваю строки через setBackgroundColor() или "android:background" Если...

1
leonardo666
3 / 3 / 0
Регистрация: 16.09.2016
Сообщений: 141
15.03.2017, 12:22  [ТС] 2
[B]
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
01-04 07:39:19.365 11667-11837/? I/InputDispatcher: Delivering touch to (15925): action: 0x0, toolType: 1
01-04 07:39:19.365 15925-15925/? D/ViewRootImpl: ViewPostImeInputStage ACTION_DOWN
01-04 07:39:19.365 15925-15925/? E/SamsungIME: updateSuggestionDelay
01-04 07:39:19.395 15925-15925/? E/SamsungIME: <AbstractKeyboardView> - onDraw() called
01-04 07:39:19.405 23214-23214/com.example.filippov.myapplication D/AndroidRuntime: Shutting down VM
01-04 07:39:19.405 23214-23214/com.example.filippov.myapplication E/AndroidRuntime: FATAL EXCEPTION: main
                                                                                    Process: com.example.filippov.myapplication, PID: 23214
                                                                                    java.lang.IllegalStateException: attempt to re-open an already-closed object: SQLiteQuery: SELECT * FROM testBase
                                                                                        at android.database.sqlite.SQLiteClosable.acquireReference(SQLiteClosable.java:55)
                                                                                        at android.database.sqlite.SQLiteQuery.fillWindow(SQLiteQuery.java:58)
                                                                                        at android.database.sqlite.SQLiteCursor.fillWindow(SQLiteCursor.java:152)
                                                                                        at android.database.sqlite.SQLiteCursor.onMove(SQLiteCursor.java:124)
                                                                                        at android.database.AbstractCursor.moveToPosition(AbstractCursor.java:214)
                                                                                        at com.example.filippov.myapplication.TestAdapter.getView(TestAdapter.java:81)
                                                                                        at android.widget.AbsListView.obtainView(AbsListView.java:2828)
                                                                                        at android.widget.ListView.measureHeightOfChildren(ListView.java:1294)
                                                                                        at android.widget.ListView.onMeasure(ListView.java:1206)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1435)
                                                                                        at android.widget.LinearLayout.measureVertical(LinearLayout.java:721)
                                                                                        at android.widget.LinearLayout.onMeasure(LinearLayout.java:612)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1435)
                                                                                        at android.widget.LinearLayout.measureVertical(LinearLayout.java:721)
                                                                                        at android.widget.LinearLayout.onMeasure(LinearLayout.java:612)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.support.constraint.ConstraintLayout.internalMeasureChildren(ConstraintLayout.java:934)
                                                                                        at android.support.constraint.ConstraintLayout.onMeasure(ConstraintLayout.java:973)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.widget.FrameLayout.onMeasure(FrameLayout.java:436)
                                                                                        at android.support.v7.widget.ContentFrameLayout.onMeasure(ContentFrameLayout.java:139)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.support.v7.widget.ActionBarOverlayLayout.onMeasure(ActionBarOverlayLayout.java:393)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.widget.FrameLayout.onMeasure(FrameLayout.java:436)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1435)
                                                                                        at android.widget.LinearLayout.measureVertical(LinearLayout.java:721)
                                                                                        at android.widget.LinearLayout.onMeasure(LinearLayout.java:612)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5908)
                                                                                        at android.widget.FrameLayout.onMeasure(FrameLayout.java:436)
                                                                                        at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:3076)
                                                                                        at android.view.View.measure(View.java:18926)
                                                                                        at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2411)
                                                                                        at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1429)
                                                                                        at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1677)
                                                                                        at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1314)
                                                                                        at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7057)
                                                                                        at android.view.Choreographer$CallbackRecord.run(Choreographer.java:829)
                                                                                        at android.view.Choreographer.doCallbacks(Choreographer.java:606)
                                                                                        at android.view.Choreographer.doFrame(Choreographer.java:576)
                                                                                        at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:815)
                                                                                        at android.os.Handler.handleCallback(Handler.java:739)
                                                                                        at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                                        at android.os.Looper.loop(Looper.java:145)
                                                                                        at android.app.ActivityThread.main(ActivityThread.java:7007)
                                                                                        at java.lang.reflect.Method.invoke(Native Method)
                                                                                        at java.lang.reflect.Method.invoke(Method.java:372)
                                                                                        at com.android.intern
01-04 07:39:19.405 11667-12797/? W/ActivityManager:   Force finishing activity 1 com.example.filippov.myapplication/.MainActivity
указывая на cursor.moveToPosition(position);

Я примерно понимаю что попытка открытия уже закрытого курсора, но что делать с этим не знаю.
Все тоже но со стандартным адаптером работает.

Помогите если можно.
0
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.03.2017, 12:22

Прикрутить RadioGroup к ListView(SimpleCursorAdapter)
Не могу понять как реализовать одиночный выбор из списка: Сейчас выводит список компаний, где я...

Каков новый аналог устаревшего SimpleCursorAdapter?
SimpleCursorAdapter устарел уже(deprecated) что лучше использовать вместо него какой есть более...

Поиск по ListView основанному на кастомном адаптере
Есть кастомный адаптер. ListView сделан на его основе. Данные загружаются из БД. Делаю поиск по...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.