1.实现动态表格效果如下:
2.项目如下:
**3.activity_smart_table.xml,表格布局代码如下:**
<com.bin.david.form.core.SmartTable
android:id="@+id/table"
android:layout_weight="1"
android:layout_width="match_parent"
android:layout_height="0dp"
android:background="@color/gray_lightest"/>
4.SmartTableActivity.java,设置表名、表格数据
private void getDatas() {
String title = "表名";
String getDatas = "[{\"宿舍楼\":\"第一栋\",\"宿舍1001人数\":\"8\",\"宿舍1002人数\":\"2\",\"宿舍1003人数\":\"2\",\"宿舍1004人数\":\"1\",\"宿舍1005人数\":\"6\",\"宿舍1006人数\":\"6\"}," +
"{\"宿舍楼\":\"第二栋\",\"宿舍1001人数\":\"2\",\"宿舍1002人数\":\"3\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第三栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第四栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第五栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第六栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第七栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第八栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第九栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十一栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十二栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十三栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十四栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十五栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十六栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十七栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十八栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第十九栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第二十栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第二十一栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第二十二栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第二十三栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第三十四栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}," +
"{\"宿舍楼\":\"第三十五栋\",\"宿舍1001人数\":\"3\",\"宿舍1002人数\":\"1\",\"宿舍1003人数\":\"3\",\"宿舍1004人数\":\"2\",\"宿舍1005人数\":\"7\",\"宿舍1006人数\":\"8\"}]";
List<Object> json = JsonUtil.jsonToObjs(getDatas, Object.class);
MapTableData tableData = MapTableData.create(title, json,null);
table.setTableData(tableData);
}
4.1 未完整的代码MapTableData.java,开始创建新表格
/**
* 创建Map表格数据
*
* @param tableName 表格名
* @param mapList Map数组
*/
public static MapTableData create(String tableName, List<Object> mapList,String classity) {
return create(tableName, mapList, null,classity);
}
/**
* 创建Map表格数据
*
* @param tableName 表格名
* @param mapList Map数组
* @param keyFormat map中key格式化
*/
public static MapTableData create(String tableName, List<Object> mapList, IFormat<String> keyFormat,String classity) {
if (mapList != null) {
List<Column> columns = new ArrayList<>();
getMapColumn(columns, Column.INVAL_VALUE, Column.INVAL_VALUE, mapList, keyFormat);
if(classity!=null&&!classity.isEmpty()){
//根据classity 设置表头
columns = getNewColumn(columns,classity);
}
return new MapTableData(tableName, mapList, columns);
}
return null;
}
private static List<Column> getNewColumn(List<Column> columns, String classity) {
try{
if(columns.size() == 0){
return columns;
}
//多表头 重新组装表头
// List<Column> newColumns = new ArrayList<>();
//
// if("Get_***".equals(classity)){
// Column column0 = columns.get(0);column0.setColumnName("单位");
// newColumns.add(column0);
//
// Column column1 = columns.get(1);column1.setColumnName("***");
// Column column2 = columns.get(2);column2.setColumnName("***");
// Column column3 = columns.get(3);column3.setColumnName("***");
// Column column4 = columns.get(4);column4.setColumnName("***");
// Column column5 = columns.get(5);column5.setColumnName("***");
// newColumns.add(new Column("***", column1, column2, column3, column4, column5));
//
// Column column6 = columns.get(6);column6.setColumnName("***");
// Column column7 = columns.get(7);column7.setColumnName("***");
// Column column8 = columns.get(8);column8.setColumnName("***");
// Column column9 = columns.get(9);column9.setColumnName("***");
// Column column10 = columns.get(10);column10.setColumnName("***");
//
// newColumns.add(new Column("***", column6, column7, column8, column9, column10));
//
// return newColumns;
// }else if("Get***".equals(classity)){//设施建设情况统计
// newColumns.add(columns.get(0));
//
// newColumns.add(new Column("***", columns.get(1), columns.get(2), columns.get(3), columns.get(4)));
//
// Column column5 = columns.get(5);column5.setColumnName("***");
// newColumns.add(column5);
//
// Column column6 = columns.get(6);column6.setColumnName("***");
// newColumns.add(column6);
//
// newColumns.add(new Column("***", columns.get(7), columns.get(8), columns.get(9)));
//
// newColumns.add(new Column("***", columns.get(10), columns.get(11), columns.get(12), columns.get(13)));
//
// Column column14 = columns.get(14);column14.setColumnName("***");
// Column column15 = columns.get(15);column15.setColumnName("***");
// Column column16 = columns.get(16);column16.setColumnName("***");
// Column column17 = columns.get(17);column17.setColumnName("地方");
// Column column18 = columns.get(18);column18.setColumnName("***");
// Column column19 = columns.get(19);column19.setColumnName("其他");
// newColumns.add(new Column("***", column14, column15, column16, column17, column18,column19));
//
// newColumns.add(new Column("***", columns.get(20), columns.get(21), columns.get(22)));
//
//
// Column column23 = columns.get(23);column23.setColumnName("***");
// newColumns.add(column23);
//
// Column column24 = columns.get(24);column24.setColumnName("***");
// newColumns.add(column24);
//
// return newColumns;
// }else if("Get***".equals(classity)){//设施运行情况统计
// newColumns.add(columns.get(0));
// newColumns.add(new Column("项目数量", columns.get(1), columns.get(2), columns.get(3), columns.get(4)));
//
// newColumns.add(new Column("项目属性", columns.get(5), columns.get(6), columns.get(7), columns.get(8)));
//
// Column column9 = columns.get(9);column9.setColumnName("合计");
// Column column10 = columns.get(10);column10.setColumnName("***");
// Column column11 = columns.get(11);column11.setColumnName("***");
// Column column12 = columns.get(12);column12.setColumnName("地方");
// Column column13 = columns.get(13);column13.setColumnName("***");
// Column column14 = columns.get(14);column14.setColumnName("其他");
// newColumns.add(new Column("***", column9, column10, column11, column12, column13, column14));
//
// Column column15 = columns.get(15);column15.setColumnName("***");
// newColumns.add(column15);
//
//
// Column column16 = columns.get(16);column16.setColumnName("合计");
// newColumns.add(new Column("***", column16, columns.get(17), columns.get(18)));
//
// newColumns.add(new Column("***", columns.get(19), columns.get(20), columns.get(21)));
//
// return newColumns;
// }
return columns;
}catch (Exception e){
e.printStackTrace();
return columns;
}
}
......
private MapTableData(String tableName, List t, List<Column> columns) {
super(tableName, t, columns);
//固定第一列//
if(columns.size() > 0){
columns.get(0).setFixed(true);
}
/
}
5.源代码zip地址下载点击链接:下载源代码