只是很简单的实现表格,使用GridView控件——>可以上下左右滚动,但是不能合并



直接上代码:
1、主要布局
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <TextView
  7. android:id="@+id/textview"
  8. android:layout_width="match_parent"
  9. android:layout_height="wrap_content"
  10. android:text="测试表格"/>
  11. <HorizontalScrollView
  12. android:layout_width="match_parent"
  13. android:layout_height="wrap_content">
  14. <LinearLayout
  15. android:layout_width="match_parent"
  16. android:layout_height="wrap_content"
  17. android:orientation="vertical" >
  18. <GridView
  19. android:id="@+id/table_grid"
  20. android:layout_width="match_parent"
  21. android:layout_height="match_parent"
  22. android:horizontalSpacing="1dp"
  23. android:verticalSpacing="1dp"
  24. android:numColumns="12">
  25. </GridView>
  26. </LinearLayout>
  27. </HorizontalScrollView>
  28. </LinearLayout>
2、表格中一个item的布局
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="80dp"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <TextView
  7. android:id="@+id/text_item"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:gravity="center"
  11. android:layout_gravity="center"
  12. android:textSize="15dp"
  13. android:textColor="#000000"></TextView>
  14. </LinearLayout>

3、Adapter代码
  1. package com.example.achartenginetest.adapter;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import android.content.Context;
  5. import android.graphics.Color;
  6. import android.view.LayoutInflater;
  7. import android.view.View;
  8. import android.view.ViewGroup;
  9. import android.widget.BaseAdapter;
  10. import android.widget.TextView;
  11. import com.example.achartenginetest.R;
  12. public class TableAdapter extends BaseAdapter {
  13. private final static int NUM_COLUMN = 12;
  14. private LayoutInflater mInflater;
  15. private List<double[]> mOriginalData;
  16. private List<String> mData;
  17. private Context mContext;
  18. public TableAdapter(Context context,List<double[]> mData){
  19. this.mInflater = LayoutInflater.from(context);
  20. this.mOriginalData = mData;
  21. this.mContext = context;
  22. toAllData();
  23. }
  24. private void toAllData(){
  25. mData = new ArrayList<String>();
  26. String[] tableTitle= new String[]{"日期","早餐前","早餐后1小时","早餐后2小时",
  27. "午餐前","午餐后1小时","午餐后2小时",
  28. "晚餐前","晚餐后1小时","晚餐后2小时",
  29. "睡前","凌晨2点"};
  30. for(int i = 0; i<tableTitle.length;++i){
  31. mData.add(tableTitle[i]);
  32. }
  33. for(int i = 0; i<mOriginalData.size();++i){
  34. double[] fixedData = fixData(mOriginalData.get(i));
  35. mData.add(""+i);
  36. for(int j = 0; j<fixedData.length; ++j){
  37. mData.add(""+fixedData[j]);
  38. }
  39. }
  40. }
  41. /**
  42. * 检查数据长度是否为11个取值点
  43. * @param data
  44. * @return 0:11个取值点,1:大于11个取值点,-1:小于11个取值点
  45. */
  46. private int checkData(double[] data){
  47. return data.length == NUM_COLUMN-1?0:(data.length<NUM_COLUMN-1?-1:1);
  48. }
  49. /**
  50. * 对数据进行修正,保证数据长度的正确性
  51. * @param data
  52. * @return
  53. */
  54. private double[] fixData(double[] data){
  55. int checkResult = checkData(data);
  56. if(checkResult == 0){
  57. return data;
  58. }else{
  59. double[] result = new double[NUM_COLUMN-1];
  60. if(checkResult == -1){
  61. for(int i =0; i<data.length;++i){
  62. result[i]=data[i];
  63. }
  64. for(int i = data.length; i<NUM_COLUMN-1; ++i){
  65. result[i] = 0;
  66. }
  67. }else{
  68. for(int i =0; i<NUM_COLUMN-1;++i){
  69. result[i]=data[i];
  70. }
  71. }
  72. return result;
  73. }
  74. }
  75. public int getDataCount() {
  76. return mOriginalData.size();
  77. }
  78. @Override
  79. public int getCount() {
  80. return mData.size();
  81. }
  82. @Override
  83. public Object getItem(int position) {
  84. return mData.get(position);
  85. }
  86. @Override
  87. public long getItemId(int position) {
  88. return position;
  89. }
  90. @Override
  91. public View getView(int position, View convertView, ViewGroup parent) {
  92. ViewHolder holder = null;
  93. if (convertView == null) {
  94. holder = new ViewHolder();
  95. convertView = mInflater.inflate(R.layout.table_item, null);
  96. holder.vText = (TextView)convertView.findViewById(R.id.text_item);
  97. convertView.setTag(holder);
  98. }else {
  99. holder = (ViewHolder)convertView.getTag();
  100. }
  101. holder.vText.setText(mData.get(position));
  102. if(position % NUM_COLUMN == 0){
  103. convertView.setBackgroundColor(Color.WHITE);
  104. }else if(position % NUM_COLUMN == 1 || position % NUM_COLUMN == 2 || position % NUM_COLUMN == 3){
  105. convertView.setBackgroundColor(Color.YELLOW);
  106. }else if(position % NUM_COLUMN == 4 || position % NUM_COLUMN == 5 || position % NUM_COLUMN == 6){
  107. convertView.setBackgroundColor(Color.GREEN);
  108. }else if(position % NUM_COLUMN == 7 || position % NUM_COLUMN == 8 || position % NUM_COLUMN == 9){
  109. convertView.setBackgroundColor(Color.BLUE);
  110. }else if(position % NUM_COLUMN == 10){
  111. convertView.setBackgroundColor(Color.rgb(97,76,32));
  112. }else if(position % NUM_COLUMN == 11){
  113. convertView.setBackgroundColor(Color.GRAY);
  114. }
  115. return convertView;
  116. }
  117. private class ViewHolder{
  118. public TextView vText = null;
  119. }
  120. }
