Android学习笔记(20)————利用ListView制作带竖线的多彩表格
http://blog.csdn.net/conowen/article/details/7421805
/********************************************************************************************
* author:conowen@大钟
* E-mail:conowen@hotmail.com
* http://blog.csdn.net/conowen
* 注:本文为原创,仅作为学习交流使用,转载请标明作者及出处。
********************************************************************************************/
1、listview与GridView
其实Android本身是有表格控件(GridView)的,但是GridView的每一列的宽度被限定为一样宽,有时设计表格时,列宽不可能为同一宽度,所有可以用ListView控件去实现表格。
2、设计思路:
listview的每一列都是由一个textview去实现,表格的竖线可以通过view控件来绘制。listview每一列的颜色相互不同可以通过复写Adapter的类,然后复写getview方法具体去实现。
3、先看一下效果图:
4、数据库操作部分可以看我之前的博文:http://blog.csdn.net/conowen/article/details/7306545
本文主要在于竖线的绘制与getview方法的复写。
代码的目录结构如下图所示:
竖线的绘制:
在ListView的布局文件中,每隔一个TextView,就增加一个<View>控件。就是绘制一条竖线的意思。可以设置表格竖线的长度,宽度,颜色等等。
颜色的交互:
首先要知道listview的工作原理,每次得到一个item,listview都会通过getview来绘制一个item,在getview方法中,可以设置这个item的各种属性,如颜色,布局等等。
- public View getView(final int position, View convertView, ViewGroup parent){
- //第一个参数position为listview的item序号,每个item的序号都是不同的。
- //第二个参数convertView为View的缓存,当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。
- // 第三个参数parent表示是一个ViewGroup(view组)
- }
5、详细代码:
- /*author:conowen
- * date:2012.4.2
- * GridActivity
- */
- package com.conowen.grid;
- import android.app.Activity;
- import android.database.Cursor;
- import android.database.sqlite.SQLiteDatabase;
- import android.os.Bundle;
- import android.widget.ListAdapter;
- import android.widget.ListView;
- public class GridActivity extends Activity {
- SQLiteDatabase sqldb;
- public String DB_NAME = "DB.sqlite";
- public String DB_TABLE = "num";
- public int DB_VERSION = 1;
- final DataHelper helper = new DataHelper(this, DB_NAME, null, DB_VERSION);
- // DbHelper类在DbHelper.java文件里面创建的
- ListView lv;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- // TODO Auto-generated method stub
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- sqldb = helper.getWritableDatabase();
- lv = (ListView) findViewById(R.id.lv);
- updatelistview();
- }
- // 更新listview
- public void updatelistview() {
- //
- Cursor cr = sqldb.query("JobChecker", null, null, null, null, null,
- null);
- String id = cr.getColumnName(0);// 获取第1列
- String job = cr.getColumnName(2);// 获取第3列
- String address = cr.getColumnName(4);// 获取第5列
- String student = cr.getColumnName(5);// 获取第6列
- String[] ColumnNames = { id, job, address, student };
- ListAdapter adapter = new MySimpleCursorAdapter(this,
- R.layout.listviewlayout, cr, ColumnNames, new int[] { R.id.id,
- R.id.job, R.id.addr, R.id.student });
- // layout为listView的布局文件,包括三个TextView,用来显示三个列名所对应的值
- // ColumnNames为数据库的表的列名
- // 最后一个参数是int[]类型的,为view类型的id,用来显示ColumnNames列名所对应的值。view的类型为TextView
- lv.setAdapter(adapter);
- }
- @Override
- protected void onDestroy() {// 关闭数据库
- // TODO Auto-generated method stub
- super.onDestroy();
- if (helper != null) {
- helper.close();
- }
- }
- }
- /*author:conowen
- * date:2012.4.2
- * MySimpleCursorAdapter
- */
- package com.conowen.grid;
- import android.content.Context;
- import android.database.Cursor;
- import android.graphics.Color;
- import android.view.View;
- import android.view.ViewGroup;
- import android.widget.SimpleCursorAdapter;
- public class MySimpleCursorAdapter extends SimpleCursorAdapter {
- public MySimpleCursorAdapter(Context context, int layout, Cursor c,
- String[] from, int[] to) {
- super(context, layout, c, from, to);
- // TODO Auto-generated constructor stub
- }
- @Override
- public View getView(final int position, View convertView, ViewGroup parent) {
- // TODO Auto-generated method stub
- // listview每次得到一个item,都要view去绘制,通过getView方法得到view
- // position为item的序号
- View view = null;
- if (convertView != null) {
- view = convertView;
- // 使用缓存的view,节约内存
- // 当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。
- // 当滚动条回到之前被遮住的item时,直接使用convertView,而不必再去new view()
- } else {
- view = super.getView(position, convertView, parent);
- }
- int[] colors = { Color.WHITE, Color.rgb(219, 238, 244) };//RGB颜色
- view.setBackgroundColor(colors[position % 2]);// 每隔item之间颜色不同
- return super.getView(position, view, parent);
- }
- }
- /*author:conowen
- * date:2012.4.2
- * DataHelper
- */
- package com.conowen.grid;
- import android.content.Context;
- import android.database.sqlite.SQLiteDatabase;
- import android.database.sqlite.SQLiteDatabase.CursorFactory;
- import android.database.sqlite.SQLiteOpenHelper;
- public class DataHelper extends SQLiteOpenHelper {
- @Override
- public synchronized void close() {
- // TODO Auto-generated method stub
- super.close();
- }
- public DataHelper(Context context, String name, CursorFactory factory,
- int version) {
- super(context, name, factory, version);
- // TODO Auto-generated constructor stub
- }
- @Override
- public void onCreate(SQLiteDatabase db) {
- // TODO Auto-generated method stub
- String sql = "CREATE TABLE JobChecker (_id INTEGER PRIMARY KEY , department VARCHAR, job VARCHAR,teacher VARCHAR,address VARCHAR,student VARCHAR,isworking VARCHAR)";
- db.execSQL(sql);
- }
- @Override
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
- // TODO Auto-generated method stub
- }
- }
main.xml
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="vertical" >
- <LinearLayout
- xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:orientation="horizontal" >
- <TextView
- android:layout_width="40dip"
- android:layout_height="30dp"
- android:text="序号"
- android:textSize="20sp" />
- <TextView
- android:id="@+id/job"
- android:layout_width="200dip"
- android:layout_height="30dp"
- android:text="岗位名称"
- android:textSize="20sp" />
- <TextView
- android:id="@+id/addr"
- android:layout_width="150dip"
- android:layout_height="30dp"
- android:text="详细地点"
- android:textSize="20sp" />
- <TextView
- android:id="@+id/student"
- android:layout_width="100dip"
- android:layout_height="30dp"
- android:text="工作学生"
- android:textSize="20sp" />
- <TextView
- android:id="@+id/isworking"
- android:layout_width="80dip"
- android:layout_height="30dp"
- android:text="备注"
- android:textSize="20sp" />
- </LinearLayout>
- <ListView
- android:id="@+id/lv"
- android:layout_width="fill_parent"
- android:layout_height="wrap_content" >
- </ListView>
- </LinearLayout>
listviewlayout.xml
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="horizontal" >
- <View
- android:layout_width="0.5px"
- android:layout_height="fill_parent"
- android:background="#B8B8B8"
- android:visibility="visible" />
- <TextView
- android:id="@+id/id"
- android:layout_width="40dip"
- android:layout_height="55dip"
- android:textColor="#CD3700"
- android:textSize="20sp" />
- <View
- android:layout_width="0.5px"
- android:layout_height="fill_parent"
- android:background="#B8B8B8"
- android:visibility="visible" />
- <TextView
- android:id="@+id/job"
- android:layout_width="200dip"
- android:layout_height="wrap_content"
- android:textColor="#000000"
- android:textSize="17sp" />
- <View
- android:layout_width="0.5px"
- android:layout_height="fill_parent"
- android:background="#B8B8B8"
- android:visibility="visible" />
- <TextView
- android:id="@+id/addr"
- android:layout_width="150dip"
- android:layout_height="wrap_content"
- android:textColor="#000000"
- android:textSize="17sp" />
- <View
- android:layout_width="0.5px"
- android:layout_height="fill_parent"
- android:background="#B8B8B8"
- android:visibility="visible" />
- <TextView
- android:id="@+id/student"
- android:layout_width="100dip"
- android:layout_height="wrap_content"
- android:textColor="#000000"
- android:textSize="20sp" />
- <View
- android:layout_width="0.5px"
- android:layout_height="fill_parent"
- android:background="#B8B8B8"
- android:visibility="visible" />
- </LinearLayout>
Android学习笔记(20)————利用ListView制作带竖线的多彩表格的更多相关文章
- Android 利用ListView制作带竖线的多彩表格
1.listview与GridView 其实Android本身是有表格控件(GridView)的,但是GridView的每一列的宽度被限定为一样宽,有时设计表格时,列宽不可能为同一宽度,所有可以用Li ...
- Android学习笔记:利用httpclient和AsyncTask 发起网络http post操作
1.在android4中,发起网络http操作,不能在Activity的事件(即主线程)中进行,必须在单独的线程中操作. 另外进行网络操作,需要在manifest文件中增加如下的权限: <use ...
- android学习笔记20——ProgressDialog进度条对话框
ProgressDialog==>进度条对话框 ProgressDialog本身就代表一个进度条对话框,程序只需要创建ProgressDialog实例,并将其显示出来就是一个进度条对话框:开发者 ...
- Android学习笔记(20):时钟(AnalogClock和TextClock)和计时器(Chronometer)
时钟文本TextClock继承自TextView.是用于显示当前时间的文本框. TextClock支持的XML属性和相关方法 XML属性 相关方法 说明 android:format12Hour se ...
- 【转】 Pro Android学习笔记(十九):用户界面和控制(7):ListView
目录(?)[-] 点击List的item触发 添加其他控件以及获取item数据 ListView控件以垂直布局方式显示子view.系统的android.app.ListActivity已经实现了一个只 ...
- 【转】Pro Android学习笔记(二三):用户界面和控制(11):其他控件
目录(?)[-] Chronometer计时器控件 倒计时CountDownTimer Switch控件 Space控件 其他控件 Android提供了很多控件,基本上都是view的扩展. Chron ...
- Android学习笔记之JSON数据解析
转载:Android学习笔记44:JSON数据解析 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种 ...
- Android学习笔记36:使用SQLite方式存储数据
在Android中一共提供了5种数据存储方式,分别为: (1)Files:通过FileInputStream和FileOutputStream对文件进行操作.具体使用方法可以参阅博文<Andro ...
- 【转】 Pro Android学习笔记(七四):HTTP服务(8):使用后台线程AsyncTask
目录(?)[-] 5秒超时异常 AsyncTask 实现AsyncTask抽象类 对AsyncTask的调用 在哪里运行 其他重要method 文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注 ...
随机推荐
- hdu 1175(广搜)
题意:容易理解... 思路:我开始的思路不好实现,而且有漏洞,时间复杂度也高,后来在网上学了下别人的方法,真心感觉很牛B,不仅代码好实现,而且时间复杂度比较低,具体看代码实现吧!! 代码实现: #in ...
- java web 学习十二(session)
一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...
- JAX-WS
JAX-WS(Java API for XML Web Services)规范是一组XML web services的JAVA API,JAX-WS允许开发者可以选择RPC-oriented或者mes ...
- linux 命令——文件管理 ls
一.介绍 ls命令是linux下最常用的命令之一,ls跟dos下的dir命令是一样的都是用来列出目录下的文件和子目录.ls全称list,即列表. 缺省下ls用来打印出当前目录的清单,如果ls指定其他目 ...
- JavaScript遍历方式详解
为了方便例子讲解,现有数组和json对象如下: var demoArr = ['Javascript', 'Gulp', 'CSS3', 'Grunt', 'jQuery', 'angular']; ...
- 关于display显示 linux
export DISPLAY=ipaddressofyourmachineorpc:0.0 如果要在本来的机器上显示,使用 export DISPLAY=localhost:0
- MVC & MVVM
什么是MVC,什么是MVVM? 面向过程 --> 面向对象 --> MVC --> MV* 面向过程: 开发人员按照需求逻辑顺序开发代码逻辑,主要思维模式在于如何实现.先细节,后整体 ...
- bzoj 1576 [Usaco2009 Jan]安全路经Travel(树链剖分,线段树)
[题意] 给定一个无向图,找到1-i所有的次短路经,要求与最短路径的最后一条边不重叠. [思路] 首先用dijkstra算法构造以1为根的最短路树. 将一条无向边看作两条有向边,考察一条不在最短路树上 ...
- UVALive 4763
一开始,没敢写,感觉会超时...其实就是暴力搜索.DFS #include<iostream> #include<stdio.h> #include<string.h&g ...
- 有关android UI 线程
1. GUI线程框架 常见的 Swing, SWT框架都是作为单线程子系统来实现的,实际上不仅限于在Java中, Qt.MacOS Cocoa以及其他的环境中的GUI框架都是单线程的.虽然很多人尝试过 ...