Android学习笔记(20)————利用ListView制作带竖线的多彩表格

摘要:
listview每一列的颜色相互不同可以通过复写Adapter的类,然后复写getview方法具体去实现。//第二个参数convertView为View的缓存,当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。

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、先看一下效果图:

Android学习笔记(20)————利用ListView制作带竖线的多彩表格第1张

4、数据库操作部分可以看我之前的博文:http://blog.csdn.net/conowen/article/details/7306545

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

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

Android学习笔记(20)————利用ListView制作带竖线的多彩表格第2张

竖线的绘制:

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

颜色的交互:

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

  1. publicViewgetView(finalintposition,ViewconvertView,ViewGroupparent){
  2. //第一个参数position为listview的item序号,每个item的序号都是不同的。
  3. //第二个参数convertView为View的缓存,当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。
  4. //第三个参数parent表示是一个ViewGroup(view组)
  5. }

5、详细代码:

  1. /*author:conowen
  2. *date:2012.4.2
  3. *GridActivity
  4. */
  5. packagecom.conowen.grid;
  6. importandroid.app.Activity;
  7. importandroid.database.Cursor;
  8. importandroid.database.sqlite.SQLiteDatabase;
  9. importandroid.os.Bundle;
  10. importandroid.widget.ListAdapter;
  11. importandroid.widget.ListView;
  12. publicclassGridActivityextendsActivity{
  13. SQLiteDatabasesqldb;
  14. publicStringDB_NAME="DB.sqlite";
  15. publicStringDB_TABLE="num";
  16. publicintDB_VERSION=1;
  17. finalDataHelperhelper=newDataHelper(this,DB_NAME,null,DB_VERSION);
  18. //DbHelper类在DbHelper.java文件里面创建的
  19. ListViewlv;
  20. @Override
  21. publicvoidonCreate(BundlesavedInstanceState){
  22. //TODOAuto-generatedmethodstub
  23. super.onCreate(savedInstanceState);
  24. setContentView(R.layout.main);
  25. sqldb=helper.getWritableDatabase();
  26. lv=(ListView)findViewById(R.id.lv);
  27. updatelistview();
  28. }
  29. //更新listview
  30. publicvoidupdatelistview(){
  31. //
  32. Cursorcr=sqldb.query("JobChecker",null,null,null,null,null,
  33. null);
  34. Stringid=cr.getColumnName(0);//获取第1列
  35. Stringjob=cr.getColumnName(2);//获取第3列
  36. Stringaddress=cr.getColumnName(4);//获取第5列
  37. Stringstudent=cr.getColumnName(5);//获取第6列
  38. String[]ColumnNames={id,job,address,student};
  39. ListAdapteradapter=newMySimpleCursorAdapter(this,
  40. R.layout.listviewlayout,cr,ColumnNames,newint[]{R.id.id,
  41. R.id.job,R.id.addr,R.id.student});
  42. //layout为listView的布局文件,包括三个TextView,用来显示三个列名所对应的值
  43. //ColumnNames为数据库的表的列名
  44. //最后一个参数是int[]类型的,为view类型的id,用来显示ColumnNames列名所对应的值。view的类型为TextView
  45. lv.setAdapter(adapter);
  46. }
  47. @Override
  48. protectedvoidonDestroy(){//关闭数据库
  49. //TODOAuto-generatedmethodstub
  50. super.onDestroy();
  51. if(helper!=null){
  52. helper.close();
  53. }
  54. }
  55. }
  1. /*author:conowen
  2. *date:2012.4.2
  3. *MySimpleCursorAdapter
  4. */
  5. packagecom.conowen.grid;
  6. importandroid.content.Context;
  7. importandroid.database.Cursor;
  8. importandroid.graphics.Color;
  9. importandroid.view.View;
  10. importandroid.view.ViewGroup;
  11. importandroid.widget.SimpleCursorAdapter;
  12. publicclassMySimpleCursorAdapterextendsSimpleCursorAdapter{
  13. publicMySimpleCursorAdapter(Contextcontext,intlayout,Cursorc,
  14. String[]from,int[]to){
  15. super(context,layout,c,from,to);
  16. //TODOAuto-generatedconstructorstub
  17. }
  18. @Override
  19. publicViewgetView(finalintposition,ViewconvertView,ViewGroupparent){
  20. //TODOAuto-generatedmethodstub
  21. //listview每次得到一个item,都要view去绘制,通过getView方法得到view
  22. //position为item的序号
  23. Viewview=null;
  24. if(convertView!=null){
  25. view=convertView;
  26. //使用缓存的view,节约内存
  27. //当listview的item过多时,拖动会遮住一部分item,被遮住的item的view就是convertView保存着。
  28. //当滚动条回到之前被遮住的item时,直接使用convertView,而不必再去newview()
  29. }else{
  30. view=super.getView(position,convertView,parent);
  31. }
  32. int[]colors={Color.WHITE,Color.rgb(219,238,244)};//RGB颜色
  33. view.setBackgroundColor(colors[position%2]);//每隔item之间颜色不同
  34. returnsuper.getView(position,view,parent);
  35. }
  36. }
  1. /*author:conowen
  2. *date:2012.4.2
  3. *DataHelper
  4. */
  5. packagecom.conowen.grid;
  6. importandroid.content.Context;
  7. importandroid.database.sqlite.SQLiteDatabase;
  8. importandroid.database.sqlite.SQLiteDatabase.CursorFactory;
  9. importandroid.database.sqlite.SQLiteOpenHelper;
  10. publicclassDataHelperextendsSQLiteOpenHelper{
  11. @Override
  12. publicsynchronizedvoidclose(){
  13. //TODOAuto-generatedmethodstub
  14. super.close();
  15. }
  16. publicDataHelper(Contextcontext,Stringname,CursorFactoryfactory,
  17. intversion){
  18. super(context,name,factory,version);
  19. //TODOAuto-generatedconstructorstub
  20. }
  21. @Override
  22. publicvoidonCreate(SQLiteDatabasedb){
  23. //TODOAuto-generatedmethodstub
  24. Stringsql="CREATETABLEJobChecker(_idINTEGERPRIMARYKEY,departmentVARCHAR,jobVARCHAR,teacherVARCHAR,addressVARCHAR,studentVARCHAR,isworkingVARCHAR)";
  25. db.execSQL(sql);
  26. }
  27. @Override
  28. publicvoidonUpgrade(SQLiteDatabasedb,intoldVersion,intnewVersion){
  29. //TODOAuto-generatedmethodstub
  30. }
  31. }

main.xml

  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical">
  6. <LinearLayout
  7. xmlns:android="http://schemas.android.com/apk/res/android"
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:orientation="horizontal">
  11. <TextView
  12. android:layout_width="40dip"
  13. android:layout_height="30dp"
  14. android:text="序号"
  15. android:textSize="20sp"/>
  16. <TextView
  17. android:id="@+id/job"
  18. android:layout_width="200dip"
  19. android:layout_height="30dp"
  20. android:text="岗位名称"
  21. android:textSize="20sp"/>
  22. <TextView
  23. android:id="@+id/addr"
  24. android:layout_width="150dip"
  25. android:layout_height="30dp"
  26. android:text="详细地点"
  27. android:textSize="20sp"/>
  28. <TextView
  29. android:id="@+id/student"
  30. android:layout_width="100dip"
  31. android:layout_height="30dp"
  32. android:text="工作学生"
  33. android:textSize="20sp"/>
  34. <TextView
  35. android:id="@+id/isworking"
  36. android:layout_width="80dip"
  37. android:layout_height="30dp"
  38. android:text="备注"
  39. android:textSize="20sp"/>
  40. </LinearLayout>
  41. <ListView
  42. android:id="@+id/lv"
  43. android:layout_width="fill_parent"
  44. android:layout_height="wrap_content">
  45. </ListView>
  46. </LinearLayout>

