显示打印机属性对话框 --API函数

来源:互联网 发布:比特币闪电网络何吋 编辑:程序博客网 时间:2024/04/29 12:57

 Dim printerName As String = m_printDoc.PrinterSettings.PrinterName

            If String.IsNullOrEmpty(printerName) = False Then

                Dim hPrinter As IntPtr

                If OpenPrinter(printerName, hPrinter, IntPtr.Zero) = False Then
                    Exit Sub
                End If


                Dim ps As PrinterSettings = m_printDoc.PrinterSettings 'New PrinterSettings()

                Dim hDevMode As IntPtr = ps.GetHdevmode()

                ' Dim hDevMode As IntPtr = ps.GetHdevmode(ps.DefaultPageSettings)
                Dim pDevMode As IntPtr = GlobalLock(hDevMode)
                Dim sizeNeeded As Integer = DocumentProperties(Me.Handle, hPrinter, ps.PrinterName, pDevMode, pDevMode, 0)
                Dim devModeData As IntPtr = System.Runtime.InteropServices.Marshal.AllocHGlobal(sizeNeeded)

                DocumentProperties(Me.Handle, hPrinter, ps.PrinterName, devModeData, pDevMode, 14)
                GlobalUnlock(hDevMode)
                ClosePrinter(hPrinter)
                ps.SetHdevmode(devModeData)
                ps.DefaultPageSettings.SetHdevmode(devModeData)
                GlobalFree(hDevMode)
                System.Runtime.InteropServices.Marshal.FreeHGlobal(devModeData)

            End If

原创粉丝点击