SimpleAdapter не показывает данные в графическом интерфейсе
Это первое приложение для Android, которое я пишу для колледжа, в котором я работаю. Это в основном тонкий клиент, который читает данные из XML на сайте и распечатывает их в список. Я столкнулся со странной проблемой, хотя и мог бы помочь. EventsListActivity читает XML-файл из файла, помещает его в массив HashMaps, сортирует и помещает в SimpleAdapter. Я использую этот же код для моей DirectoryListActivity, и он работает просто отлично. Однако EventsListActivity отображает только пустой список с 1 строкой. В этой строке при щелчке отобразятся правильные данные, и в файле xml есть только 1 строка, так что это не проблема. Однако TextView в строке ничего не отображает.
Я прошел через код, и XML читается и хранится правильно. Просто кажется, что есть проблема с привязкой SimpleAdapter. Буду очень признателен за любые советы, и не стесняйтесь указывать мне, если вы увидите некоторые более полезные вещи, которые я мог бы сделать в своем коде. Вот необходимая информация:
public class KCCEventsListActivity extends ListActivity {
public static final ArrayList<HashMap<String, String>> eventsList = new ArrayList<HashMap<String, String>>();
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.customlist);
SimpleAdapter adapter = new SimpleAdapter(KCCEventsListActivity.this, eventsList, R.layout.customrow, new String[] {"summary", "date"}, new int[] {R.id.tvHeading, R.id.tvSubheading});
if (eventsList.isEmpty()) {
getEvents();
}
KCCEventsListActivity.this.setListAdapter(adapter);
}
@Override
protected void onListItemClick(ListView lv, View v, int position, long id) {
super.onListItemClick(lv, v, position, id);
HashMap<String, String> event = eventsList.get(position);
Toast.makeText(KCCEventsListActivity.this, event.get("date"), Toast.LENGTH_LONG).show();
//Call AddtoCalendar Intent
}
protected void getEvents() {
try {
URL url = new URL(getString(R.string.KccEventsAddress));
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document doc = db.parse(new InputSource(url.openStream()));
doc.getDocumentElement().normalize();
NodeList nodeList = doc.getElementsByTagName("EventItem");
for (int i=0; i < nodeList.getLength(); i++) {
Node node = nodeList.item(i);
Element element = (Element)node;
HashMap<String, String> entry = new HashMap<String, String>();
NodeList titleList = element.getElementsByTagName("Summary");
Element titleElement = (Element)titleList.item(0);
titleList = titleElement.getChildNodes();
entry.put("summary", titleList.item(0).getNodeValue());
NodeList dateList = element.getElementsByTagName("StartTime");
Element dateElement = (Element)dateList.item(0);
dateList = dateElement.getChildNodes();
entry.put("date", dateList.item(0).getNodeValue());
NodeList orderList = element.getElementsByTagName("Seconds");
Element orderElement = (Element)orderList.item(0);
orderList = orderElement.getChildNodes();
entry.put("order", orderList.item(0).getNodeValue());
eventsList.add(entry);
}
Comparator<HashMap<String, String>> comparator = new Comparator<HashMap<String, String>>() {
public int compare(HashMap<String, String> object1, HashMap<String, String> object2)
{
return object1.get("order").compareToIgnoreCase(object2.get("order"));
}
};
Collections.sort(eventsList, comparator);
} catch (Exception e) {
Toast.makeText(this, e.getMessage(), Toast.LENGTH_LONG).show();
}
}
}
CUSTOMLIST.XML
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<ListView android:id="@id/android:list"
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"></ListView>
<TextView android:id="@id/android:empty" android:layout_width="match_parent" android:layout_height="match_parent" android:text="No data" />
</LinearLayout>
CUSTOMROW.XML
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<TextView android:id="@+id/tvHeading" android:layout_width="wrap_content" android:layout_height="26dip" android:layout_alignParentTop="true" android:textSize="20sp" />
<TextView android:id="@+id/tvSubheading" android:layout_width="wrap_content" android:layout_height="22dip" android:layout_below="@id/tvHeading" android:textSize="16sp" />
</RelativeLayout>
3 ответа
Пройдя несколько раз по коду, я, наконец, переписал веб-сервис для печати другого стиля xml. Это заставило код работать отлично. По какой-то причине ранее использованный XML-файл вызывал некорректную работу дисплея. Хотел бы я иметь больше информации о том, почему это произошло. Спасибо за ответы.
Может быть, попробовать заменить эти строки?
SimpleAdapter adapter = new SimpleAdapter(KCCEventsListActivity.this, eventsList, R.layout.customrow, new String[] {"summary", "date"}, new int[] {R.id.tvHeading, R.id.tvSubheading});
KCCEventsListActivity.this.setListAdapter(adapter);
для этих строк:
SimpleAdapter adapter = new SimpleAdapter(this, eventsList, R.layout.customrow, new String[] {"summary", "date"}, new int[] {R.id.tvHeading, R.id.tvSubheading});
setListAdapter(adapter)
Вы пробовали либо заполнить HashMap перед созданием адаптера, либо вызывать
adapter.notifyDataSetChanged()
Адаптер должен проверяться при обновлении данных поддержки.