4、Activity代码
  1. package com.example.achartenginetest.charts;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import android.app.Activity;
  5. import android.os.Bundle;
  6. import android.util.DisplayMetrics;
  7. import android.widget.GridView;
  8. import android.widget.LinearLayout;
  9. import com.example.achartenginetest.R;
  10. import com.example.achartenginetest.adapter.TableAdapter;
  11. public class TableChart extends Activity{
  12. private GridView mGridTable;
  13. private TableAdapter mAdapter;
  14. @Override
  15. protected void onCreate(Bundle savedInstanceState) {
  16. super.onCreate(savedInstanceState);
  17. this.setContentView(R.layout.activity_table);
  18. mGridTable = (GridView)this.findViewById(R.id.table_grid);
  19. List<double[]> vlist = initList();
  20. mAdapter = new TableAdapter(this,vlist);
  21. mGridTable.setAdapter(mAdapter);
  22. DisplayMetrics dm = new DisplayMetrics();
  23. getWindowManager().getDefaultDisplay().getMetrics(dm);
  24. float density = dm.density;
  25. int gridviewWidth = (int) (90 * 12* density);
  26. int itemWidth = (int) (80 * density);
  27. LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(gridviewWidth , LinearLayout.LayoutParams.MATCH_PARENT);
  28. mGridTable.setLayoutParams(params);
  29. mGridTable.setColumnWidth(itemWidth);
  30. mGridTable.setStretchMode(GridView.NO_STRETCH);
  31. mGridTable.setNumColumns(12);
  32. }
  33. private List<double[]> initList(){
  34. List<double[]> vList = new ArrayList<double[]>();
  35. vList.add(new double[]{8.5,11.2,10.3,8.2,15,10.2,8.1,12,9.8,8.6,8.5});
  36. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  37. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  38. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  39. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  40. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  41. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  42. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  43. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  44. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  45. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  46. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  47. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  48. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  49. vList.add(new double[]{8.5,11.2,10.3,8.2,15,10.2,8.1,12,9.8,8.6,8.5});
  50. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  51. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  52. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  53. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  54. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  55. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  56. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  57. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  58. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  59. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  60. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  61. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  62. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  63. vList.add(new double[]{8.5,11.2,10.3,8.2,15,10.2,8.1,12,9.8,8.6,8.5});
  64. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  65. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  66. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  67. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  68. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  69. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  70. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  71. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  72. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  73. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  74. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  75. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  76. vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});
  77. return vList;
  78. }
  79. }




