好用漂亮的Android 表格框架

2024-08-29 06:32

本文主要是介绍好用漂亮的Android 表格框架,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载 掘金 https://juejin.im/post/5a55ae6c5188257350511a8c?utm_source=gold_browser_extension#comment

作者:黄燕斌
链接:https://juejin.im/post/5a55ae6c5188257350511a8c
来源:掘金

Android 表格使用的频率并不高,之前花了心思写了SmartTable表格,觉得android移动端表格就应该是这个样子的,地址github.com/huangyanbin…,一直放在github上无人问津,最近有同学说蛮好用的,为啥没更新下去。便想写这边文章推销推销。也算值了!我按功能点一一介绍下:

附上其他文章:

好用漂亮的Android 表格框架2

好用漂亮的Android 表格框架3

如何生成一个表格
 <com.bin.david.form.core.SmartTableandroid:id="@+id/table"android:layout_width="match_parent"android:layout_height="300dp"/>

可以通过注解@SmartTable表格注解 @SmartColumn字段注解

@SmartTable(name="用户信息列表")
public class UserInfo {@SmartColumn(id =1,name = "姓名")private String name;@SmartColumn(id=2,name="年龄")private int age;...
}List<UserInfo> list = new ArrayList<>();...table = (SmartTable<UserInfo>) findViewById(R.id.table);table.setData(list);

OK,这就是最简单的注解版。下面看下强大功能的普通版。只需要创建需要显示的列,设置需要解析的字段就可以,假设需要解析到UserInfo.parent.name,只需parent.name即可。

final Column<String> nameColumn = new Column<>("姓名", "name");
final Column<Integer> ageColumn = new Column<>("年龄", "age");...tableData = new TableData<>("测试",list,nameColumn,ageColumn...);table.setTableData(tableData);
美化

肯定有人说,这点功能,呵呵。来来,我们坐一下,开始展示丰富的功能。界面不美观,看这里,格式化一下内容背景:

 table.getConfig().setContentBackgroundFormat(new BaseBackgroundFormat<CellInfo>() {@Overridepublic int getBackGroundColor() {return ContextCompat.getColor(AnnotationModeActivity.this,R.color.content_bg);}@Overridepublic boolean isDraw(CellInfo cellInfo) {return cellInfo.position%2 ==0;}});

格式化数据

发现时间这个列很不美观,我们想要格式化一下时间这列

final IFormat<Long> format =  new IFormat<Long>() {@Overridepublic String format(Long aLong) {Calendar calendar = Calendar.getInstance();calendar.setTimeInMillis(aLong);return calendar.get(Calendar.YEAR)+"-"+(calendar.get(Calendar.MONTH)+1)+"-"+calendar.get(Calendar.DAY_OF_MONTH);}};
final Column<Long> timeColumn = new Column<>("时间", "time",format);

还支持表格图文、序列号、列标题格式化;表格各组成背景、文字、网格、padding等配置,你可以参考demo;

勾选这列,我们想展示勾选的图标

 int size = DensityUtils.dp2px(this,15); //指定图标大小Column<Boolean> checkColumn = new Column<>("勾选", "isCheck",new ImageResDrawFormat<Boolean>(size,size) {@Overrideprotected Context getContext() {return AnnotationModeActivity.this;}@Overrideprotected int getResourceID(Boolean isCheck, String value, int position) {if(isCheck){return R.mipmap.check;}return 0;}});

提供支持文字,多行文字,文字和图标组合(上下左右)

表格一般可以统计功能,我们开启统计功能setShowCount(true),哪列需要统计开启setAutoCount即可,数字如果统计就是相加,文字就是取最长的大小

 tableData.setShowCount(true);nameColumn.setAutoCount(true);

但是这样不满足真实需求,需求往往很坑爹。所以提供了统计接口。下面是统计最大时间示例:

 timeColumn.setAutoCount(true);timeColumn.setCountFormat(new ICountFormat<Long, Long>() {private long maxTime;@Overridepublic void count(Long aLong) {if(aLong > maxTime){maxTime = aLong;}}@Overridepublic Long getCount() {return maxTime;}@Overridepublic String getCountString() {return format.format(maxTime);}@Overridepublic void clearCount() {maxTime =0;}});

有时候我们需要标题组合,这个时候就可以这样玩:

Column groupColumn = new Column("组合",nameColumn,ageColumn);
TableData<UserInfo> tableData = new TableData<>("用户表",userInfos,groupColumn,timeColumn,checkColumn);

动效

固定指定列和X序号列,Y序号列,列标题,统计行。你可以根据需求开启,组合效果真的很棒

//固定指定列timeColumn.setFixed(true);//Y序号列table.getConfig().setFixedYSequence(true);//X序号列table.getConfig().setFixedXSequence(true);//列标题table.getConfig().setFixedCountRow(true);//统计行table.getConfig().setFixedTitle(true);

