У меня есть фрагмент пользовательского интерфейса, у которого есть список checkbox view-checkbox.Этот фрагмент является частью табуляции двух вкладок, размещенных во фрагменте диалога.Фрагмент хостинга содержит кнопку, из которой собираются и используются идентификаторы / имена проверенных элементов повторного просмотра.
Я использовал зеленый робот, чтобы опубликовать список, содержащий выбранные элементы, и получил их во фрагменте хостинга на кнопке.щелкните, но я получаю NPE.
Вот моя реализация:
POJO Класс:
public class MySessionEvents {
public List<String> strings;
public MySessionEvents(List<String> strings) {
this.strings = strings;
}
public List<String> getStrings() {
return strings;
}
}
Логика адаптера:
viewholder.checkBoxSelect.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if (isChecked) {
Log.d(TAG, "Session id:\t" + sessions.prog_sessionId);
selectedSessionsList.add(sessions.prog_sessionId);
Bus.getBus().post(new MySessionEvents(selectedSessionsList));
for (int m = 0; m < selectedSessionsList.size(); m++) {
Log.d(TAG, "Session id in list:\t" + selectedSessionsList.get(m));
}
}
}
});
ивосстановить строки, я зарегистрировал и отменил регистрацию шины (пропустил код) и сделал это:
@Subscribe
public void retrieveMySessions() {
Log.d(TAG, "From event:\t" + events.getStrings());
//for (int i = 0; i < events.strings.size(); i++){
for (int i = 0; i < events.getStrings().size(); i++){
Log.d(TAG, "My Session Ids:\t" + events.strings.get(i));
}
}
Был ли я неправильно отправлять сообщения из моего адаптера, так как фрагмент вкладки имел NPE при попытке собрать проверенныйэлементы, а также мой поиск правильный?Спасибо.
РЕДАКТИРОВАТЬ: --- ДОБАВИТЬ ПАРАМЫ, ЧТОБЫ ПОДПИСАТЬСЯ НА МЕТОД ПОДПИСКИ ---
// public void retrieveMySessions(MySessionEvents events) {
@Subscribe
public void retrieveMySessions() {
Log.d(TAG, "From event:\t" + events.getStrings());
// for (int i = 0; i < events.strings.size(); i++){
for (int i = 0; i < events.getStrings().size(); i++){
Log.d(TAG, "My Session Ids:\t" + events.strings.get(i));
}
}