格式化数据
发现时间这个列很不美观,我们想要格式化一下时间这列
final IFormat format = new IFormat() {
@Override
public 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 timeColumn = new Column<>(“时间”, “time”,format);
还支持表格图文、序列号、列标题格式化;表格各组成背景、文字、网格、padding等配置,你可以参考demo;
勾选这列,我们想展示勾选的图标
int size = DensityUtils.dp2px(this,15); //指定图标大小
Column checkColumn = new Column<>(“勾选”, “isCheck”,new ImageResDrawFormat(size,size) {
@Override
protected Context getContext() {
return AnnotationModeActivity.this;
}
@Override
protected 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;
@Override
public void count(Long aLong) {
if(aLong > maxTime){
maxTime = aLong;
}
}
@Override
public Long getCount() {
return maxTime;
}
@Override
public String getCountString() {
return format.format(maxTime);
}
@Override
public void clearCount() {
maxTime =0;
}
});
有时候我们需要标题组合,这个时候就可以这样玩:
Column groupColumn = new Column(“组合”,nameColumn,ageColumn);
TableData 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 tip = new MultiLineBubbleTip(this,R.mipmap.round_rect,R.mipmap.triangle,fontStyle) {
@Override
public boolean isShowTip(Column column, int position) {
if(column == nameColumn){
return true;
}
return false;
}
@Override
public 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() {
@Override
public 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 tableData = ArrayTableData.create(“日程表”,week,infos,new IDrawFormat(){
@Override
public int measureWidth(Column column, TableConfig config) {
return DensityUtils.dp2px(ArrayModeActivity.this,50);
}
@Override
public int measureHeight(Column column, int position, TableConfig config) {
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;
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));
《设计思想解读开源框架》
第一章、 热修复设计
-
第一节、 AOT/JIT & dexopt 与 dex2oat
-
第二节、 热修复设计之 CLASS_ISPREVERIFIED 问题
-
第三节、热修复设计之热修复原理
-
第四节、Tinker 的集成与使用(自动补丁包生成)
第二章、 插件化框架设计
-
第一节、 Class 文件与 Dex 文件的结构解读
-
第二节、 Android 资源加载机制详解
-
第三节、 四大组件调用原理
-
第四节、 so 文件加载机制
-
第五节、 Android 系统服务实现原理
第三章、 组件化框架设计
-
第一节、阿里巴巴开源路由框——ARouter 原理分析
-
第二节、APT 编译时期自动生成代码&动态类加载
-
第三节、 Java SPI 机制
-
第四节、 AOP&IOC
-
第五节、 手写组件化架构
第四章、图片加载框架
-
第一节、图片加载框架选型
-
第二节、Glide 原理分析
-
第三节、手写图片加载框架实战
第五章、网络访问框架设计
-
第一节、网络通信必备基础
-
第二节、OkHttp 源码解读
-
第三节、Retrofit 源码解析
第六章、 RXJava 响应式编程框架设计
-
第一节、链式调用
-
第二节、 扩展的观察者模式
-
第三节、事件变换设计
-
第四节、Scheduler 线程控制
第七章、 IOC 架构设计
-
第一节、 依赖注入与控制反转
-
第二节、ButterKnife 原理上篇、中篇、下篇
-
第三节、Dagger 架构设计核心解密
第八章、 Android 架构组件 Jetpack
-
第一节、 LiveData 原理
-
第二节、 Navigation 如何解决 tabLayout 问题
-
第三节、 ViewModel 如何感知 View 生命周期及内核原理
-
第四节、 Room 架构方式方法
-
第五节、 dataBinding 为什么能够支持 MVVM
-
第六节、 WorkManager 内核揭秘
-
第七节、 Lifecycles 生命周期
本文包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
ataBinding 为什么能够支持 MVVM** -
第六节、 WorkManager 内核揭秘
-
第七节、 Lifecycles 生命周期
[外链图片转存中…(img-tS8CbrlX-1715245623790)]
本文包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…
[外链图片转存中…(img-YvzLTnqV-1715245623791)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!