1、listview与GridView
其实Android本身是有表格控件(GridView)的,但是GridView的每一列的宽度被限定为一样宽,有时设计表格时,列宽不可能为同一宽度,所有可以用ListView控件去实现表格。
2、设计思路:
listview的每一列都是由一个textview去实现,表格的竖线可以通过view控件来绘制。listview每一列的颜色相互不同可以通过复写Adapter的类,然后复写getview方法具体去实现。
3、先看一下效果图:
4、数据库操作部分可以看我之前的博文:
本文主要在于竖线的绘制与getview方法的复写。
代码的目录结构如下图所示:
竖线的绘制:
在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