Форум программистов, компьютерный форум CyberForum.ru

Программирование Android

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 19, средняя оценка - 4.89
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
#1

Как правильно построить адаптер для показа данных из базы в ListView - Android

10.02.2014, 11:32. Просмотров 2474. Ответов 21
Метки нет (Все метки)

Всем привет.
На данный момент все данные в программе хранятся в классе, есть адаптер для отображения данных в ListView:
Java
1
2
ArtsAdapter adapter = new ArtsAdapter(this, 
                R.layout.listview_item_row, Data.data_list);
Соответственно данные для адаптера в классе Data:
Java
1
2
3
4
5
6
final static Arts data_list[] = new Arts[] {
                    new Arts(R.drawable.aa, "item0"),
                    new Arts(R.drawable.ab, "item1"),
                    new Arts(R.drawable.ac, "item2"),
                    new Arts(R.drawable.ad, "item3")
    };
На данный момент перевожу программу на SQLite, соответственно все данные будут в базе, подскажите как правильно построить адаптер для показа данных из базы, картинка при этом хранится в виде названия в базе данных.

Если можно - покажите пример кода или ссылку на подоюный проект.
Спасибо
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.02.2014, 11:32     Как правильно построить адаптер для показа данных из базы в ListView
Посмотрите здесь:

Android Как создать адаптер для Gallery?
Android Передать данные из базы в ListView
Как правильно обновить данные для списка при изменении данных в другом фрагменте? Android
ListView и кастомный адаптер Android
Android Хочу сделать подписи к меню, меню у меня создано ListView, есть два массива, как их передать в адаптер?
Копирование данных из 1 listView во 2 listView Android
Способы хранения данных для expandable listview Android
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
11.02.2014, 20:25  [ТС]     Как правильно построить адаптер для показа данных из базы в ListView #21
Цитата Сообщение от KillAndEat Посмотреть сообщение
Я бы это на карту заменил
на что???

Это старая схема, когда в классе хранился отдельно массив для ListView, массив для заголовка и так далее. Я как раз и хочу от этого уйти.

В названии косяков нет.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.02.2014, 15:16     Как правильно построить адаптер для показа данных из базы в ListView
Еще ссылки по теме:

Адаптер и ListView Android
Android Your content must have a ListView whose id attribute is 'android.R.id.list' - как правильно создать адаптор ?
Android Как правильно настроить Genymotion и где потом искать файлы базы данных?
Вывод из базы данных в ListView через SimpleCursorAdapter Android
Загрузка данных из SQLite для каждого пункта ListView Android

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

Или воспользуйтесь поиском по форуму:
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
18.02.2014, 15:16  [ТС]     Как правильно построить адаптер для показа данных из базы в ListView #22
Прошу помощи!
Вот мой MyCursorAdapter:
Кликните здесь для просмотра всего текста
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
public class MyCursorAdapter extends SimpleCursorAdapter implements ViewBinder {
        private Context mContext;
 
        @SuppressWarnings("deprecation")
        public MyCursorAdapter(Context context, int layout, Cursor c, String[] from, int[] to) {
            super(context, layout, c, from, to);
            mContext = context;
            //Устанавливаем самого себя в качестве обработчика-ViewBinder'а
            setViewBinder(this);
        }
 
        @Override
        public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
            if (columnIndex == Integer.valueOf(DataBase.COLUMN_ID)) {
                try {
                    InputStream photoStream = mContext.getAssets().open(cursor.getString(columnIndex));
                    Bitmap photo = BitmapFactory.decodeStream(photoStream);
                    ((ImageView)view).setImageBitmap(photo);
                    return true;
                } catch (IOException e) {
                    e.printStackTrace();
                }
                return false;
            }
            return false;
        }
        
    }

Вот мой DataBase:
Кликните здесь для просмотра всего текста
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
public class DataBase extends SQLiteAssetHelper {
 
        private static final String DATABASE_NAME = "base.db";
        private static final int DATABASE_VERSION = 1;
 
        public static final String COLUMN_ID = "_id";
        public static final String COLUMN_IMG = "pic";
        public static final String COLUMN_TXT = "name";
        public static final String COLUMN_PRE = "paragraph";
 
    public DataBase(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
 
 
    }
    
 
 
    public Cursor getArt() {
 
        SQLiteDatabase db = getWritableDatabase();
        SQLiteQueryBuilder qb = new SQLiteQueryBuilder();
        String sqlTables = "articles_ru";
        String [] sqlSelect = {"0 _id", "name", "pic", "paragraph"}; 
        
 
        qb.setTables(sqlTables);
        Cursor c = qb.query(db, sqlSelect, null, null,
                null, null, null);
 
        c.moveToFirst();
        return c;
 
    }
    
 
}


Когда дело доходит до:
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
String[] from = new String[] { DataBase.COLUMN_IMG, DataBase.COLUMN_TXT, DataBase.COLUMN_PRE };
        int[] to = new int[] { R.id.imgIcon, R.id.txtTitle, R.id.pre };
        
        
        cursor = db.getArt();
        startManagingCursor(cursor);
        scAdapter = new MyCursorAdapter(this, R.layout.listview_item_row, cursor, from, to);
        // присваиваем адаптер списку
        lvMain.setAdapter(scAdapter);


Получаю ошибку:
Кликните здесь для просмотра всего текста
02-18 17:14:36.813: E/AndroidRuntime(21066): FATAL EXCEPTION: main
02-18 17:14:36.813: E/AndroidRuntime(21066): java.lang.NumberFormatException: Invalid int: "_id"
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.Integer.invalidInt(Integer.java:138)
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.Integer.parse(Integer.java:375)
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.Integer.parseInt(Integer.java:366)
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.Integer.parseInt(Integer.java:332)
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.Integer.valueOf(Integer.java:490)
02-18 17:14:36.813: E/AndroidRuntime(21066): at com.site.myapp.MyCursorAdapter.setViewValue(MyCursorAdapter.java:28)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.SimpleCursorAdapter.bindView(SimpleCursorAdapter.java:146)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.CursorAdapter.getView(CursorAdapter.java:250)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.AbsListView.obtainView(AbsListView.java:2159)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.ListView.makeAndAddView(ListView.java:1831)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.ListView.fillDown(ListView.java:674)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.ListView.fillFromTop(ListView.java:735)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.ListView.layoutChildren(ListView.java:1652)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.AbsListView.onLayout(AbsListView.java:1994)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.View.layout(View.java:14008)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewGroup.layout(ViewGroup.java:4373)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1663)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1521)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.LinearLayout.onLayout(LinearLayout.java:1434)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.View.layout(View.java:14008)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewGroup.layout(ViewGroup.java:4373)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.FrameLayout.onLayout(FrameLayout.java:448)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.View.layout(View.java:14008)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewGroup.layout(ViewGroup.java:4373)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1663)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1521)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.LinearLayout.onLayout(LinearLayout.java:1434)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.View.layout(View.java:14008)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewGroup.layout(ViewGroup.java:4373)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.widget.FrameLayout.onLayout(FrameLayout.java:448)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.View.layout(View.java:14008)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewGroup.layout(ViewGroup.java:4373)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:1892)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1711)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:989)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4351)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.Choreographer.doCallbacks(Choreographer.java:562)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.Choreographer.doFrame(Choreographer.java:532)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.os.Handler.handleCallback(Handler.java:725)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.os.Handler.dispatchMessage(Handler.java:92)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.os.Looper.loop(Looper.java:137)
02-18 17:14:36.813: E/AndroidRuntime(21066): at android.app.ActivityThread.main(ActivityThread.java:5226)
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.reflect.Method.invokeNative(Native Method)
02-18 17:14:36.813: E/AndroidRuntime(21066): at java.lang.reflect.Method.invoke(Method.java:511)
02-18 17:14:36.813: E/AndroidRuntime(21066): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
02-18 17:14:36.813: E/AndroidRuntime(21066): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
02-18 17:14:36.813: E/AndroidRuntime(21066): at dalvik.system.NativeStart.main(Native Method)


Прошу помощи, что не так делаю?
Спасибо
Yandex
Объявления
18.02.2014, 15:16     Как правильно построить адаптер для показа данных из базы в ListView
Ответ Создать тему
Опции темы

Текущее время: 15:05. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru