ListView
来源:互联网 发布:gtkwave windows 编辑:程序博客网 时间:2024/06/14 09:28
**
ListView的使用需要数据适配器
**
数据适配器的作用:把复杂的数据(数组、链表、数据库、集合等)填充在指定视图界面上
ArrayAdapter
ArrayAdapter: 用于绑定格式单一的数据,数据源可以是集合或数组
l
listView = (ListView)findViewById(R.id.listView); //新建适配器且添加数据源到适配器 /* * 共有3个参数 * 1.上下文 * 2.ListView子项布局的id * 3.要适配的数据*/ arr_adapter = new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,data); //视图加载适配器 listView.setAdapter(arr_adapter);
SimpleAdapter
用于绑定格式复杂的数据 数据源只能是特定泛型的集合
private SimpleAdapter simpleAdapter;private List<Map<String,Object>>dataList;private ArrayAdapter<String>arr_adapter;private String[]data = { "Apple", "Banana", "Orange", "Watermelon", "Pear","Grape","Pineapple", "Strawberry","Cherry","Mango"};private int[]img_data = {R.drawable.apple,R.drawable.banana,R.drawable.orange,R.drawable.watermelon ,R.drawable.pear,R.drawable.grape,R.drawable.pineapple,R.drawable.strawberry ,R.drawable.cherry,R.drawable.mango};
dataList = new ArrayList<Map<String, Object>>(); /* * 共有5个参数 * 1.上下文 * 2.数据源(List<? extends Map<String,?>>data)一个Map所组成的list集合 * 每一个Map都会对应ListView列表中的一行 每一个Map(键-值对)中的键必须包含所有在from中所指定的键 * 3.列表项的布局ID * 4.Map中的键名 * 5.绑定数据视图中的ID与from成对应关系*/ simpleAdapter = new SimpleAdapter(MainActivity.this,getData(),R.layout.item,new String[]{ "pic","text"},new int[]{R.id.img,R.id.name}); listView.setAdapter(simpleAdapter);
private List<Map<String,Object>> getData(){ for (int i = 0;i<data.length;i++){ Map<String,Object>map = new HashMap<String,Object>(); map.put("pic",img_data[i]); map.put("text",data[i]); dataList.add(map); } return dataList;
布局文件
<ImageView android:id="@+id/img" android:layout_marginLeft="15dp" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@mipmap/ic_launcher"/> <TextView android:id="@+id/name" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="20sp" android:text="name" android:layout_gravity="center" android:layout_marginLeft="15dp"/>
ListView的监听事件
可以用OnItemClickListener方法
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Toast.makeText(MainActivity.this,data[position],Toast.LENGTH_LONG).show(); } });
可以通过position参数确定用户点击的是哪一个子项
0 0
- listview
- listview
- listview
- ListView
- ListView
- listview
- listview
- listView
- ListView
- ListView
- ListView
- listview
- LIstView
- ListView
- listview
- ListView
- ListView
- ListView
- 通过Htmlunit操作模拟百度查询接口的填写与提交
- android源码开发之Camera添加自动对焦ListPreference,camera,key
- sublime text2 使用技巧之快捷键
- iOS开发的52个要点纪要之四
- 跨区域 Scrum 团队项目管理经验谈
- ListView
- LeetCode145——Binary Tree Postorder Traversal二叉树后序遍历
- WPF 绘正方形,支持从各个方向开始绘
- C++primer plus第六版课后编程练习答案8.4
- Python基础_继承类
- 【生活感触】:grow to be an expert
- Contains Duplicate
- Android敲诈者病毒“安卓性能激活”分析(2015年9月版)
- android异步AsyncTask