C# XPTable 自己画cell单元格(XPTable控件使用说明六)

private void Form_Load(object sender, EventArgs e)
{
   table.BeforePaintCell += new PaintCellEventHandler(table_BeforePaintCell);
}
 
 
private void table_BeforePaintCell(object sender, PaintCellEventArgs e)
{
   // draw a checkerboard style table
   if ((e.Row + e.Column) % 2 == 0)
   {
      e.Graphics.FillRectangle(Brushes.Black, e.CellRect);
      e.Graphics.DrawString(e.Cell.Text, e.Cell.Font, Brushes.White, e.CellRect);
 
      // must set e.Handled to true otherwise the table
      // may erase what we've just done (depends on what
      // the cell and row background colors are but we
      // don't want to take that chance)
      e.Handled = true;
   }
}

private void Form_Load(object sender, EventArgs e)
{
   table.AfterPaintCell += new PaintCellEventHandler(table_AfterPaintCell);
}
 
 
private void table_AfterPaintCell(object sender, PaintCellEventArgs e)
{
   // draw a blue box around the cell if it is
   // in an even row and column number
   if (e.Column % 2 == 0 && e.Row % 2 == 0)
   {
      e.Graphics.DrawRectangle(Pens.Blue, e.CellRect.X, e.CellRect.Y, e.CellRect.Width-1, e.CellRect.Height-1);
   }
 
   // draw a red box around the cell if it is
   // in an odd row and column number
   if (e.Column % 2 == 1 && e.Row % 2 == 1)
   {
      e.Graphics.DrawRectangle(Pens.Red, e.CellRect.X, e.CellRect.Y, e.CellRect.Width-1, e.CellRect.Height-1);
   }
 
   // no need to set e.Handled property as the table
   // has already drawn the cell for us
}

 

 

 private void table2_AfterPaintCell(object sender, XPTable.Events.PaintCellEventArgs e)
        {
            
           
            if (  tableModel2.Selections.IsRowSelected(e.Row))
            { 

                foreach (Row item in tableModel2.Selections.SelectedItems)
                {
                    if (e.Column == 0)
                    {
                        Row row = tableModel2.Rows[e.Row];

                        Rectangle r = table2.RowRect(row);

                        r.Width = table2.Width;

                        e.Graphics.DrawRectangle(Pens.Blue, r);
                    }
 

                }
            }
        }

XPTable的大名,想必C#开发的人都有所耳闻,使用下来确实强大,在表格中添加下拉列表、进度条、图标等非常容易,灵活方便。 XPTable最重要的是开源,可根据自己的需要修改,有bug也可想办法解决,我就对其进行了若干处改进,使其更好用了。源代码写的非常标准,架构设计也很值得借鉴,研读源代码也是个学习提高的过程。真心感谢将如此完美的代码公开分享的人,最为点滴回报,也将自己修改后的源码放出,供大家参考,和原作者的贡献比起来,我这点小小的修改就如沧海一粟,不足为道了。 我修改过的代码和解决的问题列示如下: 1、...\Models\Table.cs Line 2118,2153 解决问题:否则在某些情况下(任意调整窗口大小,XPTable的Anchor设置为随窗口大小自适应调整)会抛System.ArgumentOutOfRangeException异常,vScrollBar.LargeChange不能小于0 2、...\Models\Table.cs Line 5598,5606 解决问题:在列头Resizing状态下双击鼠标,应根据该列数据中最长的一行调整当前列宽度,目前仅对TextColumn和NumberColumn有效 3、...\Models\Table.cs Line 6134 解决问题:在列头Resizing状态下单击鼠标,避免OnMouseUp激发列宽的调整。应该双击或者调整宽度后才能激发 4、...\Models\Table.cs Line 6373 解决问题:根据原代码,如果Table允许多选,选中多行后,点鼠标右键将自动选择鼠标所在行,修改后,多选的行依然选中 这个问题借鉴了“恶猫的尾巴”的代码:http://emao.me/tag/XpTable/,在此感谢! 5、...\Models\Table.cs Line 6627 解决问题:鼠标在列头为Resizing图标时,移动到数据区域不会自动变为默认图标 6、...\Models\Table.cs Line 7229 解决问题:解决列头的对齐方式始终是靠左的问题 7、...\Renderers\NumberCellRenderer.cs Line 661 解决问题:为了实现Table.cs的函数CalColumnWidth中实现对NumberColumn列格式化数据宽度的计算
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘欣的博客

你将成为第一个打赏博主的人!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值