表格类似Excel的更多相关文章

  1. 如何在web中实现类似excel的表格控件

    Execl功能非常强大,内置的很多函数或公式可以大大提高对数据的加工处理能力.那么在web中有没有类似的控件呢?经过一番搜寻,发现handsontable具备了基本的excel功能支持公式,同时能对数 ...

  2. 【图解】Web前端实现类似Excel的电子表格

    本文将通过图解的方式,使用纯前端表格控件 SpreadJS 来一步一步实现在线的电子表格产品(例如可构建Office 365 Excel产品.Google的在线SpreadSheet). 工具简介: ...

  3. js插件---在线类似excel生成图表插件解决方案

    js插件---在线类似excel生成图表插件解决方案 一.总结 一句话总结:google比百度好用多了,多用google google js editable table jquery 双向绑定 这种 ...

  4. SpreadJS:一款高度类似Excel的开发工具,功能涵盖Excel的 95% 以上

    Excel 作为一款深受用户喜爱的电子表格工具,借助其直观的界面.出色的计算性能.数据分析和图表,已经成为数据统计领域不可或缺的软件之一. 基于Excel对数据处理与分析的卓越表现,把Excel的功能 ...

  5. 用VBA计算WPS 表格ET EXCEL中的行数和列数的多重方法

    用VBA计算WPS 表格ET EXCEL中的行数和列数 每种方法中上面的是Excel的行数,下面的是Excel的列数. 方法1: ActiveSheet.UsedRange.Rows.Count Ac ...

  6. thinkphp导出csv文件,用表格输出excel

    1.thinkphp导出csv文件 导出csv文件可能就那几行代码,今天有个问题困扰我好久,就是导出之后出现一些html代码,这个不应该,view里面是空的,controller中最后也没有$this ...

  7. 适用于iview的表格转Excel插件

    在网上找的一个表格转excel插件,经过修改后使其适用于iview中的table组件 let idTmr; const getExplorer = () => { let explorer = ...

  8. Html Table用JS导出excel格式问题 导出EXCEL后单元格里的000412341234会变成412341234 7-14 会变成 2018-7-14(7月14) 自定义格式 web利用table表格生成excel格式问题 js导出excel增加表头、mso-number-format定义数据格式 数字输出格式转换 mso-number-format:"\@"

    Html Table用JS导出excel格式问题 我在网上找的JS把HTML Tabel导出成EXCEL.但是如果Table里的数字内容为0开的的导成Excel后会自动删除0,我想以text的格式写入 ...

  9. vue+iview中的table表格导出excel表格

    一.iveiw框架中table中有exportCsv()方法可以导出.csv后缀文件,类似于excel文件,但是并不是excel文件. 二.实现table表格导出excel文件利用Blob.js 和 ...

随机推荐

  1. poj 1936 All in All

    All in All Time Limit: 1000 MS Memory Limit: 30000 KB 64-bit integer IO format: %I64d , %I64u   Java ...

  2. Frugalware Linux 1.9 RC1 发布

    Frugalware Linux 1.9 RC1 发布了,下载地址:fvbe-1.9rc1-full-x86_64.iso (1,874MB, SHA1). 发行通知:http://www.fruga ...

  3. MVC路由探寻,涉及路由的惯例、自定义片段变量、约束、生成链接和URL等

    引子 在了解MVC路由之前,必须了解的概念是"片段".片段是指除主机名和查询字符串以外的.以"/"分隔的各个部分.比如,在http://site.com/Hom ...

  4. t-sql或mssql怎么用命令行导入数据脚本

    osql简单用法:用来将本地脚本执行,适合sql脚本比较大点的情况,执行起来比较方便 osql -S serverIP -U sa -P 123 -i C:\script.sql serverIP数据 ...

  5. 微信支付接口 H5

    php微信支付若干问题记录 1.缺少参数$key0$ 此问题的可能性有几种,大致有1.timeStamp这个参数应该是string类型,默认time是int 2.确实是参数缺少  比如:prepay_ ...

  6. 在Linux CentOS 6.6上安装Python 2.7.9

    CentOS 6.6自带的是Python 2.6.6,而编译llvm需要Python 2.7以上. checking for python... /usr/bin/python checking fo ...

  7. 如何真正重写window对象的方法

    重写window对象的方法不是一件新奇的事,比如我们可能需要改变默认alert的行为,如何安全的重写呢? 小菜看到某知名IT网站是这样的写法: window.alert = function(){}; ...

  8. Mac系统下lipo, ar, nm等工具的使用简介

    引言 开发第三方库时, 如果没有进行特殊处理, 很容易把其他第三方库的符号暴露出来, 导致链接时产生符号重复. 如下图所示 如果用户链接了其他版本的libjpeg, 会因为入口地址不正确让程序直接崩溃 ...

  9. ASP.NET 5系列教程(七)完结篇-解读代码

    在本文中,我们将一起查看TodoController 类代码. [Route] 属性定义了Controller的URL 模板: [Route("api/[controller]") ...

  10. phpcms v9二次开发笔记

    phpcms是基于MVC结构的. 安装: 下载phpcms_v9.5.9_UTF8.zip:新建目录phpcms,将压缩包里install_package目录下所有文件复制到phpcms目录.浏览器输 ...