winform中可以摺疊的datagridview,自定義控制元件
winform中可以摺疊的datagridview,自定義控制元件。
目前實現了兩層摺疊,可以進一步擴充。
public partial class CollDataGridView : DataGridView
{
public CollDataGridView()
{
InitializeComponent();
}
public CollDataGridView(IContainer container)
{
container.Add(this);
InitializeComponent();
this.RowHeadersVisible = true;
this.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.DisableResizing;
this.ImageWidth = 15;
this.ImageHeight = 15;
this.RowHeadersDefaultCellStyle.Padding = new Padding(this.RowHeadersWidth);
this.CurrentCellDirtyStateChanged += CollDataGridView_CurrentCellDirtyStateChanged;
}
private void CollDataGridView_CurrentCellDirtyStateChanged(object sender, EventArgs e)
{
if (this.IsCurrentCellDirty)
{
this.CommitEdit(DataGridViewDataErrorContexts.Commit);
}
}
#region property
/// <summary>
/// 行首圖片寬度
/// </summary>
[
Category("CollDataGridViewProperties"),
Description("行首圖片寬度"),
Bindable(true)
]
public int ImageWidth { get; set; }
/// <summary>
/// 行首圖片高度
/// </summary>
[
Category("CollDataGridViewProperties"),
Description("行首圖片高度"),
Bindable(true)
]
public int ImageHeight { get; set; }
/// <summary>
/// 行首收縮圖示
/// </summary>
[
Category("CollDataGridViewProperties"),
Description("行首收縮圖示"),
Bindable(true)
]
public Image ImgExpand { get; set; }
/// <summary>
/// 行首展開圖片
/// </summary>
[
Category("CollDataGridViewProperties"),
Description("行首展開圖片"),
Bindable(true)
]
public Image ImgCollapse { get; set; }
#endregion
protected override void OnRowPostPaint(DataGridViewRowPostPaintEventArgs e)
{
base.OnRowPostPaint(e);
DataGridViewRow row = this.Rows[e.RowIndex];
Rectangle rectBack = new Rectangle(e.RowBounds.Location.X, e.RowBounds.Location.Y, this.RowHeadersWidth, e.RowBounds.Height - 1);
Rectangle rectLineBottom = new Rectangle(e.RowBounds.Location.X, e.RowBounds.Location.Y + e.RowBounds.Height - 1, this.RowHeadersWidth, 1);
if (row is CollDataGridViewRow && (row as CollDataGridViewRow).Rows.Count != 0)
{
Rectangle rect = new Rectangle(e.RowBounds.Location.X + 4, e.RowBounds.Location.Y + 4, this.ImageWidth, this.ImageHeight);
Image img = null;
if ((row as CollDataGridViewRow).IsCollapse)
{
img = this.ImgExpand;
}
else
{
img = this.ImgCollapse;
}
e.Graphics.DrawImage(img, rect);
}
}
/// <summary>
/// 增加點選行首摺疊功能
/// </summary>
/// <param name="e"></param>
protected override void OnRowHeaderMouseClick(DataGridViewCellMouseEventArgs e)
{
DataGridViewRow row = this.Rows[e.RowIndex];
if (row is CollDataGridViewRow)
{
if ((row as CollDataGridViewRow).IsCollapse == true)
{
this.Expand(e.RowIndex);
}
else
{
this.Collapse(e.RowIndex);
}
}
base.OnRowHeaderMouseClick(e);
}
public void Expand(int nRowIndex)
{
DataGridViewRow row = this.Rows[nRowIndex];
if (row is CollDataGridViewRow)
{
if ((row as CollDataGridViewRow).IsCollapse == true)
{
(row as CollDataGridViewRow).IsCollapse = false;
if ((row as CollDataGridViewRow).Rows.Count != 0)
{
for (int i = 0; i < (row as CollDataGridViewRow).Rows.Count; i++)
{
this.Rows.Insert(nRowIndex + 1 + i, (row as CollDataGridViewRow).Rows[i]);
//展開子條目時重繪子條目背景色,防止與主條目背景色不一致
(row as CollDataGridViewRow).Rows[i].DefaultCellStyle.BackColor =
(row as CollDataGridViewRow).DefaultCellStyle.BackColor;
}
}
}
}
}
/// <summary>
/// 摺疊
/// </summary>
/// <param name="nRowIndex">行號</param>
public void Collapse(int nRowIndex)
{
DataGridViewRow row = this.Rows[nRowIndex];
if ((row as CollDataGridViewRow).IsCollapse == false)
{
if ((row as CollDataGridViewRow).Rows.Count != 0)
{
this.RemoveAllSubRow((CollDataGridViewRow)row, false);
}
(row as CollDataGridViewRow).IsCollapse = true;
}
}
/// <summary>
/// 刪除集合除首條外的所有子條目
/// </summary>
/// <param name="row">摺疊行物件</param>
/// <param name="flag"></param>
private void RemoveAllSubRow(CollDataGridViewRow row, bool flag)
{
if (row.Rows.Count != 0)
{
if (!row.IsCollapse)
{
for (int i = 0; i < row.Rows.Count; i++)
{
if (row.Rows[i] is CollDataGridViewRow)
{
RemoveAllSubRow((CollDataGridViewRow)row.Rows[i], true);
}
else
{
this.Rows.Remove(row.Rows[i]);
}
}
}
if (flag)
{
row.IsCollapse = true;
this.Rows.Remove(row);
}
}
}
public void AddColumns(JObject obj)
{
int cloumIndex = 0;
foreach (var item in obj)
{
var name = item.Key;
AddTextBoxColumn(cloumIndex, name, name);
cloumIndex++;
}
}
public void AddData(JArray array, int ignoreIndex, int childNum)
{
foreach (var item in array)
{
var childList = new List<JObject>();
for (int i = 0; i < childNum; i++)
{
childList.Add((JObject)item);
}
CollDataGridViewRow collapseRow = new CollDataGridViewRow();
collapseRow.IsCollapse = true;
collapseRow.GroupTag = childList;
DataGridViewCheckBoxCell cell = new DataGridViewCheckBoxCell();
cell.Value = false;
collapseRow.Cells.Add(cell);//不預先新增則無法摺疊--相當於插入了空行
for (int i = 1; i < childNum + 1; i++)
{
DataGridViewRow row = new DataGridViewRow();
cell = new DataGridViewCheckBoxCell();
cell.Value = false;
row.Cells.Add(cell);//不預先新增則無法摺疊
row.Tag = i;
collapseRow.Rows.Add(row);
}
var rownum = this.Rows.Add(collapseRow);
this.Expand(rownum);
//Add Data
for (int i = rownum; i < rownum + childNum + 1; i++)
{
if (i == rownum)
{
for (int k = 0; k < ignoreIndex; k++)
{
DataGridViewTextBoxCell cellTextBox = new DataGridViewTextBoxCell();
cellTextBox.Value = "";
this.Rows[i].Cells[k] = cellTextBox;
}
}
int j = ignoreIndex;
foreach (JProperty item2 in item)
{
this.Rows[i].Cells[j].Value = item2.Value;
j++;
}
}
}
}
private void AddTextBoxColumn(int index, string name, string headerText)
{
DataGridViewTextBoxColumn column = new DataGridViewTextBoxColumn();
column.AutoSizeMode = DataGridViewAutoSizeColumnMode.NotSet;
column.SortMode = DataGridViewColumnSortMode.NotSortable;
column.Name = name;
column.HeaderText = headerText;
this.Columns.Insert(index, column);
}
}
public class CollDataGridViewRow : DataGridViewRow
{
#region Private fields
private CollDataGridViewRowCollection m_rowCollection = new CollDataGridViewRowCollection();
#endregion
#region Public Properties
/// <summary>
/// 是否展開
/// </summary>
public bool IsCollapse
{
get;
set;
}
/// <summary>
/// 摺疊控制元件的集合
/// </summary>
public CollDataGridViewRowCollection Rows
{
get { return m_rowCollection; }
set { m_rowCollection = value; }
}
/// <summary>
/// 集合行的Tag,用於儲存集合所有的資訊
/// </summary>
public object GroupTag
{
get;
set;
}
#endregion
}
public class CollDataGridViewRowCollection : IEnumerable<DataGridViewRow>, ICollection<DataGridViewRow>
{
private List<DataGridViewRow> m_list = new List<DataGridViewRow>();
public DataGridViewRow this[int index]
{
get
{
if (index >= m_list.Count)
{
throw new ArgumentOutOfRangeException("index");
}
return m_list[index];
}
}
#region IEnumerable<DataGridViewRow> Member
public IEnumerator<DataGridViewRow> GetEnumerator()
{
if (m_list.Count == 0)
{
throw new ArgumentOutOfRangeException("collection is null");
}
for (int i = 0; i < m_list.Count; i++)
{
yield return m_list[i];
}
}
#endregion
#region IEnumerable Member
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
if (m_list.Count == 0)
{
throw new ArgumentOutOfRangeException("collection is null");
}
for (int i = 0; i < m_list.Count; i++)
{
yield return m_list[i];
}
}
#endregion
#region ICollection<DataGridViewRow> Member
public void Add(DataGridViewRow item)
{
m_list.Add(item);
}
public void Clear()
{
m_list.Clear();
}
public bool Contains(DataGridViewRow item)
{
return m_list.Contains(item);
}
public void CopyTo(DataGridViewRow[] array, int arrayIndex)
{
m_list.CopyTo(array, arrayIndex);
}
public int Count
{
get { return m_list.Count; }
}
public bool IsReadOnly
{
get { return false; }
}
public bool Remove(DataGridViewRow item)
{
return m_list.Remove(item);
}
#endregion
}
具體的實現如下:
1.定義摺疊圖片
dgv.ImgCollapse = new FontAwesome.Properties(FontAwesome.Type.MinusSquareO) { ForeColor = Color.Black, BorderColor = Color.Transparent, BackColor = Color.Transparent }.AsImage();
dgv.ImgExpand = new FontAwesome.Properties(FontAwesome.Type.PlusSquareO) { ForeColor = Color.Black, BorderColor = Color.Transparent, BackColor = Color.Transparent }.AsImage();
dgv.ImageHeight = 15;
dgv.ImageWidth = 15;
2.新增列和資料
dgv.AddColumns((JObject)obj[name].First);
dgv.AddData((JArray)obj[name], 2, 3);
相關文章
- winform 自定義容器控制元件ORM控制元件
- WinForm 載入自定義控制元件閃爍問題ORM控制元件
- VScode自定義摺疊程式碼快 region和endregion 關鍵字VSCode
- DataGridView控制元件 1129View控制元件
- 自定義控制元件ViewPager控制元件Viewpager
- 自定義Switch控制元件控制元件
- 4. 自定義控制元件(4) --- 自定義屬性控制元件
- iOS自定義控制元件 SlideriOS控制元件IDE
- iOS自定義控制元件 AlertViewiOS控制元件View
- iOS自定義控制元件 SegmentiOS控制元件
- WPF Blend 自定義控制元件控制元件
- Flutter 之 自定義控制元件Flutter控制元件
- 消費摺疊
- winform中更新UI控制元件的方案介紹ORMUI控制元件
- 簡單的自定義表單控制元件控制元件
- 如何開發FineReport的自定義控制元件?控制元件
- UWP自定義ToggleButton控制元件的樣式控制元件
- 自定義控制元件 --- 電池icon控制元件
- Flutter 自定義縮放控制元件Flutter控制元件
- Qt實現自定義控制元件QT控制元件
- AngularJS自定義表單控制元件AngularJS控制元件
- 【Android】自定義樹形控制元件Android控制元件
- C#將Excel檔案中選擇的內容,複製貼上到 winform datagridviewC#ExcelORMView
- iOS自定義控制元件:簡易下拉控制元件iOS控制元件
- BootStrap | 例項 - 摺疊boot
- java之常量摺疊Java
- 【android】自定義佈局控制控制元件的位置可以通過繼承FrameLayout實現Android控制元件繼承
- WinForm使用DataGridView實現類似Excel表格的查詢替換ORMViewExcel
- Android自定義控制元件 帶文字提示的SeekBarAndroid控制元件
- QT常用控制元件(三)——自定義控制元件封裝QT控制元件封裝
- 自定義控制元件總結和思考控制元件
- WPF自定義FixedColumnGrid佈局控制元件控制元件
- 【自定義使用者控制元件】CNMButton控制元件
- UWP 自定義密碼框控制元件密碼控制元件
- iOS 自定義拖拽式控制元件:QiDragViewiOS控制元件View
- C#自定義控制元件—指示燈C#控制元件
- 蘋果OLED摺疊手機和可摺疊平板電腦情景分析蘋果
- Android 控制元件架構與自定義控制元件詳解Android控制元件架構