好用漂亮的Android 表格框架

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

附上其他文章:

好用漂亮的Android 表格框架2

好用漂亮的Android 表格框架3

如何生成一个表格
 <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即可。

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>() {
            @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;

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

 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…

转载于:https://juejin.im/post/5a55ae6c5188257350511a8c

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android Studio框架布局是一种用于设计Android应用程序界面的布局方式。它是基于XML语言的,可以通过拖拽和放置控件来快速创建应用程序界面。Android Studio框架布局支持多种布局方式,如线性布局、相对布局、表格布局等,可以根据不同的需求选择不同的布局方式。同时,Android Studio框架布局还支持自定义控件和属性,可以让开发者更加灵活地设计应用程序界面。 ### 回答2: Android Studio是一款强大的开发工具,提供了多种布局方式。其中最常用的是框架布局(FrameLayout)。 框架布局是一种最简单的容器式布局,它允许在屏幕上放置一个或多个子视图,这些子视图是相对于父布局容器定位的,即它们的位置是相对于父视图左上角的。 使用框架布局时,应该先设计好UI界面,并理解布局的层级结构。在设计时,可以使用Android Studio中的布局编辑器来创建和编辑布局。可以在布局编辑器中使用拖拽和放置的方式来添加和移动控件。 框架布局可以实现复杂的层叠效果,可以添加遮罩层或通过设置透明度实现阴影效果等。此外,框架布局还可以通过设置子视图的相对位置来实现复杂的动态布局。 为了优化UI界面,建议使用适当的控件和UI元素来简化层级结构。如果层级结构太深,则会导致UI加载速度变慢,可能导致卡顿和崩溃等问题。 总之,框架布局是Android Studio中最常用的布局方式之一,它可以帮助我们创建简单的控件和UI元素,还可以在保持简单和易于维护的同时实现复杂的动态布局和效果。 ### 回答3: Android Studio是一款由Google开发的强大的集成开发环境(IDE)。它为开发人员提供了各种工具和功能来设计,构建和管理Android移动应用程序。在其中,Android Studio的布局框架是开发Android应用程序时不可或缺的一部分。 Android应用程序使用布局来确定界面元素(如按钮、文本框和图像)的位置。Android Studio有三种不同的布局框架:线性布局、相对布局和帧布局。每种布局框架都有其独特的特点和用途。 线性布局是Android应用程序中最基本的布局之一。它根据设置方向的默认方向(水平或垂直)在屏幕上按顺序排列界面元素。在线性布局中,每个元素必须定义权重和宽度或高度。这种布局适合简单的界面和小型应用程序。 相对布局是基于元素之间的相对位置排列的。在相对布局中,每个元素与其父元素或其他元素有一定的关系。每个元素可以相对于其他元素靠近或远离。相对布局适合复杂的界面和大型应用程序。但是,这种布局可能需要更多的时间来完成。 帧布局充当图像框,并包含单个组件并允许它们覆盖。在帧布局中,只有一个元素是显示出来的,其他元素被堆叠在一起。帧布局适用于需要通过一些图像或动画来显示自己的应用程序。 此外,在Android Studio中,您还可以使用约束布局进行自适应屏幕设计,自动调整不同的大小屏幕上的组件,使得应用程序在所有屏幕大小和设备中都能显示出最佳的效果。 总之,Android Studio的布局框架很重要,因为它可以帮助我们开发出漂亮、易于使用的Android应用程序。根据应用程序的需求和复杂程度选择正确的布局框架是至关重要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值