缩放

当然肯定少不了放大和缩小

table.setZoom(true);
//可以设置放大最大和最小值setZoom(boolean zoom,float maxZoom,float minZoom);

事件

批注和点击事件

table.setOnColumnClickListener();MultiLineBubbleTip<Column> tip = new MultiLineBubbleTip<Column>(this,R.mipmap.round_rect,R.mipmap.triangle,fontStyle) {@Overridepublic boolean isShowTip(Column column, int position) {if(column == nameColumn){return true;}return false;}@Overridepublic String[] format(Column column, int position) {UserInfo data = testData.get(position);String[] strings = {"批注","姓名:"+data.getName(),"年龄:"+data.getAge()};return strings;}};

排序

可以通过设置列,然后列条件来排序。

//设置排序列,设置是否反序table.setSortColumn(ageColumn,false);

如果觉得还是不满足,可以自己定义排序规则

ageColumn.setComparator(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o1- o2;}});

支持二维数组

你可以使用ArrayTableData来代替TableData。就可以愉快的使用二维数组,你甚至可以不用设置列标题。这样可以实现一些类似选票和选座app需求。

 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<Integer> tableData = ArrayTableData.create("日程表",week,infos,new IDrawFormat<Integer>(){@Overridepublic int measureWidth(Column<Integer> column, TableConfig config) {return DensityUtils.dp2px(ArrayModeActivity.this,50);}@Overridepublic int measureHeight(Column<Integer> column, int position, TableConfig config) {return DensityUtils.dp2px(ArrayModeActivity.this,50);}@Overridepublic void draw(Canvas c, Column<Integer> 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;case 3:color =R.color.github_con_3;break;case 4:color =R.color.github_con_4;break;default:color =R.color.github_con_0;break;}paint.setStyle(Paint.Style.FILL);paint.setColor(ContextCompat.getColor(ArrayModeActivity.this, color));c.drawRect(rect.left+5,rect.top+5,rect.right-5,rect.bottom-5,paint);}});

其他

还有很多功能点,包括动态添加首尾数据,分页,格式化字体,背景等。这里不一一介绍了。

  • 支持首尾动态添加数据

首尾动态添加数据 SmartTable.addData(List<T> t,boolean isFoot)来实现添加数据.

  • 设置单个格子背景

在网上参考了htmltable,发现样式好看多了,按到这个思路,SmartTable增加了支持对单个格子的不同背景支持,在TableConfig里面有5个IBackgroundFormat样式,可以根据boolean isDraw(T t)返回数据做出判断是否绘制背景drawBackground,默认绘制整个背景,当然你可以自己定义IBackgroundFormat使用其他形状。

  • 设置单个格子字体

由于支持到单个格子背景的支持,字体颜色也需要根据背景还进行调整,所以又支持单个格子的字体设置,IBackgroundFormat中有 int getTextColor(T t),你只需重写它,根据需求设置不同颜色。

  • 分页

在客户端太多数据体验不好,所以开发分页模式,在未使用注解情况下,只需要使用PageTableData分页表格数据类 代替之前TableData表格数据类即可,使用PageTableDatasetPageSize方法设置每页数量。分页就完成了。如果你使用注解,请在@SmartTable注解元素添加pageSize属性即可,setData会返回PageTableData对象,你可以使用它完成后面其他的设置。

  • 其他

SmartTable 增加notifyDataChanged方法用于重新解析计算布局;

提供back方法fling到原点。

github地址

github.com/huangyanbin…

公众号 更新Java,Android知识




这篇关于好用漂亮的Android 表格框架的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1117107

相关文章

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

无线路由器哪个品牌好用信号强? 口碑最好的三个路由器大比拼

《无线路由器哪个品牌好用信号强?口碑最好的三个路由器大比拼》不同品牌在信号覆盖、稳定性和易用性等方面各有特色,如何在众多选择中找到最适合自己的那款无线路由器呢?今天推荐三款路由器让你的网速起飞... 今天我们来聊聊那些让网速飞起来的路由器。在这个信息爆炸的时代,一个好路由器简直就是家庭网编程络的心脏。无论你

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

无线领夹麦克风什么牌子好用?揭秘领夹麦克风哪个牌子音质好!

随着短视频行业的星期,围绕着直播和视频拍摄的电子数码类产品也迎来了热销不减的高增长,其中除了数码相机外,最为重要的麦克风也得到了日益增长的高需求,尤其是无线领夹麦克风,近几年可谓是异常火爆。别看小小的一对无线麦克风,它对于视频拍摄的音质起到了极为关键的作用。 不过目前市面上的麦克风品牌种类多到让人眼花缭乱,盲目挑选的话容易踩雷,那么无线领夹麦克风什么牌子好用?今天就给大家推荐几款音质好的

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF