项目步骤

  1. 声明listView控件并获取显示的视图
  2. 获取显示的数据
  3. 设置显示的adapter
  4. 注冊点击事件

详细案例

实现效果:

查找的方法

public List<Map<String, Object>> getData() {
SQLiteDatabase db = dh.getWritableDatabase();
List<Map<String, Object>> data = new ArrayList<Map<String, Object>>();
Cursor c = db
.rawQuery(
"select userid ,username,userage,usersalary,userphone from users",
null); while (c.moveToNext()) {
Map<String, Object> map = new HashMap<String, Object>();
map.put("id", c.getInt(c.getColumnIndex("userid")));
map.put("name", c.getString(c.getColumnIndex("username")));
map.put("age", c.getInt(c.getColumnIndex("userage")));
map.put("phone", c.getString(c.getColumnIndex("userphone")));
data.add(map);
}
db.close();
return data;
}

布局文件

同BaseAdapter的布局文件activity_main.xml

ArrayAdapter实现类(主程序)

package com.example.android_sqlite;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import android.app.Activity;
import android.database.Cursor;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast; import com.example.android_sqlite.dao.impl.UserDaoImpls;
import com.example.android_sqlite.database.DatabaseHelper; /**
* SimpleAdapter
*
* @author zhaoyazhi
*
*/
public class MainActivity extends Activity implements OnItemClickListener {
private ListView lv_users;// 视图层 // model层 相关的对象的声明
private DatabaseHelper dh;
private UserDaoImpls userDao; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); // 模型层
dh = new DatabaseHelper(this);// 创建数据库
userDao = new UserDaoImpls(dh);// 获取显示数据 model
List<Map<String, Object>> data = userDao.getData();// 查询获取数据 // 控制层 依赖于模型层
SimpleAdapter adapter = new SimpleAdapter(this, data,
R.layout.item_phone, new String[] { "name", "phone", "id",
"age" }, new int[] { R.id.tv_name, R.id.tv_phone,
R.id.tv_id, R.id.tv_age }); // 视图层 依赖于控制层
lv_users = (ListView) findViewById(R.id.lv_users);
lv_users.setAdapter(adapter); // 注冊点击事件
lv_users.setOnItemClickListener(this); } @Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long arg3) { // 获取点击我的数据
Toast.makeText(this, parent.getItemAtPosition(position) + "", 0).show(); } }

最新文章

  1. 开发微信App支付
  2. Python自动化测试 (九)urllib2 发送HTTP Request
  3. 从vmware下载到Linux环境下jdk和maven的安装
  4. 【洛谷P1969】积木大赛
  5. HDU 4292 Food 最大流
  6. ZOJ 1654 - Place the Robots (二分图最大匹配)
  7. fastjson 使用方法
  8. 黄聪:wordpress如何添加自定义文章快速编辑按钮
  9. AC多模式匹配算法
  10. linux下mysql修改数据库账户root密码
  11. paip.gch预编译头不生效的原因以及解决:
  12. JQuery 操作input
  13. kubernetes入门之快速部署
  14. 0-ajax操作json(番外篇)
  15. JAVA常用知识点及面试题总结
  16. 牛客网编程练习之PAT乙级(Basic Level):1041 说反话
  17. Spark:大数据的电花火石!
  18. css 元素溢出
  19. 一.html介绍
  20. Centos 6\7下yum安装R

热门文章

  1. 90.商城登录页面Extjs
  2. Python 35 进程间的通信(IPC机制)、生产者消费者模型
  3. JVM命令参数指南
  4. 汇编程序18:利用and和or指令变换大小写
  5. A - Infinite Sequence
  6. Android 权限管理(持续整理)
  7. Unity引擎GUI之Image
  8. Ubuntu16下安装lamp
  9. JAVA软件工程师应该具备的技能有哪些?
  10. windows server 2012 r2 安装无法找到install.wim 错误代码0x80070026,以及制作U启动盘决解ISO文件超过5G大小限制的解决方案(转)