热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

AndroidListView数据绑定显示的三种解决方法

本篇文章小编为大家介绍,AndroidListView数据绑定显示的三种解决方法。需要的朋友参考下

首先,创建一个用于显示一个item的layout,名为item.xml

代码如下:


android:layout_
android:layout_
android:orientation="horizontal" >

android:id="@+id/name"
android:layout_
android:layout_ />

android:id="@+id/phone"
android:layout_
android:layout_ />

android:id="@+id/amount"
android:layout_
android:layout_ />



然后,在main.xml中,添加一个ListView数据显示控件,添加id名称为listview

接下来便是进行数据的绑定,总共分为三种方法:

代码如下:

 private void show1() {
  List persOns= ps.getScollData(0, 10);
  List> data = new ArrayList>();
  for (Person person : persons) {
   HashMap item = new HashMap();
   item.put("amount", person.getAmount());
   item.put("id", person.getId());
   item.put("name", person.getName());
   item.put("phone", person.getPhone());
   data.add(item);
  }
  SimpleAdapter adapter = new SimpleAdapter(getApplicationContext(),data, R.layout.item,
    new String[] { "name", "phone", "amount" }, new int[] {R.id.name, R.id.phone, R.id.amount });
          // item表示为之前定义的item.xml,表示将data集合中的每一个对象绑定到些item中,即将data中的每一项绑定到一个视图item上;
          // 后两个参数表示把结果集中哪些key的值绑定到哪些控件上;(把结果集中key为name对应的对象绑定到视图中id为name的控件上)
  listview.setAdapter(adapter);//内部处理流程如下
  // {int total = adapter.getCount();// 获取得到的数据总数
  // int perpage = 7;//获取每一页的显示条目数,
  // for (int i = 0; i   // View view = adapter.getView(i, convertView, parent);//第二次执行时会将前一次执行的view传给convertView;
  // 显示条目
  // }}
 }

 private void show2() {//此方法需要一个结果集中的Cursor,要求Cursor中需要有一个名称为_id的字段;所以添加一个获取Cursor的方法如下!
  Cursor cursor = ps.getCursorScollData(0, 10);
  SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,R.layout.item, cursor,
    new String[] { "name", "phone", "amount" }, new int[] {R.id.name, R.id.phone, R.id.amount });
  listview.setAdapter(adapter);
 }

     public Cursor getCursorScollData(int offest, int maxResult) {
  SQLiteDatabase db = dbOpenHelper.getReadableDatabase();//因为要求结果集中要有一个名为_id的字,所以SQL语句如下!
  Cursor cursor = db.rawQuery("select personid as _id,name,phone,amount from person order by personid asc limit ?,?",
      new String[] { String.valueOf(offest),String.valueOf(maxResult) });
  // db.query(table, columns, selection, selectionArgs, groupBy, having,orderBy, limit);
  return cursor;
 }

 private void show3() {
  List persOns= ps.getScollData(0, 10);// PersonAdapter见下一章节自定义适配器
  PersonAdapter adapter = new PersonAdapter(getApplicationContext(),persons, R.layout.item);
  listview.setAdapter(adapter);
 }


当每点击一项需要获取此项的相关信息时可以添加此方法:
listview.setOnItemClickListener(new ItemClickListener());

 private final class ItemClickListener implements OnItemClickListener {
  @Override//此方法中第一个参数为显示数据(item项)的控件,在此例子中即为ListView;第三个参数为点击项的位置,
  public void onItemClick(AdapterView parent, View arg1, int position,long arg3) {
   ListView lview = (ListView) parent;
   // show3()方法对应的处理方法
   // Person person = (Person) lview.getItemAtPosition(position);
   // Toast.makeText(getApplicationContext(),person.getId().toString(),1).show();

              // show2()方法对应的处理方法
              // show2方法中,adapter返回的是Cursor,
   // Cursor cursor = (Cursor) lview.getItemAtPosition(position);
   // int persOnid= cursor.getInt(cursor.getColumnIndex("_id"));
   // Toast.makeText(getApplicationContext(), personid + "", 1).show();

              // show1()方法对应的处理方法
   // show1方法中,adapter返回的是Map,再对Map进行操作取出相应的id值
   HashMap item = (HashMap) lview.getItemAtPosition(position);
   int persOnid= (Integer) item.get("id");
   Toast.makeText(getApplicationContext(), personid + "", 1).show();
  }
 }


推荐阅读
author-avatar
手机用户2502935287_564
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有