Android自定义DataGridView数据表格控件

我是一个.net程序员,但是苦于公司要求开发一个android app,没办法,只能硬着头皮上了。

由于项目里面很多地方需要用到数据显示控件(类似于.net的DataGridView),度娘找了下发现没人公开类似的控件,没办法只好自己写了。

废话不多说,直接贴代码:

public class DataGridView extends HorizontalScrollView {
 private List<DataGridViewColumn> columns;
 private List<Map<String,String>> rows;

 private boolean hasHeader;

 private CellClickListener cellClickListener;
 private RowClickListener rowClickListener;
 private RowValidatorListener rowValidatorListener;
 private LinearLayout headerRow;
 private LinearLayout bodyRow;

 public DataGridView(Context context, AttributeSet attrs) {
  super(context, attrs);
  TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.DataGridView);
  hasHeader = a.getBoolean(R.styleable.DataGridView_hasHeader, true);
  a.recycle();

  LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  LinearLayout container = (LinearLayout) inflater.inflate(R.layout.ctrl_data_grid_view, null, false);
  addView(container);
  this.columns = new ArrayList<DataGridViewColumn>();
  this.rows = new ArrayList<Map<String,String>>();
   headerRow = new LinearLayout(getContext());
   headerRow.setOrientation(LinearLayout.HORIZONTAL);
   headerRow.setBackgroundResource(R.drawable.datagrid_header_background);
   headerRow.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
  if (hasHeader){
   container.addView(headerRow);
  }
  ScrollView scrollView = (ScrollView)inflater.inflate(R.layout.ctrl_data_grid_view_scroll, container, false);
  bodyRow = (LinearLayout) inflater.inflate(R.layout.ctrl_data_grid_view, scrollView, false);
  scrollView.addView(bodyRow);
  container.addView(scrollView);
 }

 public void addColumn(String dataField, String headerText){
  this.addColumn(dataField, headerText, 200);
 }

 public void addColumn(String dataField, String headerText, int columnWidth){
  this.addColumn(dataField, headerText, columnWidth, Gravity.START);
 }

 public void addColumn(String dataField, String headerText, int columnWidth, int textAlign){
  this.addColumn(dataField, headerText, columnWidth, textAlign, Color.rgb(80, 80, 80));
 }

 public void addColumn(String dataField, String headerText, int columnWidth, int textAlign, int textColor){
  this.addColumn(dataField, headerText, columnWidth, textAlign, textColor, true);
 }

 public void addColumn(String dataField, String headerText, int columnWidth, int textAlign, int textColor, boolean isEnabled){
  DataGridViewColumn column = new DataGridViewColumn();
  column.dataField =dataField;
  column.headerText = headerText;
  column.columnWidth = columnWidth;
  column.textAlign = textAlign;
  column.textColor = textColor;
  column.isEnabled = isEnabled;
  this.addColumn(column);
 }

 public void addColumn(DataGridViewColumn column){
  columns.add(column);
  insertColumn(column);
  if (rows.size() > 0){
   bodyRow.removeAllViews();
   for (Map<String,String> row : rows){
    insertRow(row);
   }
  }
 }

 public void addColumn(DataGridViewColumn column, int index){
  columns.add(column);
  insertColumn(column, index);
  if (rows.size() > 0){
   bodyRow.removeAllViews();
   for (Map<String,String> row : rows){
    insertRow(row);
   }
  }
 }

 public void removeColumn(int index){
  columns.remove(index);
 }

 public void removeColumn(String dataField){
  for (DataGridViewColumn column : columns){
   if (column.dataField.equals(dataField)){
    this.removeColumn(column);
    if (rows.size() > 0){
     bodyRow.removeAllViews();
     for (Map<String,String> row : rows){
      insertRow(row);
     }
    }
    return;
   }
  }
 }

 public void removeColumn(DataGridViewColumn column){
  columns.remove(column);
 }

 public void setDataSource(List<Map<String,String>> rows){
  this.rows = rows;
  if (columns.size() > 0){
   bodyRow.removeAllViews();
   for (Map<String,String> row : rows){
    insertRow(row);
   }
  }
 }

 public void addRow(Map<String,String> row){
  rows.add(row);
  if (columns.size() > 0) {
   insertRow(row);
  }
 }

 public void addRow(Map<String,String> row, int index){
  rows.add(index, row);
  if (columns.size() > 0) {
   insertRow(row, index);
  }
 }

 public void removeRow(int index){
  rows.remove(index);
  bodyRow.removeViewAt(index);
 }

 public void removeRow(Map<String,String> row){
  int index = rows.indexOf(row);
  this.removeRow(index);
 }

 public void setCellClickListener(CellClickListener cellClickListener) {
  this.cellClickListener = cellClickListener;
 }

 public void setRowClickListener(RowClickListener rowClickListener) {
  this.rowClickListener = rowClickListener;
 }

 public void setRowValidatorListener(RowValidatorListener rowValidatorListener) {
  this.rowValidatorListener = rowValidatorListener;
 }

 public boolean isHasHeader() {
  return hasHeader;
 }

 public void setHasHeader(boolean hasHeader) {
  this.hasHeader = hasHeader;
 }

 private void insertColumn(DataGridViewColumn column){
  this.insertColumn(column, -1);
 }

 private void insertColumn(DataGridViewColumn column, int index){
  LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  TextView headerTextView = (TextView) inflater.inflate(R.layout.ctrl_data_grid_view_column, headerRow, false);
  headerTextView.setText(column.headerText);
  headerTextView.setLayoutParams(new LayoutParams(column.columnWidth, LayoutParams.WRAP_CONTENT, 1));
  if (index == -1){
   headerRow.addView(headerTextView);
  }else {
   headerRow.addView(headerTextView, index);
  }
 }

 public DataGridViewColumn getColumn(int index){
  return columns.get(index);
 }

 private void insertRow(final Map<String, String> row){
  this.insertRow(row, -1);
 }

 private void insertRow(final Map<String,String> row, int index){
  LinearLayout dataRow = new LinearLayout(getContext());
  dataRow.setOrientation(LinearLayout.HORIZONTAL);
  dataRow.setSelected(true);
  dataRow.setClickable(true);
  dataRow.setBackgroundResource(R.drawable.datagrid_row_border);
  dataRow.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
  LayoutInflater inflater = (LayoutInflater) getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  for (final DataGridViewColumn column : columns){
   String cellText = row.get(column.dataField);
   TextView rowFieldText = (TextView) inflater.inflate(R.layout.ctrl_data_grid_view_cell, dataRow, false);
   rowFieldText.setText(cellText);
   rowFieldText.setGravity(column.textAlign);
   rowFieldText.setTextColor(column.textColor);
   rowFieldText.setLayoutParams(new LayoutParams(column.columnWidth, LayoutParams.WRAP_CONTENT, 1));
   dataRow.addView(rowFieldText);
   if (column.isEnabled) {
    rowFieldText.setOnClickListener(new OnClickListener() {
     @Override
     public void onClick(View v) {
      if (cellClickListener != null) {
       cellClickListener.onClick(row, column.dataField);
      }
     }
    });
   } else {
    rowFieldText.setTextColor(Color.rgb(128, 128, 128));
   }
  }
  if (rowValidatorListener != null){
   rowValidatorListener.onValidator(dataRow, row);
  }
  if (index == -1){
   bodyRow.addView(dataRow);
  }else {
   bodyRow.addView(dataRow, index);
  }
  dataRow.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    if (rowClickListener != null) {
     rowClickListener.onClick(row);
    }
   }
  });
 }

 public void updateRow(Map<String,String> row){
  int index = rows.indexOf(row);
  bodyRow.removeViewAt(index);
  this.insertRow(row, index);
 }

 public Map<String,String> getRow(int index) {
  return rows.get(index);
 }

 public int getColumnsCount() {
  return columns.size();
 }

 public int getRowsCount() {
  return rows.size();
 }

 public interface CellClickListener{
  void onClick(Map<String,String> rowData, String dataField);
 }

 public interface RowClickListener{
  void onClick(Map<String,String> rowData);
 }

 public interface RowValidatorListener{
  void onValidator(ViewGroup v,Map<String,String> rowData);
 }
}

代码里面用到的列属性类也附上:

public class DataGridViewColumn {
 public String dataField;
 public String headerText;
 public int columnWidth;
 public int textAlign;
 public int textColor;
 public boolean isEnabled;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android 利用ViewPager+GridView实现首页导航栏布局分页效果

    最近我尝试使用ViewPager+GridView实现的,看起来一切正常,废话不多说,具体代码如下: 如图是效果图 首先分析下思路 1.首先是怎么布局:整体是一个ViewPager将GridView作为一个View添加到ViewPager的adapter中,下方是圆点 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.a

  • Android中控件GridView实现设置行列分割线的方法示例

    前言 虽然Aandroid目前已经有RecyclerView了.非常强大的一个View.可以直接控制成ListView以及GridView等.而且画框线也比较方便.但是呢在很多情况下我们不得不仍然使用GridView来实现布局.那么在这个时候我们又要怎么来对GridViw进行画框线呢.下面将提供两种实现方式.大家可以选择一下 一.设置垂直.横向间距.通过GRIDVIEW和ITEM的背景色来实现 1.设置GridView背景色 2.设置水平和竖直方向间隔:android:horizontalSpa

  • Android 中 GridView嵌套在ScrollView里只有一行的解决方法

    在做android项目中遇到一个bug,GridView嵌套在ScrollView里只有一行的问题.下面小编在网上找到了解决方法,具体方法如下所示: 方法一:就是上面说的通过计算出来ListView或者GridView中的子列高度和 进行显示: public void setListViewHeightBasedOnChildren(ListView listView) { ListAdapter listAdapter = listView.getAdapter(); if (listAdap

  • Android GridView简单实例

    也是今天用到的一个东西,就是简单实现九宫格的Demo 1.就是定义各种layout 和对应的item 我的: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" and

  • Android使用GridView实现日历的简单功能

    简单的日历实现,只是显示了每一个月,没有显示当天和记事这些功能 主要是计算月初是周几,月末是周几,然后相应的显示上一月多少天和下一月多少天. 先看一下关于日期的用到的几个工具类 /** * 获取该月天数 */ public static int getCurrentMonthDay(long millSec) { Calendar calendar = Calendar.getInstance(); calendar.setTimeInMillis(millSec); calendar.set(

  • android中GridView实现点击查看更多功能示例

    首先来看一下效果图:   先说一下我的需求:查看群成员,如果超过15人则全部显示,如果大于15人则先加载15人,其余的不显示,点击查看更多则加载全部.再来说一下我实现的逻辑:首先呢要判断群成员的人数,如果小于或者等于15就用GridView加载全部数据,隐藏查看更多的按钮.如果大于15人,则显示加载更多的按钮,先加载15条数据,其余的不加载,点击按钮之后获取全部数据放到自己写好的adapter里然后加载刷新,再隐藏加载更多的按钮. 好了,来看代码: <LinearLayout android:l

  • Android使用GridView实现日历功能示例(详细代码)

    Android使用GridView实现日历功能示例,代码有点多,发个图先: 如果懒得往下看的,可以直接下载源码吧,最近一直有人要,由于时间太久了,懒得找出来整理,今天又看到有人要,正好没事就整理了一下 源码下载.... 布局文件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/an

  • Android GridView实现动画效果实现代码

     Android GridView实现动画效果 项目中用到的一些动画,GridView的Item依次从屏幕外飞入到相应位置,附上相关代码: MainActivity.Java package com.mundane.gridanimationdemo; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.view.an

  • Android自定义DataGridView数据表格控件

    我是一个.net程序员,但是苦于公司要求开发一个android app,没办法,只能硬着头皮上了. 由于项目里面很多地方需要用到数据显示控件(类似于.net的DataGridView),度娘找了下发现没人公开类似的控件,没办法只好自己写了. 废话不多说,直接贴代码: public class DataGridView extends HorizontalScrollView { private List<DataGridViewColumn> columns; private List<

  • Android自定义view实现输入控件

    本文实例为大家分享了Android自定义view实现输入控件的具体代码,供大家参考,具体内容如下 网络上大部分的输入控件都是多个EditText组合而成,本例中采用的是: 单个EditText作为输入的捕捉控件 多个ImageView的子类作为显示的控件,绘制EditText中的数据 如上图: 输入前和输入后输入框需要发生响应的改变 点击自定义控件要弹出软键盘 EditText数据捕捉,以及EditView不能操作(如果可以操作,数据处理会混乱) 输完后会得到相应的提示 ImageView的子类

  • Android自定义View之组合控件实现类似电商app顶部栏

    本文实例为大家分享了Android自定义View之组合控件,仿电商app顶部栏的相关代码,供大家参考,具体内容如下 效果图: 分析:左右两边可以是TextView和Button,设置drawableTop即可,中间的看着像是EditText,但是用过淘宝天猫等类似app的话会发现点击搜索不是在当前Activit进行搜索的,是跳转到另外的页面进行的,所以用TextView然后设置背景即可. 实现流程 参数列表: 设置属性文件:values下建立attrs.xml文件,添加需要自定义的属性. <?x

  • Android 自定义底部上拉控件的实现方法

    前言 又到了新的一月,今天提供一个Android自定义底部上拉布局的实现,起因是自己在项目中需要实现这样一个控件,干脆自己写一个练练手. 写完了觉得能想到的需求都基本有了(可能会有其它需求,不过基本上改吧改吧就行了),又花了一点时间直接放到了Github上托管,希望能给您一些参考价值: SlideBottomLayout-Android 简单易上手的Android底部上拉控件 先看一下实现效果: 分析一下这种控件的基本需求有以下几种: 1.有一个部分是能够作为把手(就是图中的handle,)进行

  • android自定义圆形倒计时显示控件

    本文实例为大家分享了android自定义圆形倒计时显示控件的具体代码,供大家参考,具体内容如下 先上效果图 - 倒计时结束 代码块 attr.xml 控件需要用到的属性: <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="CountDownView"> <!--颜色--> <attr name

  • Android自定义顶部导航栏控件实例代码

    下面一段代码给大家介绍了android 自定义顶部导航栏控件功能,具体代码如下所示: class HeaderBar @JvmOverloads constructor( context: Context, attrs: AttributeSet? = null, defStyleAttr: Int = 0 ) : FrameLayout(context, attrs, defStyleAttr) { //重写构造方法 在java里面 我们一般是重写三个构造方法//在kotlin中 我们可以使用

  • android自定义WaveView水波纹控件

    本文实例为大家分享了android自定义WaveView水波纹控件的使用方法,供大家参考,具体内容如下 Github Repository and libaray WaveView水波纹控件 首先看下演示demo demo中可以看到不同高度,不同速度,不同幅度的水波纹:你可以通过view的参数直接控制view的表现形式. 引入你的工程 在项目的根目录下的build.gradle文件中添加如下代码: allprojects { repositories { ... maven { url 'htt

  • Android 自定义日期段选择控件功能(开始时间-结束时间)

    开发中碰到个需求,需要在一个空间中选择完成开始和结束时间.实现的过程走的是程序员开发的老路子,找到轮子后自己改吧改吧就成了. 当时做的时候有几个需求:1.当天为最大的结束日期,2.最大选择范围1年,3.开始时间和结束时间可以为同一天.如有其他需求实现,可以参考代码改进一下.先上效果图: 视频点击后的虚影是屏幕录制的原因.实现步骤:(如有缺失什么资源,请告知.开始时间和结束时间显示自己布局内添加就可以) 1.自定义控件属性 <declare-styleable name="MyCalenda

  • Android自定义view实现倒计时控件

    本文实例为大家分享了Android自定义view实现倒计时控件的具体代码,供大家参考,具体内容如下 直接上代码 自定义TextView 文字展示 public class StrokeTextView extends TextView { private TextView borderText = null;///用于描边的TextView private Context mContext; public StrokeTextView(Context context) { super(conte

  • Android自定义滑动接听电话控件组实例

    本文根据组件开发思想,首先介绍android自定义控件,然后将自定义的控件封装为jar包.最为实现滑动接听电话控件组. 一.目录结构 二.运行效果 三.代码实现 首先,自定义一个类IncomingPhone继承RelativeLayout public IncomingPhone(Context context, AttributeSet attrs) { super(context, attrs); mContext = context; TextView textView = new Tex

随机推荐