1、listview与GridView

其实Android本身是有表格控件(GridView)的,但是GridView的每一列的宽度被限定为一样宽,有时设计表格时,列宽不可能为同一宽度,所有可以用ListView控件去实现表格。


2、设计思路:

listview的每一列都是由一个textview去实现,表格的竖线可以通过view控件来绘制。listview每一列的颜色相互不同可以通过复写Adapter的类,然后复写getview方法具体去实现。



3、先看一下效果图:

Android 利用ListView制作带…_SQL


4、数据库操作部分可以看我之前的博文:

本文主要在于竖线的绘制与getview方法的复写。

代码的目录结构如下图所示:


Android 利用ListView制作带…_SQL


竖线的绘制:

在ListView的布局文件中,每隔一个TextView,就增加一个控件。就是绘制一条竖线的意思。可以设置表格竖线的长度,宽度,颜色等等。


颜色的交互:

首先要知道listview的工作原理,每次得到一个item,listview都会通过getview来绘制一个item,在getview方法中,可以设置这个item的各种属性,如颜色,布局等等。



public View getView(final int position, View convertView, ViewGroup parent){
2	  
3	//第一个参数position为listview的item序号,每个item的序号都是不同的。
4	  
5	//第二个参数convertView为View的缓存,当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。
6	  
7	// 第三个参数parent表示是一个ViewGroup(view组)
8	  
9


5、详细代码:

	package com.conowen.grid;  
06	    
07	import android.app.Activity;  
08	import android.database.Cursor;  
09	import android.database.sqlite.SQLiteDatabase;  
10	import android.os.Bundle;  
11	import android.widget.ListAdapter;  
12	import android.widget.ListView;  
13	    
14	public class GridActivity extends Activity {  
15	    
16	    SQLiteDatabase sqldb;  
17	    public String DB_NAME = "DB.sqlite";  
18	    public String DB_TABLE = "num";  
19	    public int DB_VERSION = 1;  
20	    final DataHelper helper = new DataHelper(this, DB_NAME, null, DB_VERSION);  
21	    // DbHelper类在DbHelper.java文件里面创建的  
22	    ListView lv;  
23	    
24	    @Override  
25	    public void onCreate(Bundle savedInstanceState) {  
26	        // TODO Auto-generated method stub  
27	        super.onCreate(savedInstanceState);  
28	        setContentView(R.layout.main);  
29	        sqldb = helper.getWritableDatabase();  
30	        lv = (ListView) findViewById(R.id.lv);  
31	        updatelistview();  
32	    }  
33	    
34	    // 更新listview  
35	    public void updatelistview() {  
36	    
37	        //  
38	        Cursor cr = sqldb.query("JobChecker", null, null, null, null, null,  
39	                null);  
40	    
41	        String id = cr.getColumnName(0);// 获取第1列  
42	        String job = cr.getColumnName(2);// 获取第3列  
43	        String address = cr.getColumnName(4);// 获取第5列  
44	        String student = cr.getColumnName(5);// 获取第6列  
45	        String[] ColumnNames = { id, job, address, student };  
46	    
47	        ListAdapter adapter = new MySimpleCursorAdapter(this,  
48	                R.layout.listviewlayout, cr, ColumnNames, new int[] { R.id.id,  
49	                        R.id.job, R.id.addr, R.id.student });  
50	        // layout为listView的布局文件,包括三个TextView,用来显示三个列名所对应的值  
51	        // ColumnNames为数据库的表的列名  
52	        // 最后一个参数是int[]类型的,为view类型的id,用来显示ColumnNames列名所对应的值。view的类型为TextView  
53	        lv.setAdapter(adapter);  
54	    
55	    }  
56	    
57	    @Override  
58	    protected void onDestroy() {// 关闭数据库  
59	        // TODO Auto-generated method stub  
60	        super.onDestroy();  
61	        if (helper != null) {  
62	            helper.close();  
63	        }  
64	    }  
65	    
66


package com.conowen.grid;  
06	    
07	import android.content.Context;  
08	import android.database.Cursor;  
09	import android.graphics.Color;  
10	import android.view.View;  
11	import android.view.ViewGroup;  
12	import android.widget.SimpleCursorAdapter;  
13	    
14	public class MySimpleCursorAdapter extends SimpleCursorAdapter {  
15	    
16	    public MySimpleCursorAdapter(Context context, int layout, Cursor c,  
17	            String[] from, int[] to) {  
18	        super(context, layout, c, from, to);  
19	        // TODO Auto-generated constructor stub  
20	    
21	    }  
22	    
23	    @Override  
24	    public View getView(final int position, View convertView, ViewGroup parent) {  
25	        // TODO Auto-generated method stub  
26	        // listview每次得到一个item,都要view去绘制,通过getView方法得到view  
27	        // position为item的序号  
28	        View view = null;  
29	        if (convertView != null) {  
30	            view = convertView;  
31	            // 使用缓存的view,节约内存  
32	            // 当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。  
33	            // 当滚动条回到之前被遮住的item时,直接使用convertView,而不必再去new view()  
34	    
35	        } else {  
36	            view = super.getView(position, convertView, parent);  
37	    
38	        }  
39	    
40	        int[] colors = { Color.WHITE, Color.rgb(219, 238, 244) };//RGB颜色  
41	    
42	        view.setBackgroundColor(colors[position % 2]);// 每隔item之间颜色不同  
43	    
44	        return super.getView(position, view, parent);  
45	    }  
46	    
47
	package com.conowen.grid;  
06	    
07	import android.content.Context;  
08	import android.database.sqlite.SQLiteDatabase;  
09	import android.database.sqlite.SQLiteDatabase.CursorFactory;  
10	import android.database.sqlite.SQLiteOpenHelper;  
11	    
12	public class DataHelper extends SQLiteOpenHelper {  
13	    
14	    @Override  
15	    public synchronized void close() {  
16	        // TODO Auto-generated method stub  
17	        super.close();  
18	    }  
19	    
20	    public DataHelper(Context context, String name, CursorFactory factory,  
21	            int version) {  
22	        super(context, name, factory, version);  
23	        // TODO Auto-generated constructor stub  
24	    
25	    }  
26	    
27	    @Override  
28	    public void onCreate(SQLiteDatabase db) {  
29	        // TODO Auto-generated method stub  
30	    
31	        String sql = "CREATE  TABLE JobChecker (_id INTEGER PRIMARY KEY , department VARCHAR, job VARCHAR,teacher VARCHAR,address VARCHAR,student VARCHAR,isworking VARCHAR)";  
32	        db.execSQL(sql);  
33	    
34	    }  
35	    
36	    @Override  
37	    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
38	        // TODO Auto-generated method stub  
39	    
40	    }  
41