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

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

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

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

10.02.2014, 11:32. Просмотров 2660. Ответов 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, соответственно все данные будут в базе, подскажите как правильно построить адаптер для показа данных из базы, картинка при этом хранится в виде названия в базе данных.

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

Как правильно настроить Genymotion и где потом искать файлы базы данных? - Программирование Android
Здравствуйте. В проекте нужно создать базу данных. Как правильно настроить Genymotion и где потом искать файлы этой базы данных в...

Вывод из базы данных в ListView через SimpleCursorAdapter - Программирование Android
Доброе время суток. Пишу программу под Андроид в среде Android Studio и возникла проблема с выводом данных в listview через...

Адаптер и ListView - Программирование Android
Решил написать свой адаптер, работающий с listView. Беда в том, что программа вылетает сразу же. Вот код MainActivity: package...

Кастомный адаптер listView - Программирование Android
Доброго времени суток, в общем впервые столкнулся с задачей создания кастомного адаптера для listView. Нашел много примеров/статей,...

ListView и кастомный адаптер - Программирование Android
Добрый день ув. Программисты! Нашёл код который заполняет ListView с кастомным адаптером. Но вот проблема ListView создаётся...

Хочу сделать подписи к меню, меню у меня создано ListView, есть два массива, как их передать в адаптер? - Программирование Android
public class MainMenu extends ListActivity { public void onCreate(Bundle cicle) { super.onCreate(cicle); ...

21
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
11.02.2014, 12:39  [ТС] #16
Цитата Сообщение от KillAndEat Посмотреть сообщение
А так используйте дефолтный SimpleCursorAdapter
а я его изначально и использовал и проблема была такая же. для TextView все хорошо, данные выгружатся и отображаются правильно, а картинка нет. При этом картинку пробовал хранить в базе в виде пути к assets и в виде R.id.drawable - при лббом раскладе возникала ошибка что файл не найден

Добавлено через 14 минут
Вот такая ошибака выходит в логи - не понимаю как правильно сделать =(

Кликните здесь для просмотра всего текста
02-11 14:38:37.179: E/BitmapFactory(18329): Unable to decode stream: java.io.FileNotFoundException: /R.drawable.aa: open failed: ENOENT (No such file or directory)
02-11 14:38:37.179: I/System.out(18329): resolveUri failed on bad bitmap uri: R.drawable.aa
0
KillAndEat
63 / 63 / 8
Регистрация: 17.05.2013
Сообщений: 286
11.02.2014, 14:41 #17
картинки хранятся в папке drawable а не в assets. Путь к ним выглядит как R.drawable.имя картинки
0
NiRamz
211 / 211 / 16
Регистрация: 26.12.2010
Сообщений: 691
11.02.2014, 14:45 #18
картинки можно хранить и в assets, но только вот способ получения разных из этих мест.
я бы все таки посоветовал написать свой небольшой адаптер, вышло бы намного быстрее и проще. а там уже без разницы что вы передадите, массив данных или курсор - работать будет в любом случаи
0
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
11.02.2014, 14:51  [ТС] #19
Цитата Сообщение от KillAndEat Посмотреть сообщение
картинки хранятся в папке drawable а не в assets. Путь к ним выглядит как R.drawable.имя картинки
Цитата Сообщение от NiRamz Посмотреть сообщение
картинки можно хранить и в assets, но только вот способ получения разных из этих мест.
Пробовал и тот и другой способ

Цитата Сообщение от NiRamz Посмотреть сообщение
я бы все таки посоветовал написать свой небольшой адаптер, вышло бы намного быстрее и проще. а там уже без разницы что вы передадите, массив данных или курсор - работать будет в любом случаи
К сожалению не так много знаний чтобы с нуля написать адаптер - точнее могу, но столкнусь с этой же проблемой.

Я не понимаю что именно не правильно в моем случае, в базе хранятся идентификаторы R.drawable.aa - но ошибка (см выше) возникает при любом раскладе.
Помогите понять в чем проблема - когда дойдет, тогда и свой адаптер смогу написать.
Спасибо
0
KillAndEat
63 / 63 / 8
Регистрация: 17.05.2013
Сообщений: 286
11.02.2014, 15:37 #20
Проблема в том что программа не находит картинку. Может с названием какой косяк. Или типом.

Добавлено через 4 минуты
Позвольте отступление:

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")
    };
Я бы это на карту заменил
0
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
11.02.2014, 20:25  [ТС] #21
Цитата Сообщение от KillAndEat Посмотреть сообщение
Я бы это на карту заменил
на что???

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

В названии косяков нет.
0
NOSC
43 / 43 / 3
Регистрация: 10.10.2013
Сообщений: 297
18.02.2014, 15:16  [ТС] #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)


Прошу помощи, что не так делаю?
Спасибо
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.02.2014, 15:16
Привет! Вот еще темы с ответами:

Как правильно декодировать файл для показа в TextBox - Visual Basic .NET
Как правильно декодировать файл для показа в TextBox (фото прилогается + файл тоже) ?

Как правильно настроить фильтр для базы данных? - Lazarus
На Form1 установлены DBGrid1, DataSource1 и Sqlite3Dataset1, которые служат для визуализации данных. В DataModule1 установлены...

SybaseIQ : построить схему данных для базы - Базы данных
Учитывая что под sybase я раздела не нашёл создам тему здесь :) Есть SybaseIQ, на нём очень много табличек и баз, никаких схем данных в...

Как сделать правильно выборку из базы данных? - PHP БД
Привет форумчане! Я пока только учусь, так что не судите строго, но вопрос такой: У меня есть 2 страницы - одна index.php - сам...


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

Или воспользуйтесь поиском по форуму:
22
Yandex
Объявления
18.02.2014, 15:16
Ответ Создать тему
Опции темы

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