using System;
using System.Collections.Generic;
using System.Text;
using System.Web.UI.WebControls;
using System.Web.UI;
namespace YYControls.Helper

{
/// <summary>
/// SmartGridView的Helper
/// </summary>
public
class SmartGridView

{
/// <summary>
/// 合併指定列的相鄰且內容相同的單元格
/// </summary>
/// <param name="gv">GridView</param>
/// <param name="columnIndices">須要合併單元格的列的索引(用逗號「,」分隔)</param>
public
static
void MergeCells(GridView gv,
int[] columnIndices)

{
// 指定的列中須要設置RowSpan的單元格的行索引
int[] aryInt =
new
int[columnIndices.Length];
// 是否從新指定aryInt的相關元素的值
// aryInt中的元素與aryBln中的元素一一對應
bool[] aryBln =
new
bool[columnIndices.Length];
// aryInt初值均爲0
for (
int i = 0; i < aryInt.Length; i++)

{

aryInt[i] = 0;

}
// aryBln初值均爲true
for (
int i = 0; i < aryBln.Length; i++)

{

aryBln[i] =
true;

}
for (
int i = 1; i < gv.Rows.Count; i++)

{
// 本行和上一行均爲DataControlRowType.DataRow
if (gv.Rows[i].RowType == DataControlRowType.DataRow && gv.Rows[i - 1].RowType == DataControlRowType.DataRow)

{
// 遍歷指定的列索引
for (
int j = 0; j < columnIndices.Length; j++)

{
// 列索引超出範圍則不處理
if (columnIndices[j] < 0 || columnIndices[j] > gv.Columns.Count - 1)
continue;
// 相鄰單元格的內容相同
if (gv.Rows[i].Cells[columnIndices[j]].Text == gv.Rows[i - 1].Cells[columnIndices[j]].Text)

{
if (aryBln[j])

aryInt[j] = i - 1;
if (gv.Rows[aryInt[j]].Cells[columnIndices[j]].RowSpan == 0)

gv.Rows[aryInt[j]].Cells[columnIndices[j]].RowSpan = 1;

gv.Rows[aryInt[j]].Cells[columnIndices[j]].RowSpan++;

gv.Rows[i].Cells[columnIndices[j]].Visible =
false;

aryBln[j] =
false;

}
else

{

aryBln[j] =
true;

}

}

}

}

}

}

}