好用漂亮的Android 表格框架

Android 表格使用的頻率並不高,以前花了心思寫了SmartTable表格,以爲android移動端表格就應該是這個樣子的,地址github.com/huangyanbin…,一直放在github上無人問津,最近有同窗說蠻好用的,爲啥沒更新下去。便想寫這邊文章推銷推銷。也算值了!我按功能點一一介紹下:html

附上其餘文章:android

好用漂亮的Android 表格框架2git

好用漂亮的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)來實現添加數據.

  • 設置單個格子背景

在網上參考了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…

相關文章
相關標籤/搜索