【发布时间】:2014-12-25 04:11:01
【问题描述】:
我有一个 gridview,其中包含大量数据(来自数据库)。我想把它打印出来。如果我只有 1 页要打印(我的意思是只有 44 行记录),下面的代码工作正常。如果网格视图内容的其余部分没有被打印出来。
如果我要在多页上打印数据,需要进行哪些更改才能允许多页打印?
任何人请帮助我....提前衷心感谢...我的代码附在下面...期待一个快速明确的答案...
Private Sub PrintDocument1_PrintPage(sender As System.Object, e As System.Drawing.Printing.PrintPageEventArgs) Handles PrintDocument1.PrintPage
Dim ColumnCount As Integer = DataGridView1.ColumnCount
Dim RowCount As Integer = DataGridView1.RowCount
Dim CellTopPos As Integer = 1
For Row = 0 To RowCount - 1
Dim CellLeftPos As Integer = PrintDocument1.PrinterSettings.DefaultPageSettings.Margins.Left
For Cell = 0 To ColumnCount - 1
Dim CellValue As String = DataGridView1.Rows(Row).Cells(Cell).Value.ToString()
Dim CellWidth = DataGridView1.Rows(Row).Cells(Cell).Size.Width + 50
Dim CellHeight = DataGridView1.Rows(Row).Cells(Cell).Size.Height
Dim Brush As New SolidBrush(Color.Black)
e.Graphics.DrawString(CellValue, New Font("Century Gothic", 10), Brush, CellLeftPos, CellTopPos)
e.Graphics.DrawRectangle(Pens.Black, CellLeftPos, CellTopPos, CellWidth, CellHeight)
CellLeftPos += CellWidth
Next
CellTopPos += DataGridView1.Rows(Row).Cells(0).Size.Height
Next
End sub
Private Sub Button1_Click_1(sender As System.Object, e As System.EventArgs) Handles Button1.Click
preview.PrintDialog1.Document = PrintDocument1
preview.PrintDialog1.PrinterSettings = PrintDocument1.PrinterSettings
preview.PrintPreviewControl1.Document = PrintDocument1()
PrintDocument1.PrinterSettings.DefaultPageSettings.Landscape = False
preview.ShowDialog()
AddHandler PrintDocument1.PrintPage, AddressOf PrintDocument1_PrintPage
End Sub
【问题讨论】:
标签: sql vb.net sql-server-2008 printing datagridview