寻VB.net高手,在dataGridView中能够实现上下两行内容相同的单元格的合并吗?如能,怎么实现?

hfxk1983 2009-06-11 04:24:46
请教高人VB.net在dataGridView中能够实现上下两行内容相同的单元格的合并吗?如能,怎么实现?

是winForm,不是web,实现下面的效果即可。
-------------------------------------------------------------
| 新增 | | 300 | | 武汉 | | |
----------000001 --------- 食品 -----------------------
| 变更 | | 500 | | 南京 | | |
-------------------------------------------------------------

从这个画面可以容易地看出000001这个食品的价格和产地被改变了。
求实现方式。
...全文
479 24 打赏 收藏 转发到动态 举报
写回复
用AI写文章
24 条回复
切换为时间正序
请发表友善的回复…
发表回复
lizhengnan 2009-06-15
  • 打赏
  • 举报
回复
不要允许用户新加或修改记录.
lizhengnan 2009-06-15
  • 打赏
  • 举报
回复
你把编辑有效的那个选择取消.


把这个属性DataGridView1.AllowUserToResizeRows也设为FALSE
如果每一行的高度不同的话,合并的有点问题.
hfxk1983 2009-06-15
  • 打赏
  • 举报
回复
感谢楼上,基本上可以,但有个问题,就是在合并的单元格中点击鼠标,隐藏的内容又会出现,有什么办法防止这种现象的出现吗?
lizhengnan 2009-06-15
  • 打赏
  • 举报
回复
我简单做了一个,你看一下,只实现了浏览功能,不要允许用户新加或修改记录.

Public Class Form1

Private dtb As New DataTable

Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

With dtb.Columns
.Add("Col1")
.Add("Col2")
End With

For i As Integer = 1 To 10
Dim drw As DataRow = dtb.NewRow

If i < 5 Then
drw("Col1") = 1
Else
drw("Col1") = i
End If

drw("Col2") = "Column" & i

dtb.Rows.Add(drw)
Next

Me.DataGridView1.DataSource = dtb

Me.DataGridView1.AutoGenerateColumns = False
End Sub

Private Sub DataGridView1_CellPainting(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellPaintingEventArgs) Handles DataGridView1.CellPainting
If e.ColumnIndex = -1 OrElse e.RowIndex = -1 Then
Exit Sub
End If

If e.RowIndex >= DataGridView1.Rows.Count Then
Exit Sub
End If

If DataGridView1.Columns(e.ColumnIndex).Name = "Col1" Then

Dim i As Integer = e.RowIndex + 1
Dim j As Integer = e.RowIndex - 1
Dim height As Integer = e.CellBounds.Height
Dim blnMerge As Boolean = False

While j >= DataGridView1.FirstDisplayedCell.RowIndex AndAlso (dtb.Rows(e.RowIndex)("Col1") = dtb.Rows(j)("Col1"))
height += DataGridView1.RowTemplate.Height

blnMerge = True
j -= 1
End While

While i < DataGridView1.Rows.Count AndAlso (dtb.Rows(e.RowIndex)("Col1") = dtb.Rows(i)("Col1"))
height += DataGridView1.RowTemplate.Height

blnMerge = True
i += 1
End While

If blnMerge Then
e.AdvancedBorderStyle.All = DataGridViewAdvancedCellBorderStyle.None

Dim y As Integer = e.CellBounds.Y
If j < e.RowIndex - 1 Then
j += 1
Dim rec1 As Rectangle = Me.DataGridView1.GetCellDisplayRectangle(e.ColumnIndex, j, True)
y = rec1.Y
End If

Dim rec As Rectangle = New Rectangle(e.CellBounds.X, y - 1, e.CellBounds.Width - 1, height)
Dim g As Graphics = Me.DataGridView1.CreateGraphics

g.FillRectangle(Brushes.White, rec)
g.DrawRectangle(New Pen(DataGridView1.GridColor), rec)
g.DrawString(e.FormattedValue, e.CellStyle.Font, Brushes.Black, rec)
e.Handled = True
End If

Me.DataGridView1.Update()
End If
End Sub
End Class
hj246 2009-06-13
  • 打赏
  • 举报
回复
web的没问题,winForm的没试过,
帮忙顶一个
Forrest23 2009-06-13
  • 打赏
  • 举报
回复
看懂了,么遇到过
hanjs 2009-06-13
  • 打赏
  • 举报
回复
关注.

多行表头的gridview也没法实现吧.
wzuomin 2009-06-12
  • 打赏
  • 举报
回复
帮顶 up
yanlongwuhui 2009-06-12
  • 打赏
  • 举报
回复
参考下:http://topic.csdn.net/u/20080428/15/c77a49f4-3695-4088-b0fa-29c5ecf381ea.html
一只熊猫 2009-06-12
  • 打赏
  • 举报
回复
顶起来关注。
  • 打赏
  • 举报
回复
js吧
yanlongwuhui 2009-06-12
  • 打赏
  • 举报
回复
帮顶
makun0624 2009-06-12
  • 打赏
  • 举报
回复
学习``UP
jidianxueyuan 2009-06-12
  • 打赏
  • 举报
回复
有个第三方控件能yy什么的
lizhengnan 2009-06-12
  • 打赏
  • 举报
回复
UP
hfxk1983 2009-06-12
  • 打赏
  • 举报
回复
上面 食品 和 300/500 的前后顺序搞错了,不用理会
hfxk1983 2009-06-12
  • 打赏
  • 举报
回复
不是表头的合并,是表中内容的合并

合并前如下,是两行:
----------------------------------------------
| 新增 | 000001 | 食品 | 300 | 武汉 |
---------------------------------------------
| 变更 | 000001 | 食品 | 500 | 南京 |
----------------------------------------------

其中有内容相同的单元格,就要合并,合并后如下:
-------------------------------------------------------------
| 新增 | | 300 | | 武汉 | | |
----------000001 --------- 食品 -----------------------
| 变更 | | 500 | | 南京 | | |
-------------------------------------------------------------

不知道可说明白了
古今多少事 2009-06-12
  • 打赏
  • 举报
回复
换支持合并的网格控件吧,如MSFlexGrid(在NET里我不会用)。
DataGridView能不能实现合并还是个问题,好像看到过类似的帖子,你搜一下,有回答可以实现的,代码较复杂,到底可不可行,我没试过。

呵呵!
lgx1972 2009-06-12
  • 打赏
  • 举报
回复
看不懂
请提高发贴质量
hfxk1983 2009-06-12
  • 打赏
  • 举报
回复
再把问题说一遍,
----------------------------------------------
| 新增 | 000001 | 食品 | 300 | 武汉 |
---------------------------------------------
| 变更 | 000001 | 食 | 500 | 南京 |
----------------------------------------------
对于上面的数据,要实现:
上下两个000001合并后,只显示一个,并且居中显示,类似于excel中的单元格合并的效果。
加载更多回复(4)
DataGridView打印控件和.NET轻松打印控件5.0版(含报表模板设计组件)2012年5月12日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB、C#等都可以用),有帮助文档与使用实例。 与4.95版相比,控件5.0版的主要更改如下: 1、解决了生成预览及打印过程的状态窗口显示的“第 页共 页”问题,现在可以正确显示总页数。 2、增加了打印DataGridView选定内容(选定行、列或矩形区域)的功能。对DGVPrint组件,设置PrintRange属性为相应的值即可,而对于VB2008Print组件,请先用CopyDataGridViewSelectedRange函数将要打印的DGV复制到新的DGV,然后再用PrintDGV函数打印这个新DGV即可。 3、增加了大量的绘图函数(如路径、多边形、填充多边形、曲线等),基本上.NET的GDI+绘图函数都有了(注意,填充类绘图函数名称为DrawFill……,而不是GDI+的Fill…。另外,对于Brush参数,只支持SolidBrush、TextureBrush、LinearGradientBrush三种类型的画刷,而且对于后2个画刷,只支持其的主要属性。 4、增加了直接打印Panel、GroupBox等容器控件内容的DrawPanel函数(对容器的TextBox控件与Label控件以文本的形式打印,除此之外的其他除容器控件之外的控件如CheckBox、ComboBox、Button控件等则直接以图片的形式打印,函数还支持嵌套容器控件的打印,且如果一页打印不下具有自动换页续打功能)。借助该函数的功能,您可以在Panel等容器控件设计好要打印的内容及打印相对位置,控件轻松帮助您解决打印问题。(参见演示实例) 5、增加了报表文件及模板文件的自动关联功能。在运行了“打印控件安装.msi”文件安装了打印控件的前提下,双击报表文件(扩展名为you的文件)即可打印预览该报表的内容;双击报表模板文件(扩展名为mb的文件)即可进入报表模板修改界面(此时如果打印预览报表模板不会有数据,因为这样修改报表模板时是没有设置数据源的)。 6、解决了原EasyReport报表组件由于资源释放不及时,在多次重复使用时占用大量句柄而可能产生的不能打印或预览问题。 7、解决了DataGridView在有固定列(冻结列)的时候,有些情况下(DGV固定列的index与DisplayIndex不一致时)打印可能出错的问题。 8、DGVPrint组件的自定义纸张使用更方便,设计时在可以通过设置PaperHeight与PaperWidth属性设置,运行时在“打印参数”设置窗口也可设置自定义纸张大小。 9、解决了EasyReport组件“页表头”区域设置的背景图片覆盖该区域打印内容的问题。 10、增加了打印XML格式的HTML文档的功能(目前只支持部分HTML标记,不支持表格及图片等标记,请参见DrawXML函数) 11、对帮助文件做了进一步的修订 12、增加了很多新的演示实例。 13、其他一些完善和修改。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印)打印DataGridView表格,基本上能完全按DataGridView控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,如果您在使用时调整了列的顺序,刷新打印后就会按调整后的列显示顺序进行打印,基本上做到了所见即所得的打印。 2、报表设计功能,这是4.7版控件的新增功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView和GridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 4、强大的文本打印输出功能,有多个文本打印重载函数,打印文本时,如果需要,控件会自动换行或换页打印输出。 5、支持同一文档多种版面格式打印(类似于Word的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页时在NewPage方法指定要使用的页面格式即可,使用非常简单。 6、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 7、打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或都从保存的打印方案文件读取打印参数。 8、水印

16,554

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