android数据库操作(三)-----用listview显示数据库数据

原创 2013年09月26日 20:10:31



四、用listview显示数据库数据(效果如下)


1)adapter使用最基本的BasesAdapter

public class SqlActivity extends Activity{
	private ListView lv_db;
	private List<PersonInfo> persons;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.dblist);
		
		PersonDao2 dao = new PersonDao2(this);
		persons = dao.findAll();
		//使用ListView的步骤:
		//1、在xml文件定义一个listView控件,获取控件id
		lv_db = (ListView) findViewById(R.id.lv_db);
		//2、为listview设置adapter
		lv_db.setAdapter(new MyAdapter());
	}
	
	//3、重新定义adapter的类继承BaseAdapter,实现里面未实现的方法,最主要是:getCount()和getView()
	//默认实现类 simpleXXX defaultXXX baseXXX
	private class MyAdapter extends BaseAdapter{
		private static final String TAG = "COCO";

		// getCount()控制listview里面总共有多少个条目
		@Override
		public int getCount() {
			int count = persons.size(); //条目个数=集合的size
			return count;
		}
		@Override
		public Object getItem(int position) {
			return null;
		}
		@Override
		public long getItemId(int position) {
			return 0;
		}
		//getView控制每个条目显示的内容,依据position来控制,传进来的位置是什么就把此位置的view对象给他
		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
		//	Log.i(TAG, "返回的view对象,position"+position);
			//得到某个位置对应的person对象
			PersonInfo info = persons.get(position);
			//视图填充器:inflate ;这个为内部类,要使用上下文则为  类.this
			View view = View.inflate(SqlActivity.this, R.layout.dblist_item, null);
			//一定要在view对象里面寻找孩子的id
			TextView id = (TextView) view.findViewById(R.id.tv_id);
			id.setText("id:"+info.getId()); 
			//上条语句需注意:如果有int类型的值要显示到textview界面上不能使用:id.setText(info.getId());
			//应该要把int值转成字符串:id.setText(info.getId()+"");
			
			TextView name = (TextView) view.findViewById(R.id.tv_name);
			name.setText("姓名:"+info.getName());
			
			TextView number = (TextView) view.findViewById(R.id.tv_number);
			number.setText("电话:"+info.getNumber());
			
			TextView acount = (TextView) view.findViewById(R.id.tv_account);
			acount.setText("收入:"+info.getAccount());
			
			return view ;
		}
	}
}

2)adapter使用ArrayAdapter:

	private static String[] names = { "功能1","功能2","功能3","功能4","功能5","功能6",};
	//this上下文;R.layout.List_item 单个的布局文件里面只有一个textView控件;R.id.tv 控件的id ,所需放置的位置;names 所需放置的内容,此处为names数组
 	 lv_db.setAdapter(new ArrayAdapter<String>(this,R.layout.List_item,R.id.tv,names));

注:

ArrayAdapter适合的需求是可以有图标,但图标只能是一致的;放置一个条目,即一个控件。

ArrayAdapter是继承了BasesAdapter,用起来比较简单


相关文章推荐

Android整理:SQlite数据库的使用以及通过listView显示数据

前言:上个月与同学一起做了一个简单的Android应用,这段时间正好没有很多事情所以趁热整理一下学习到的知识,刚开始学习Android还有很多不懂的地方,继续努力吧! 作业中需要用到数据库,...

EditText+listview+数据库操作实现搜索功能

实现搜索功能方式有哪些android搜索框功能是非常常见的,实现搜索框的方式有很多种,常见的有这三种: - SearchView - autocompletetextview - Edit...

Project——SQLite数据库操作(采用ListView实现数据列表展现)

1、 http://schemas.android.com/apk/res/android"       package="cn.itcast.db"       android:versi...

【Android 开发】:数据存储之 SQLite 数据库操作(三)

内容不定时更新中,尽情期待

android listview综合使用示例_结合数据库操作和listitem单击长按等事件处理

本示例说明: 1.自定义listview条目样式,自定义listview显示列数的多少,灵活与数据库中字段绑定. 2.实现对DB的增删改查,并且操作后listview自动刷新. 3.响应用户操作...
  • lk_blog
  • lk_blog
  • 2012年05月05日 12:16
  • 42952

android: ListView,及数据库操作,模拟实现 联系人功能

android: 模拟实现 联系人 前边包含一个头像图标,右侧是姓名 电话 既简单介绍,点击下方 添加联系人 添加,单击item显示电话 长按显示 编辑和 删除,删除之前有 提示是否删除  如图 ...

Android数据读取之Sqlite数据库操作

安卓开发只SQLite数据库操作实例

android 数据之数据库操作

一、建立 SQLite数据库的方法 1、定义一个数据库帮助类 SQLiteOpenHelper 的子类,定义静态数据库变量名称和静态数据库版本 //数据库名称 private static Strin...

Android数据存储之——SQLite数据库操作

对于一些重复的或者结构化的数据,保存到数据库是一个理想的选择,下面对SQLite数据库的操作进行讲解。 首先是定义一个数据结构体: package com.easyliu.sqlite.db; im...

Android数据存储方式之:数据库操作

开发安卓应用肯定离不开与数据打交道,现在有很多的开源框架可用,比原生的操作方便了不少比如AHibernate,GreenDao,OrmLite等等。我目前项目用到的就是GreenDao框架,可以用ja...
  • true100
  • true100
  • 2015年03月27日 16:04
  • 1148
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:android数据库操作(三)-----用listview显示数据库数据
举报原因:
原因补充:

(最多只允许输入30个字)