好用漂亮的Android 表格框架2(1)

//造假数据 仿github贡献图
String[] week = {“日”,“一”,“二”,“三”,“四”,“五”,“六”};
Integer[][] infos = {{0,1,2,1,1,0,1,1,0,1,1,2,3}, {4,2,1,1,0,1,1,0,1,1,2,2,3},
{2,2,0,1,2,4,1,0,1,3,0,1,1},{2,1,1,0,1,4,0,1,1,2,2,0,3},
{0,1,2,4,1,0,1,4,0,1,1,2,2}, {1,0,1,3,2,2,0,1,2,1,1,0,4},
{3,1,2,4,0,1,2,1,1,0,1,1,0}};
ArrayTableData tableData = ArrayTableData.create(“日程表”,week,infos,new IDrawFormat(){
@Override
public int measureWidth(Column column, TableConfig config) {
//设置宽50dp
return DensityUtils.dp2px(ArrayModeActivity.this,50);
}

@Override
public int measureHeight(Column column, int position, TableConfig config) {
//设置高50dp
return DensityUtils.dp2px(ArrayModeActivity.this,50);
}
@Override
public void draw(Canvas c, Column column, Integer integer, String value, Rect rect, int position, TableConfig config) {
Paint paint = config.getPaint();
int color;
switch (integer){
case 1:
color =R.color.github_con_1;
break;
case 2:
color =R.color.github_con_2;
break;

break;
}
//绘制正方形
c.drawRect(rect.left+5,rect.top+5,rect.right-5,rect.bottom-5,paint);
}
});
//点击事件
tableData.setOnItemClickListener(new ArrayTableData.OnItemClickListener() {
@Override
public void onClick(Column column, String value, Integer o, int col, int row) {
Toast.makeText(ArrayModeActivity.this,“列:”+col+ " 行:"+row + “数据:”+value,Toast.LENGTH_SHORT).show();
}
});
//设置表格数据
table.setTableData(tableData);

就是这么简单。IDrawFormat是格式化样式的接口。其中我几种提供图片和文字多行格式化等。这里直接实现接口,measureWidthmeasureHeight方法用于指定Cell格子大小。二维数组里面数据为null也是可以的。

你可能会说,我不想要列标题显示出来,OK,你也可以不用列标题。下面是选座的示例。

final ArrayTableData tableData = ArrayTableData.create(table, “选座表”, data, new ImageResDrawFormat(size,size) {
@Override
protected Context getContext() {
return SeatModeActivity.this;
}

@Override
protected int getResourceID(Integer status, String value, int position) {
if(status == null){return 0;}
switch (status){
case 0:
return R.mipmap.seat;
case 1:
return R.mipmap.seat_selected;
}
return 0;
}

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

展示Excel

展示Excel也是使用ArrayTableData就可以。导入数据现在可以通过POI,jxl。我这里使用的jxl.下面是个示例:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

public class ExcelAsyncTask extends AsyncTask<Integer,Void,String[][]>{

@Override
protected String[][] doInBackground(Integer… position) {

try {
int maxRow, maxColumn;
cellRanges = null;
InputStream is = getAssets().open(fileName);
Workbook workbook = Workbook.getWorkbook(is);
Sheet sheet = workbook.getSheet(position[0]);
maxRow = sheet.getRows();
maxColumn = sheet.getColumns();
String[][] data = new String[maxRow][];
for (int i = 0; i < maxRow; i++) {
String[] rows = new String[maxColumn];
for(int j = 0;j < maxColumn;j++){
Cell cell = sheet.getCell(j, i);
if(cell !=null){
rows[j] = cell.getContents();
}else{
rows[j] = null;
}
}
data[i] = rows;
}
workbook.close();
String[][] newData = new String[maxColumn][maxRow];
for (int i = 0; i < data.length; i++) { //转换一下
for (int j = 0; j < data[i].length; j++) {
newData[j][i] = data[i][j]; // 转置核心
}
}
return newData;

} catch (Exception e) {

}

return null;
}

@Override
protected void onPostExecute(String[][] data) {
if(data null || data.length0) {
data = new String[26][50]; //空白表格美观
}
ArrayTableData tableData = ArrayTableData.create(table, “Excel表”, data, new TextDrawFormat());
tableData.setCellRangeAddresses(cellRanges);
table.setTableData(tableData);

}
}

gif效果不是很清楚,贴张截图

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
**

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值