只是很简单的实现表格,使用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. 数据库知识整理<一>

    关系型数据库知识整理: 一,关系型数据库管理系统简介: 1.1使用数据库的原因: 降低存储数据的冗余度 提高数据的一致性 可以建立数据库所遵循的标准 储存数据可以共享 便于维护数据的完整性 能够实现数 ...

  2. 导航VC的左右item代码

    代码控制左右item: UIButton *btnCancel = [UIButton buttonWithType:UIButtonTypeCustom];     btnCancel.frame= ...

  3. Eclipse 创建Maven项目的问题:a pom xml file already exists in the destination folder

    创建过一个Maven项目,删除的时候只在Eclipse中删除了,但是磁盘上的这个项目没有删除,所以报错 方法:重新创建一个不同名称的Maven项目,右键项目,选择Properties,看你的项目目录( ...

  4. 分享一下SQLSERVER技术交流QQ群里的群共享资源

    分享一下SQLSERVER技术交流QQ群里的群共享资源 SQLSERVER技术交流QQ群已经开了一段时间了,人数已经有了100多号人, 而群里面很多SQLSERVER爱好者上传了他们宝贵的SQLSER ...

  5. Dynamic CRM 2013学习笔记(二)插件基本用法及调试

      插件是可与 Microsoft Dynamics CRM 2013 和 Microsoft Dynamics CRM Online 集成的自定义业务逻辑(代码),用于修改或增加平台的标准行为.也可 ...

  6. 聊聊JS与设计模式之(工厂Factory)篇------(麦当劳的故事)

    一,总体概要 1,笔者浅谈 说起设计模式其实并不是什么很新奇的概念,它也不是基于特定语言所形成的产物,它是基于软件设计原则以及相关的方法论和经过特定时期衍生出的若干解决方案.本文会以一个实例带入大家学 ...

  7. 3-MSP430引脚中断

    为了写一篇文章做铺垫--提醒着自己,,,,,, 这两天一直在寻找 #pragma vector = PORT1_VECTOR __interrupt void P1_Interrupt()//P1口中 ...

  8. mysql 5.6.17 x64 安装

    下载地址 百度网盘地址:http://pan.baidu.com/share/link?shareid=1895747668&uk=3257050114&fid=234538452 官 ...

  9. Rails下cloud datastore的使用

      Rails下cloud datastore的使用 背景 部门有一个项目要用Ruby做 WebAPI,DB使用关系型数据库Cloud Sql和非关系型数据库Cloud Datastore . 还不了 ...

  10. JS 基本数据类型

    一.undefined 类型 (ECMAScript 3引入undefined类型) 1.它的值只有一个 undefined 2.未初始化的变量 会隐式转换为undeFined类型 var box; ...