请使用打印文档在vb.net中帮助, 如果我在数据库中的特定表中有100个或更多数据。如何检索其他信息或数据,并在下一页中继续使用其他数据进行打印。
例如:在第1页25数据和第2,第3和第4页也是25数据
这是我的代码:
Private Sub PrintDocument1_PrintPage(ByVal sender As System.Object, ByVal e As System.Drawing.Printing.PrintPageEventArgs) Handles PrintDocument1.PrintPage
Dim rect As New Rectangle(20, 10, CInt(PrintDocument1.DefaultPageSettings.PrintableArea.Width), Panel2.Height)
Static startPage As Integer = 0
For p As Integer = startPage To pages.Count - 1
Dim cell As New Rectangle(startX, startY, dgw.RowHeadersWidth, dgw.ColumnHeadersHeight)
e.Graphics.FillRectangle(New SolidBrush(SystemColors.ControlLight), cell)
e.Graphics.DrawRectangle(Pens.Black, cell)
startY += dgw.ColumnHeadersHeight
For r As Integer = pages(p).startRow To pages(p).startRow + pages(p).rows - 1
cell = New Rectangle(startX, startY, dgw.RowHeadersWidth, dgw.Rows(r).Height)
e.Graphics.FillRectangle(New SolidBrush(SystemColors.ControlLight), cell)
e.Graphics.DrawRectangle(Pens.Black, cell)
startY += dgw.Rows(r).Height
Next
startX += cell.Width
startY = rect.Bottom
For c As Integer = pages(p).startCol To pages(p).startCol + pages(p).columns - 1
cell = New Rectangle(startX, startY, dgw.Columns(c).Width, dgw.ColumnHeadersHeight)
e.Graphics.FillRectangle(New SolidBrush(SystemColors.ControlLight), cell)
e.Graphics.DrawRectangle(Pens.Black, cell)
e.Graphics.DrawString(dgw.Columns(c).HeaderCell.Value.ToString, dgw.Font, Brushes.Black, cell, sf)
startX += dgw.Columns(c).Width
Next
startY = rect.Bottom + dgw.ColumnHeadersHeight
For r As Integer = pages(p).startRow To pages(p).startRow + pages(p).rows - 1
startX = 50 + dgw.RowHeadersWidth
For c As Integer = pages(p).startCol To pages(p).startCol + pages(p).columns - 1
cell = New Rectangle(startX, startY, dgw.Columns(c).Width, dgw.Rows(r).Height)
e.Graphics.DrawRectangle(Pens.Black, cell)
e.Graphics.DrawString(dgw(c, r).Value.ToString, dgw.Font, Brushes.Black, cell, sf)
startX += dgw.Columns(c).Width
Next
startY += dgw.Rows(r).Height
Next
If p <> pages.Count - 1 Then
startPage = p + 1
e.HasMorePages = True
Return
Else
startPage = 0
End If
Next
End Sub
答案 0 :(得分:0)
好的,首先,除非我非常错误,每次调用新页面时都会引发PrintPage
。因此,您在PrintPage
事件处理程序中所要做的就是为特定页面编写内容,而不是一次为所有页面编写内容。
检索其他数据以及主数据应该没有任何问题。如果您的其他数据垂直扩展页面,那么唯一会给您带来麻烦的时间就是您的数据少于25个。但是如果你知道每次都适合25,那么这应该相当容易。
如果您遇到特定问题,请扩展您的问题以说明问题所在,我会尝试回答这些问题。
您可能还会发现this article有用。