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

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><TextViewandroid:id="@+id/textview"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="测试表格"/><HorizontalScrollViewandroid:layout_width="match_parent"android:layout_height="wrap_content"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical" ><GridViewandroid:id="@+id/table_grid"android:layout_width="match_parent"android:layout_height="match_parent"android:horizontalSpacing="1dp"android:verticalSpacing="1dp"android:numColumns="12"></GridView></LinearLayout></HorizontalScrollView></LinearLayout>
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="80dp"android:layout_height="match_parent"android:orientation="vertical"><TextViewandroid:id="@+id/text_item"android:layout_width="wrap_content"android:layout_height="wrap_content"android:gravity="center"android:layout_gravity="center"android:textSize="15dp"android:textColor="#000000"></TextView></LinearLayout>
package com.example.achartenginetest.adapter;import java.util.ArrayList;import java.util.List;import android.content.Context;import android.graphics.Color;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.BaseAdapter;import android.widget.TextView;import com.example.achartenginetest.R;public class TableAdapter extends BaseAdapter {private final static int NUM_COLUMN = 12;private LayoutInflater mInflater;private List<double[]> mOriginalData;private List<String> mData;private Context mContext;public TableAdapter(Context context,List<double[]> mData){this.mInflater = LayoutInflater.from(context);this.mOriginalData = mData;this.mContext = context;toAllData();}private void toAllData(){mData = new ArrayList<String>();String[] tableTitle= new String[]{"日期","早餐前","早餐后1小时","早餐后2小时","午餐前","午餐后1小时","午餐后2小时","晚餐前","晚餐后1小时","晚餐后2小时","睡前","凌晨2点"};for(int i = 0; i<tableTitle.length;++i){mData.add(tableTitle[i]);}for(int i = 0; i<mOriginalData.size();++i){double[] fixedData = fixData(mOriginalData.get(i));mData.add(""+i);for(int j = 0; j<fixedData.length; ++j){mData.add(""+fixedData[j]);}}}/*** 检查数据长度是否为11个取值点* @param data* @return 0:11个取值点,1:大于11个取值点,-1:小于11个取值点*/private int checkData(double[] data){return data.length == NUM_COLUMN-1?0:(data.length<NUM_COLUMN-1?-1:1);}/*** 对数据进行修正,保证数据长度的正确性* @param data* @return*/private double[] fixData(double[] data){int checkResult = checkData(data);if(checkResult == 0){return data;}else{double[] result = new double[NUM_COLUMN-1];if(checkResult == -1){for(int i =0; i<data.length;++i){result[i]=data[i];}for(int i = data.length; i<NUM_COLUMN-1; ++i){result[i] = 0;}}else{for(int i =0; i<NUM_COLUMN-1;++i){result[i]=data[i];}}return result;}}public int getDataCount() {return mOriginalData.size();}@Overridepublic int getCount() {return mData.size();}@Overridepublic Object getItem(int position) {return mData.get(position);}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {ViewHolder holder = null;if (convertView == null) {holder = new ViewHolder();convertView = mInflater.inflate(R.layout.table_item, null);holder.vText = (TextView)convertView.findViewById(R.id.text_item);convertView.setTag(holder);}else {holder = (ViewHolder)convertView.getTag();}holder.vText.setText(mData.get(position));if(position % NUM_COLUMN == 0){convertView.setBackgroundColor(Color.WHITE);}else if(position % NUM_COLUMN == 1 || position % NUM_COLUMN == 2 || position % NUM_COLUMN == 3){convertView.setBackgroundColor(Color.YELLOW);}else if(position % NUM_COLUMN == 4 || position % NUM_COLUMN == 5 || position % NUM_COLUMN == 6){convertView.setBackgroundColor(Color.GREEN);}else if(position % NUM_COLUMN == 7 || position % NUM_COLUMN == 8 || position % NUM_COLUMN == 9){convertView.setBackgroundColor(Color.BLUE);}else if(position % NUM_COLUMN == 10){convertView.setBackgroundColor(Color.rgb(97,76,32));}else if(position % NUM_COLUMN == 11){convertView.setBackgroundColor(Color.GRAY);}return convertView;}private class ViewHolder{public TextView vText = null;}}
package com.example.achartenginetest.charts;import java.util.ArrayList;import java.util.List;import android.app.Activity;import android.os.Bundle;import android.util.DisplayMetrics;import android.widget.GridView;import android.widget.LinearLayout;import com.example.achartenginetest.R;import com.example.achartenginetest.adapter.TableAdapter;public class TableChart extends Activity{private GridView mGridTable;private TableAdapter mAdapter;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);this.setContentView(R.layout.activity_table);mGridTable = (GridView)this.findViewById(R.id.table_grid);List<double[]> vlist = initList();mAdapter = new TableAdapter(this,vlist);mGridTable.setAdapter(mAdapter);DisplayMetrics dm = new DisplayMetrics();getWindowManager().getDefaultDisplay().getMetrics(dm);float density = dm.density;int gridviewWidth = (int) (90 * 12* density);int itemWidth = (int) (80 * density);LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(gridviewWidth , LinearLayout.LayoutParams.MATCH_PARENT);mGridTable.setLayoutParams(params);mGridTable.setColumnWidth(itemWidth);mGridTable.setStretchMode(GridView.NO_STRETCH);mGridTable.setNumColumns(12);}private List<double[]> initList(){List<double[]> vList = new ArrayList<double[]>();vList.add(new double[]{8.5,11.2,10.3,8.2,15,10.2,8.1,12,9.8,8.6,8.5});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.5,11.2,10.3,8.2,15,10.2,8.1,12,9.8,8.6,8.5});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.5,11.2,10.3,8.2,15,10.2,8.1,12,9.8,8.6,8.5});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});vList.add(new double[]{8.4,10,9.3,8.3,14.1,13,8.0,13,9.6,9.1,8.9});return vList;}}
表格类似Excel的更多相关文章
- 如何在web中实现类似excel的表格控件
Execl功能非常强大,内置的很多函数或公式可以大大提高对数据的加工处理能力.那么在web中有没有类似的控件呢?经过一番搜寻,发现handsontable具备了基本的excel功能支持公式,同时能对数 ...
- 【图解】Web前端实现类似Excel的电子表格
本文将通过图解的方式,使用纯前端表格控件 SpreadJS 来一步一步实现在线的电子表格产品(例如可构建Office 365 Excel产品.Google的在线SpreadSheet). 工具简介: ...
- js插件---在线类似excel生成图表插件解决方案
js插件---在线类似excel生成图表插件解决方案 一.总结 一句话总结:google比百度好用多了,多用google google js editable table jquery 双向绑定 这种 ...
- SpreadJS:一款高度类似Excel的开发工具,功能涵盖Excel的 95% 以上
Excel 作为一款深受用户喜爱的电子表格工具,借助其直观的界面.出色的计算性能.数据分析和图表,已经成为数据统计领域不可或缺的软件之一. 基于Excel对数据处理与分析的卓越表现,把Excel的功能 ...
- 用VBA计算WPS 表格ET EXCEL中的行数和列数的多重方法
用VBA计算WPS 表格ET EXCEL中的行数和列数 每种方法中上面的是Excel的行数,下面的是Excel的列数. 方法1: ActiveSheet.UsedRange.Rows.Count Ac ...
- thinkphp导出csv文件,用表格输出excel
1.thinkphp导出csv文件 导出csv文件可能就那几行代码,今天有个问题困扰我好久,就是导出之后出现一些html代码,这个不应该,view里面是空的,controller中最后也没有$this ...
- 适用于iview的表格转Excel插件
在网上找的一个表格转excel插件,经过修改后使其适用于iview中的table组件 let idTmr; const getExplorer = () => { let explorer = ...
- 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的格式写入 ...
- vue+iview中的table表格导出excel表格
一.iveiw框架中table中有exportCsv()方法可以导出.csv后缀文件,类似于excel文件,但是并不是excel文件. 二.实现table表格导出excel文件利用Blob.js 和 ...
随机推荐
- poj 1936 All in All
All in All Time Limit: 1000 MS Memory Limit: 30000 KB 64-bit integer IO format: %I64d , %I64u Java ...
- Frugalware Linux 1.9 RC1 发布
Frugalware Linux 1.9 RC1 发布了,下载地址:fvbe-1.9rc1-full-x86_64.iso (1,874MB, SHA1). 发行通知:http://www.fruga ...
- MVC路由探寻,涉及路由的惯例、自定义片段变量、约束、生成链接和URL等
引子 在了解MVC路由之前,必须了解的概念是"片段".片段是指除主机名和查询字符串以外的.以"/"分隔的各个部分.比如,在http://site.com/Hom ...
- t-sql或mssql怎么用命令行导入数据脚本
osql简单用法:用来将本地脚本执行,适合sql脚本比较大点的情况,执行起来比较方便 osql -S serverIP -U sa -P 123 -i C:\script.sql serverIP数据 ...
- 微信支付接口 H5
php微信支付若干问题记录 1.缺少参数$key0$ 此问题的可能性有几种,大致有1.timeStamp这个参数应该是string类型,默认time是int 2.确实是参数缺少 比如:prepay_ ...
- 在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 ...
- 如何真正重写window对象的方法
重写window对象的方法不是一件新奇的事,比如我们可能需要改变默认alert的行为,如何安全的重写呢? 小菜看到某知名IT网站是这样的写法: window.alert = function(){}; ...
- Mac系统下lipo, ar, nm等工具的使用简介
引言 开发第三方库时, 如果没有进行特殊处理, 很容易把其他第三方库的符号暴露出来, 导致链接时产生符号重复. 如下图所示 如果用户链接了其他版本的libjpeg, 会因为入口地址不正确让程序直接崩溃 ...
- ASP.NET 5系列教程(七)完结篇-解读代码
在本文中,我们将一起查看TodoController 类代码. [Route] 属性定义了Controller的URL 模板: [Route("api/[controller]") ...
- phpcms v9二次开发笔记
phpcms是基于MVC结构的. 安装: 下载phpcms_v9.5.9_UTF8.zip:新建目录phpcms,将压缩包里install_package目录下所有文件复制到phpcms目录.浏览器输 ...