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

Список с разными и сложными элементами - Программирование Android

Войти
Регистрация
Восстановить пароль
Другие темы раздела
Программирование Android GreenDao ORM query метод http://www.cyberforum.ru/android-dev/thread1664122.html
Здравствуйте, использую для работы с БД GreenDao ORM и у меня возник вопрос: у меня есть вот примерно такой RecyclerView (см. картинку). Каждый item имеет свой id начиная с 0. Вопрос: как мне в зависимости от нажатого пункта (id) доставать нужную информацию с БД? Например когда кликнули на id 0 то перешли на второе Activity и с базы вытащили такое описание "Это описание id 0", кликнули на id1...
Программирование Android RSS и новостное приложение Суть:Нужно простое новостное приложние, которое грубо транслирует RSS. Скажите, как это грамотно организовать. Я начинающий и знания пока что малы. Скажите какие знания понадобятся для реализации такого приложения. Что нужно для интеграции RSS. Заранее всем очень благодарен http://www.cyberforum.ru/android-dev/thread1664086.html
Получение публикаций пользователя facebook Программирование Android
Всем привет, прошу вашей помощи, в поиске решения такой задачи: необходимо получить все публикации пользователя в facebook-е, я сделал авторизацию пользователя с помощью facebook api, все проходит успешно, но ни как не могу понять как мне получить публикации? может кто-то сталкивался с такой задачей? Я понял что это можно сделать вот таким вот способом: try { final Request request =...
Программирование Android Прочитать часть файла
Нужно открыть файл и, начиная от 4-го байта, все записать в массив byte. Такой код записывает все, но начиная с 4-го байта в массиве: InputStream is = new FileInputStream(APP_PREFERENCES_NAME); is.read(SettingsFileBytes, 4, is.available()); Пример: в файле: 0,1,2,3,4,5,6,7,8,9 в массиве должно быть: 4,5,6,7,8,9 Как это сделать?
Программирование Android Пропущенные звонки и СМС http://www.cyberforum.ru/android-dev/thread1663959.html
Я вывожу на экран количество пропущенных звонков и СМС, но информация выводятся только после 2-го пропущенного уведомления. Как я понял по логам, нумерация начинается с 0-я. Так ли это? Я не смог найти информацию об этом в документации, да и на форумах также пусто. А вот что еще интересно: если сделать так - cursor.getCount() + 1, то при очередном вызове onCreate вместо положенного количества...
Программирование Android Calendar.get(Calendar.WEEK_OF_YEAR) на разных устройствах возвращает разные значения Собственно вопрос в названии темы. Данный код возвращает разное значение на разных устройствах. Но в большинстве все таки проверка на четность правильное значение возвращает. В чем может быть проблема? public boolean evenWeek(){ Calendar cal = Calendar.getInstance(); int day = cal.get(Calendar.WEEK_OF_YEAR); boolean flag; if(day%2 == 0) flag =... подробнее

Показать сообщение отдельно
New man
37 / 28 / 8
Регистрация: 23.05.2011
Сообщений: 294
19.02.2016, 14:51  [ТС]     Список с разными и сложными элементами
Спасибо вам всем за советы.
Разобрался.
Вот годные ссылки на stackoverflow и developer.android. com
Ссылки нерабочие, так как форум рабочие ссылки зачем-то портит
stackoverflow. com/questions/28110033/recyclerview-with-different-cardlayouts
developer.android. com/intl/ru/training/material/lists-cards.html

В общем, смог реализовать список со сложными элементами и разной логикой. Привожу код, так как это может оказаться кому-нибудь полезным.

Так как RecyclerView и CardView - нестандартные, надо в dependencies в файле build.gradle (Module app) добавить
Код
    compile 'com.android.support:cardview-v7:23.0.+'
    compile 'com.android.support:recyclerview-v7:23.0.+'
Вот код элементов, которые нужно представить:
Кликните здесь для просмотра всего текста
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public abstract class Item {
    public abstract String toString();
}
 
public class Item0 extends Item {
    private String value;
    public Item0(String v){value=v;}
    @Override
    public String toString() {return value;}
}
 
public class Item1 extends Item {
    public boolean checked = false;
    public String caption;
    public Item1(String v){caption = v;}
    @Override
    public String toString() {return caption+": "+checked;}
}


Вот код xml файлов:
Кликните здесь для просмотра всего текста

Код activity
XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.user.tmp.MainActivity">
    <android.support.v7.widget.RecyclerView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/mainRecyclerView"
        android:scrollbars="vertical"
        ></android.support.v7.widget.RecyclerView>
</RelativeLayout>
Код item0.xml:
XML
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
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    android:layout_height="wrap_content"
    android:layout_margin="@dimen/activity_vertical_margin"
    android:layout_width="match_parent">
    <!-- A CardView that contains a TextView -->
    <android.support.v7.widget.CardView xmlns:card_view="http://schemas.android.com/apk/res-auto"
        android:id="@+id/card_view"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        card_view:cardCornerRadius="4dp">
 
        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
 
            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="New Text"
                android:id="@+id/textView" />
        </RelativeLayout>
    </android.support.v7.widget.CardView>
 
</LinearLayout>
Код item1.xml:
XML
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
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    android:layout_height="wrap_content"
    android:layout_margin="@dimen/activity_vertical_margin"
    android:layout_width="match_parent">
    <!-- A CardView that contains a TextView -->
    <android.support.v7.widget.CardView xmlns:card_view="http://schemas.android.com/apk/res-auto"
        android:id="@+id/card_view"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        card_view:cardCornerRadius="4dp">
 
        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
 
            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentTop="true"
                android:layout_centerHorizontal="true"
                android:text="New Text"
                android:id="@+id/textView" />
 
            <CheckBox
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_below="@id/textView"
                android:text="New CheckBox"
                android:id="@+id/checkBox" />
        </RelativeLayout>
    </android.support.v7.widget.CardView>
 
</LinearLayout>


Мой переопределенный Adapter. Именно здесь определяется, какой именно View будет в качестве элемента + связываются обработчики нажатий и всё такое.
Кликните здесь для просмотра всего текста
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
/**
 * Created by Angelicos Phosphohoros on 19.02.2016.
 */
public class MyAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
 
    private List<Item> data;
 
    public MyAdapter(List<Item> strs){
        data = strs;
    }
 
    @Override
    public int getItemCount() {
        return data.size();
    }
 
    //Переопределяем метод, так как именно результат этого метода отправляется в onCreateViewHolder
    @Override
    public int getItemViewType(int position) throws IllegalArgumentException{
        Item item = data.get(position);
        if (Item0.class.isInstance(item)) return 0;
        if (Item1.class.isInstance(item)) return 1;
        throw  new IllegalArgumentException("Unknown element");
    }
 
    @Override
    public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view;
        RecyclerView.ViewHolder vh;
        //Чтобы понять, откуда мы знаем viewType, см. getItemViewType выше
        switch (viewType){
            case 0: view= LayoutInflater.from(parent.getContext()).inflate(R.layout.item0,parent,false);
                vh = new ViewHolderZero(view);
                break;
            case 1: view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item1,parent,false);
                vh = new ViewHolderOne(view);
                break;
            default: vh = null;
        }
        return vh;
    }
 
    //Заполняем всё данными
    @Override
    public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
        if (Item0.class.isInstance(data.get(position))){
            Item0 item = (Item0)data.get(position);
            ((ViewHolderZero)holder).tv.setText(item.toString());
        }
        else{
            Item1 item = (Item1)data.get(position);
            ViewHolderOne vh1 = ((ViewHolderOne) holder);
            vh1.cb.setChecked(item.checked);
            vh1.tv.setText(item.caption);
            //В тэги закидываем наш объект из-за того, что в обработчике надо получить этот объект из кнопки
            vh1.cb.setTag(item);
            vh1.cb.setOnCheckedChangeListener(onCheckedChangeListener);
        }
    }
 
    //Два класса ViewHolder
 
    public class ViewHolderZero extends RecyclerView.ViewHolder{
        TextView tv;
        public ViewHolderZero(View v){
            super(v);
            tv = (TextView)v.findViewById(R.id.textView);
        }
    }
 
    public class ViewHolderOne extends RecyclerView.ViewHolder{
        TextView tv;
        CheckBox cb;
        public ViewHolderOne(View v){
            super(v);
            tv =(TextView)v.findViewById(R.id.textView);
            cb = (CheckBox)v.findViewById(R.id.checkBox);
        }
    }
 
    //Обработчик клика на чекбокс
    CompoundButton.OnCheckedChangeListener onCheckedChangeListener = new CompoundButton.OnCheckedChangeListener() {
        @Override
        public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
            ((Item1)buttonView.getTag()).checked = buttonView.isChecked();
        }
    };
}


Вот описание MainActivity.
Кликните здесь для просмотра всего текста
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
public class MainActivity extends AppCompatActivity {
    private Random random = new Random();
    private RecyclerView recyclerView;
    private RecyclerView.Adapter adapter;
    private RecyclerView.LayoutManager layoutManager;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        recyclerView = (RecyclerView)findViewById(R.id.mainRecyclerView);
        layoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(layoutManager);
        adapter = new MyAdapter(createData(50));
        recyclerView.setAdapter(adapter);
    }
 
    private List<Item> createData(int length){
        LinkedList<Item> ll = new LinkedList<>();
        for (int i = 0;i<length;i++){
            StringBuilder str = new StringBuilder(i);
            for (int j = 0;j<=i;j+=10)
                str.append('\n').append(j);
            if (random.nextBoolean()){
                ll.add(new Item0("ZeroType\n"+str.toString()));
            }
            else {
                ll.add(new Item1("FirstType\n"+str.toString()));
            }
        }
        return ll;
    }
}
Миниатюры
Список с разными и сложными элементами  
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru