⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 printtextform.vb

📁 Mastering VBNet Include Source Code
💻 VB
字号:
Public Class PrintTextForm
    Inherits System.Windows.Forms.Form

#Region " Windows Form Designer generated code "

    Public Sub New()
        MyBase.New()

        'This call is required by the Windows Form Designer.
        InitializeComponent()

        'Add any initialization after the InitializeComponent() call

    End Sub

    'Form overrides dispose to clean up the component list.

    Private WithEvents TextBox1 As System.Windows.Forms.TextBox
    Private WithEvents Button1 As System.Windows.Forms.Button
    Private WithEvents PrintDocument1 As System.Drawing.Printing.PrintDocument
    Private WithEvents PrintPreviewDialog1 As System.Windows.Forms.PrintPreviewDialog
    Friend WithEvents PageSetupDialog1 As System.Windows.Forms.PageSetupDialog

    'Required by the Windows Form Designer
    Private components As System.ComponentModel.Container

    'NOTE: The following procedure is required by the Windows Form Designer
    'It can be modified using the Windows Form Designer.  
    'Do not modify it using the code editor.
    <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
        Dim resources As System.Resources.ResourceManager = New System.Resources.ResourceManager(GetType(PrintTextForm))
        Me.PrintDocument1 = New System.Drawing.Printing.PrintDocument()
        Me.PrintPreviewDialog1 = New System.Windows.Forms.PrintPreviewDialog()
        Me.Button1 = New System.Windows.Forms.Button()
        Me.TextBox1 = New System.Windows.Forms.TextBox()
        Me.PageSetupDialog1 = New System.Windows.Forms.PageSetupDialog()
        Me.SuspendLayout()
        '
        'PrintDocument1
        '
        '
        'PrintPreviewDialog1
        '
        Me.PrintPreviewDialog1.AutoScrollMargin = New System.Drawing.Size(0, 0)
        Me.PrintPreviewDialog1.AutoScrollMinSize = New System.Drawing.Size(0, 0)
        Me.PrintPreviewDialog1.ClientSize = New System.Drawing.Size(400, 300)
        Me.PrintPreviewDialog1.Enabled = True
        Me.PrintPreviewDialog1.Icon = CType(resources.GetObject("PrintPreviewDialog1.Icon"), System.Drawing.Icon)
        Me.PrintPreviewDialog1.Location = New System.Drawing.Point(88, 88)
        Me.PrintPreviewDialog1.MaximumSize = New System.Drawing.Size(0, 0)
        Me.PrintPreviewDialog1.Name = "PrintPreviewDialog1"
        Me.PrintPreviewDialog1.Opacity = 1
        Me.PrintPreviewDialog1.TransparencyKey = System.Drawing.Color.Empty
        Me.PrintPreviewDialog1.Visible = False
        '
        'Button1
        '
        Me.Button1.Font = New System.Drawing.Font("Microsoft Sans Serif", 9.75!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(0, Byte))
        Me.Button1.Location = New System.Drawing.Point(584, 416)
        Me.Button1.Name = "Button1"
        Me.Button1.Size = New System.Drawing.Size(136, 32)
        Me.Button1.TabIndex = 1
        Me.Button1.Text = "Preview && Print "
        '
        'TextBox1
        '
        Me.TextBox1.Font = New System.Drawing.Font("Verdana", 9.0!, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, CType(0, Byte))
        Me.TextBox1.MaxLength = 0
        Me.TextBox1.Multiline = True
        Me.TextBox1.Name = "TextBox1"
        Me.TextBox1.ScrollBars = System.Windows.Forms.ScrollBars.Vertical
        Me.TextBox1.Size = New System.Drawing.Size(728, 408)
        Me.TextBox1.TabIndex = 0
        Me.TextBox1.Text = "TextBox1"
        '
        'PrintTextForm
        '
        Me.AutoScaleBaseSize = New System.Drawing.Size(5, 13)
        Me.ClientSize = New System.Drawing.Size(728, 453)
        Me.Controls.AddRange(New System.Windows.Forms.Control() {Me.Button1, Me.TextBox1})
        Me.Name = "PrintTextForm"
        Me.Text = "Printing Text Demo"
        Me.ResumeLayout(False)

    End Sub

#End Region


    Private Sub PrintDocument1_PrintPage(ByVal sender As Object, ByVal e As System.Drawing.Printing.PrintPageEventArgs) Handles PrintDocument1.PrintPage
        Dim txtFont As New Font("Arial", 10)
        Dim LMargin As Integer = PrintDocument1.DefaultPageSettings.Margins.Left
        Dim TMargin As Integer = PrintDocument1.DefaultPageSettings.Margins.Top
        Dim txtH As Integer = _
           PrintDocument1.DefaultPageSettings.PaperSize.Height - _
           PrintDocument1.DefaultPageSettings.Margins.Top - _
           PrintDocument1.DefaultPageSettings.Margins.Bottom
        Dim txtW As Integer = _
           PrintDocument1.DefaultPageSettings.PaperSize.Width - _
           PrintDocument1.DefaultPageSettings.Margins.Left - _
           PrintDocument1.DefaultPageSettings.Margins.Right
        Dim linesPerPage As Integer = _
           e.MarginBounds.Height / txtFont.GetHeight(e.Graphics)
        Dim R As New RectangleF(LMargin, TMargin, txtW, txtH)
        Static line As String
        Dim word As String
        Dim cols, lines As Integer
        word = GetNextWord()
        While word <> "" And lines < linesPerPage
            line = line & word
            word = GetNextWord()
            e.Graphics.MeasureString(line & word, txtFont, New SizeF(txtW, txtH), _
                                     New StringFormat(), cols, lines)
        End While
        If word = "" And Trim(line) <> "" Then
            e.Graphics.DrawString(line, txtFont, Brushes.Black, R, _
                                  New StringFormat())
            e.HasMorePages = False
            Exit Sub
        End If
        e.Graphics.DrawString(line, txtFont, Brushes.Black, R, New StringFormat())
        e.HasMorePages = True
        line = word
    End Sub

    Function GetNextWord(Optional ByVal reset As Boolean = False) As String
        Static currPos As Integer
        Dim word As String

        If reset Then currPos = 0
        If currPos >= TextBox1.Text.Length Then Return ""
        While Not System.Char.IsLetterOrDigit(TextBox1.Text.Chars(currPos))
            word = word & TextBox1.Text.Chars(currPos)
            currPos = currPos + 1
            If currPos >= TextBox1.Text.Length Then Return word
        End While
        While Not (System.Char.IsWhiteSpace(TextBox1.Text.Chars(currPos)))
            word = word & TextBox1.Text.Chars(currPos)
            currPos = currPos + 1
            If currPos >= TextBox1.Text.Length Then Return word
        End While
        Return word
    End Function

    Dim textToPrint As String

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        textToPrint = TextBox1.Text

        PageSetupDialog1.PageSettings = PrintDocument1.DefaultPageSettings
        If PageSetupDialog1.ShowDialog() = DialogResult.OK Then
            PrintDocument1.DefaultPageSettings = PageSetupDialog1.PageSettings
        End If
        Try
            PrintPreviewDialog1.Document = PrintDocument1
            PrintPreviewDialog1.ShowDialog()
        Catch exc As Exception
            MsgBox("Print operation failed " & vbCrLf & exc.Message)
        End Try
    End Sub

End Class

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -