Android GridView 实现合并单元格效果

package com.example.test;

import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.LinearLayout;
import android.widget.TextView;

public class MainActivity extends Activity {
	private static GridView mGridView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		mGridView = new GridView(getApplicationContext());
		MAdapter adapter = new MAdapter(mGridView.getContext(), new String[]{
			"你好1","你好2","你好3","你好4","你好5","你好6","你好7","你好8","你好9","你好10",
			"你好11","你好12","你好13","你好14","你好15","你好16","你好17","你好18","你好19","你好20",
			"你好21","你好22","你好23","你好24","你好25","你好26","你好27","你好28","你好29","你好30"
		});
		LinearLayout headLayout = new LinearLayout(getApplicationContext());
		LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
				LinearLayout.LayoutParams.FILL_PARENT, 300);
		headLayout.setLayoutParams(params);
		headLayout.setBackgroundColor(Color.RED);
		mGridView.setAdapter(adapter);
		mGridView.setNumColumns(2);
		setContentView(mGridView);
	}

	static class MAdapter extends BaseAdapter{

		private String[] items;
		private Context context;
		public MAdapter(Context context, String[] items) {
			this.items = items;
			this.context = context;
		}

		@Override
		public int getCount() {
			return items.length;
		}

		@Override
		public Object getItem(int position) {
			return position;
		}

		@Override
		public long getItemId(int position) {
			return position;
		}

		@Override
		public int getItemViewType(int position) {
			return super.getItemViewType(position);
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {

			TextView textView = null;
			if (position %4 == 0) {
				textView = new MyText(context);
				AbsListView.LayoutParams params = new AbsListView.LayoutParams(
						AbsListView.LayoutParams.FILL_PARENT, 100);
				textView.setLayoutParams(params);
				textView.setTextColor(Color.BLACK);
				textView.setTextSize(20);
				textView.setText(items[position]);
				textView.setBackgroundColor(0x88FF0000);
				textView.setGravity(Gravity.LEFT | Gravity.CENTER_VERTICAL);
			} else {
				textView = new TextView(context);
				AbsListView.LayoutParams params = new AbsListView.LayoutParams(
						AbsListView.LayoutParams.FILL_PARENT, 200);
				textView.setLayoutParams(params);
				textView.setTextColor(Color.BLACK);
				textView.setTextSize(20);
				textView.setText(items[position]);
				textView.setVisibility(View.VISIBLE);
				if (position %4 == 1) {		// GridView的行高由该行最后一个元素的高度决定
					AbsListView.LayoutParams params2 = new AbsListView.LayoutParams(
							AbsListView.LayoutParams.FILL_PARENT, 100);
					textView.setLayoutParams(params2);
					textView.setVisibility(View.INVISIBLE);
				}
				textView.setGravity(Gravity.CENTER);
			}
			return textView;
		}

		class MyText extends TextView {
			public MyText(Context context) {
				super(context);
			}
			@Override
			protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
				super.onMeasure(widthMeasureSpec, heightMeasureSpec);
				int targetWidth = mGridView.getMeasuredWidth()
	                    - mGridView.getPaddingLeft()
	                    - mGridView.getPaddingRight();
	            widthMeasureSpec = MeasureSpec.makeMeasureSpec(targetWidth,
	                    MeasureSpec.getMode(widthMeasureSpec));
	            super.onMeasure(widthMeasureSpec, heightMeasureSpec);
			}
		}
	}
}

Android GridView 实现合并单元格效果

时间: 2024-10-12 19:46:07

Android GridView 实现合并单元格效果的相关文章

转载:Android GridView 实现合并单元格效果

package com.example.test;   import android.app.Activity; import android.content.Context; import android.graphics.Color; import android.os.Bundle; import android.view.Gravity; import android.view.View; import android.view.ViewGroup; import android.wid

GridView相同内容合并单元格

using System;using System.Data;using System.Configuration;using System.Collections;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControl

GRIDVIEW多行多列合并单元格(合并列)

GitHub项目地址:https://github.com/mingceng/merge-gridviewcell 两篇文章:  GridView多行多列合并单元格(完整代码和例子)和 GridView多行多列合并单元格(指定列合并).今天继续再添加一些功能,首先看下图: 左边是原始数据的显示,右边是应用合并列之后的效果. 从图中可以看到,二级指标有两列,有的行中两列的内容一样,有的则不一样,如果实现如右图所示,看起来效果会更好一些.下面就着手实现这个功能,我的实现原理很简单,就是遍历GridV

GridView合并单元格万能版(包括模板列)

今天修改旧的项目,发现之前用到的gridview合并单元格代码不适用于模板列.做了修改之后记录下来.两种方法,第一种适用于所有情况,第二种适用于合并依据列非模板列.两种方法如下:方法一: /// <summary> /// 合并GridView中某列相同信息的行(单元格) 包含模板列 根据ID=rowspanid 的hiddenfield控件的值来合并.需要合并的 单元格需加上这个控件.根据控件值合并.可以将控件放在某一列,也可以放在每一列.取值的时候分开就行.此方法适合任意列,特别是模板列

【转】C# DataTable 导出 Excel 进阶 多行表头、合并单元格、中文文件名乱码

本文原创地址:http://blog.csdn.net/ranbolwb/article/details/8083983 ,转载请保留本行. 本例子是上一篇 DataTable 导出 Excel 的进阶,除了上一篇提到的处理乱码问题,本例还添加了处理多行表头.合并单元格的功能及处理中文文件名乱码问题,应该可以满足日常开发的需要了. 废话不多说了,直接上代码: [C#] 可以写单独类 1 using System; 2 using System.Collections.Generic; 3 usi

Asp.net导出Excel续章(自定义合并单元格,非Office组件)

结合上次写的导出Excel方法,这次上头要求我将列头进行一下合并 以前的效果: 改进后的效果: 在上篇文章中写到了Excel的导出方法,这次为了避免在生产环境中使用Office组件,服务器各种权限配置的麻烦,这次就不使用Office组件来生成Excel了. 上篇文章:Asp.net导出Excel(HTML输出) 关键代码如下图: 说道这里,其实主要思路已经很明显了. 在数据绑定结束后,重新绘制表头替换掉原来的表头就行了. TableCell自定义表头的时候是table标签的,很方便. 另外发现了

DataGrid合并单元格(wpf)

在网上搜索wpf合并单元格,一直没搜索到,没办法,只能自己想办法搞定了.其实就是DataGrid套DataGrid,为了方便支持Column拖动,在合并的DataGridColumn那一列的Header也放一个DataGrid,但是合并的这一个连续列中只支持一列的拖动,效果如下,上图 代码如下 首先定义两个模板,一个用于合并的Header显示 <DataTemplate x:Key="MergeHeader">             <DataGrid Horizo

【记录】解析具有合并单元格的Excel

最近公司让做各种数据表格的导入导出,就涉及到电子表格的解析,做了这么多天总结一下心得. 工具:NOPI 语言:C# 目的:因为涉及到导入到数据库,具有合并单元格的多行必然要拆分,而NPOI自动解析的时候拆分单元格除第一个单元格外其余值都是空,对于列头有合并项目的,数据库设计一般才有合并单元格下面的最小列单元作为数据库字段.于是希望达到这样一个效果.于是有了一个思路就是把读入的Excel复制到新建的Excel,然后再去读新的Excel.总体思路就是把合并单元格所包含的所有最小单元格的值都设置成合并

devexpress实现单元格合并以及依据条件合并单元格

1.devexpress实现单元格合并非常的简单,只要设置属性[AllowCellMerge=True]就可以了,实现效果如下图: 2.但是在具体要求中并非需要所有的相同单元格都合并,可能需要其他的条件来控制合并.这个时候我们就需要在事件gridView1_CellMerge中来控制了.下图为根据最后一列判断是否合并单元格的效果图(其中第四列设置为不合并<非必需>,这里只是为了达到一个比较效果.). 3.重要代码: int row1 = e.RowHandle1; int row2 = e.R