Android
表格使用的频率并不高,以前花了心思写了SmartTable表格,以为android移动端表格就应该是这个样子的,地址github.com/huangyanbin…,一直放在github
上无人问津,最近有同窗说蛮好用的,为啥没更新下去。便想写这边文章推销推销。也算值了!我按功能点一一介绍下:html
附上其余文章:android
好用漂亮的Android 表格框架3github
<com.bin.david.form.core.SmartTable
android: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
便可。bash
final Column<String> nameColumn = new Column<>("姓名", "name");
final Column<Integer> ageColumn = new Column<>("年龄", "age");
...
tableData = new TableData<>("测试",list,nameColumn,ageColumn...);
table.setTableData(tableData);
复制代码
确定有人说,这点功能,呵呵。来来,咱们坐一下,开始展现丰富的功能。界面不美观,看这里,格式化一下内容背景:app
table.getConfig().setContentBackgroundFormat(new BaseBackgroundFormat<CellInfo>() {
@Override
public int getBackGroundColor() {
return ContextCompat.getColor(AnnotationModeActivity.this,R.color.content_bg);
}
@Override
public boolean isDraw(CellInfo cellInfo) {
return cellInfo.position%2 ==0;
}
});
复制代码
发现时间这个列很不美观,咱们想要格式化一下时间这列框架
final IFormat<Long> format = new IFormat<Long>() {
@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<Long> timeColumn = new Column<>("时间", "time",format);
复制代码
还支持表格图文、序列号、列标题格式化;表格各组成背景、文字、网格、padding等配置,你能够参考demo;ide
勾选这列,咱们想展现勾选的图标布局
int size = DensityUtils.dp2px(this,15); //指定图标大小
Column<Boolean> checkColumn = new Column<>("勾选", "isCheck",new ImageResDrawFormat<Boolean>(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<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) {
@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<Integer>() {
@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<Integer> tableData = ArrayTableData.create("日程表",week,infos,new IDrawFormat<Integer>(){
@Override
public int measureWidth(Column<Integer> column, TableConfig config) {
return DensityUtils.dp2px(ArrayModeActivity.this,50);
}
@Override
public int measureHeight(Column<Integer> column, int position, TableConfig config) {
return DensityUtils.dp2px(ArrayModeActivity.this,50);
}
@Override
public 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)
来实现添加数据.
在网上参考了
html
的table
,发现样式好看多了,按到这个思路,SmartTable增长了支持对单个格子的不一样背景支持,在TableConfig
里面有5个IBackgroundFormat
样式,能够根据boolean isDraw(T t)
返回数据作出判断是否绘制背景drawBackground
,默认绘制整个背景,固然你能够本身定义IBackgroundFormat
使用其余形状。
因为支持到单个格子背景的支持,字体颜色也须要根据背景还进行调整,因此又支持单个格子的字体设置,
IBackgroundFormat
中有int getTextColor(T t)
,你只需重写它,根据需求设置不一样颜色。
在客户端太多数据体验很差,因此开发分页模式,在未使用注解状况下,只须要使用
PageTableData
分页表格数据类 代替以前TableData
表格数据类便可,使用PageTableData
的setPageSize
方法设置每页数量。分页就完成了。 若是你使用注解,请在@SmartTable
注解元素添加pageSize
属性便可,setData
会返回PageTableData
对象,你可使用它完成后面其余的设置。
SmartTable 增长notifyDataChanged方法用于从新解析计算布局;
提供back方法fling到原点。
![]()