listviewlayout.xml

    1. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
    2. android:layout_width="fill_parent"
    3. android:layout_height="fill_parent"
    4. android:orientation="horizontal">
    5. <View
    6. android:layout_width="0.5px"
    7. android:layout_height="fill_parent"
    8. android:background="#B8B8B8"
    9. android:visibility="visible"/>
    10. <TextView
    11. android:id="@+id/id"
    12. android:layout_width="40dip"
    13. android:layout_height="55dip"
    14. android:textColor="#CD3700"
    15. android:textSize="20sp"/>
    16. <View
    17. android:layout_width="0.5px"
    18. android:layout_height="fill_parent"
    19. android:background="#B8B8B8"
    20. android:visibility="visible"/>
    21. <TextView
    22. android:id="@+id/job"
    23. android:layout_width="200dip"
    24. android:layout_height="wrap_content"
    25. android:textColor="#000000"
    26. android:textSize="17sp"/>
    27. <View
    28. android:layout_width="0.5px"
    29. android:layout_height="fill_parent"
    30. android:background="#B8B8B8"
    31. android:visibility="visible"/>
    32. <TextView
    33. android:id="@+id/addr"
    34. android:layout_width="150dip"
    35. android:layout_height="wrap_content"
    36. android:textColor="#000000"
    37. android:textSize="17sp"/>
    38. <View
    39. android:layout_width="0.5px"
    40. android:layout_height="fill_parent"
    41. android:background="#B8B8B8"
    42. android:visibility="visible"/>
    43. <TextView
    44. android:id="@+id/student"
    45. android:layout_width="100dip"
    46. android:layout_height="wrap_content"
    47. android:textColor="#000000"
    48. android:textSize="20sp"/>
    49. <View
    50. android:layout_width="0.5px"
    51. android:layout_height="fill_parent"
    52. android:background="#B8B8B8"
    53. android:visibility="visible"/>
    54. </LinearLayout>

免责声明:文章转载自《Android学习笔记(20)————利用ListView制作带竖线的多彩表格》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇java数据库登陆页面Error: Program type already present: com.google.gson.FieldAttributes 的解决方法下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

WPF如何获得ListView内各单元格控件

------------------首先不推荐这种模式ItemsSource 已经绑定了源. Items 集合的数量变化很随机, 每个单元格的控件取决於  默认的DataTemplate(设置 DisplayMemberBinding 时) 或者  CellTemplate 定义的控件, 或者  CellTemplateSelector 指定的 Templ...

WPF: 在ListView中添加Checkbox列表

描述:ListView是WPF中动态绑定工具的数据容器,本文实现了一个在ListView中显示的供用户选择的列表项目,并且控制列表中选择的项目数量,即实现单选。 XAML中创建ListView,代码如下: <ListView x:Name="listView_LineOfBusiness" Width="280" Height="220">...

Android 演示 Android ListView 和 github XListView(1-3)

本文内容 环境 项目结构 演示 1:ListView 演示 2:简单 XListView 演示 3:音乐列表 XListView 演示 4:另一个音乐列表 XListView 本文四个演示,循序渐进。 演示 1 只是普通的 Android ListView 控件; 演示 2 是 GitHub 上的 XListView 控件,具备“下拉...

jQuery Mobile 列表视图(带有自动检索)

输入a: 输入b: jQuery Mobile 列表视图 jQuery Mobile 中的列表视图是标准的 HTML 列表:有序列表 (<ol>) 和无序列表 (<ul>)。 如需创建列表,请向 <ol> 或 <ul> 元素添加 data-role="listview"。如需使这些项目可点击,请在每个列...

Xamarin.Forms Layout Challenges – Timeline(转载,已翻译)

翻译采用中英对照的方式. 原文地址:http://www.kymphillpotts.com/xamarin-forms-layout-challenges-timeline/ Github地址:https://github.com/kphillpotts/XamarinFormsLayoutChallenges/tree/master/Timeline...

继续聊WPF——用Blend自定义Listview控件的列表头

在Blend中右击ListView控件,从样式和模板相关的菜单项中,我们没找到与列表头有关的项。 然后,我们到属性面板中找GridView的ColumnHeaderContainerStyle属性,结果你发现,就算你在高级选项菜单中把它转换为本地资源,你会发现它没有反应,切换到XAML视图也没看到生成的代码。 那是不是没办法了呢?这个问题我想了想...