HOWTO: Đặt song in ấn cho tự động hóa từ

QUAN TRỌNG: Bài viết này được dịch bằng phần mềm dịch máy của Microsoft chứ không phải do con người dịch. Microsoft cung cấp các bài viết do con người dịch và cả các bài viết do máy dịch để bạn có thể truy cập vào tất cả các bài viết trong Cơ sở Kiến thức của chúng tôi bằng ngôn ngữ của bạn. Tuy nhiên, bài viết do máy dịch không phải lúc nào cũng hoàn hảo. Loại bài viết này có thể chứa các sai sót về từ vựng, cú pháp hoặc ngữ pháp, giống như một người nước ngoài có thể mắc sai sót khi nói ngôn ngữ của bạn. Microsoft không chịu trách nhiệm về bất kỳ sự thiếu chính xác, sai sót hoặc thiệt hại nào do việc dịch sai nội dung hoặc do hoạt động sử dụng của khách hàng gây ra. Microsoft cũng thường xuyên cập nhật phần mềm dịch máy này.

Nhấp chuột vào đây để xem bản tiếng Anh của bài viết này:230743
Bài viết này đã được lưu trữ. Bài viết được cung cấp "nguyên trạng" và sẽ không còn được cập nhật nữa.
TÓM TẮT
Microsoft Word cho Windows không cung cấp một phương pháp cho khách hàng tự động hóa thiết in cờ song công trước khi bắt đầu công việc in. Mặc dù có một tham số trong các PrintOut phương pháp chỉ ra hỗ trợ cho việc in ấn song, các tham số không cung cấp đúng song in và có thể không có sẵn tùy thuộc vào hệ điều hành hoặc cài đặt ngôn ngữ của bạn. Tuy nhiên, các nhà phát triển có thể làm việc xung quanh giới hạn này trên hệ thống Windows bởithay đổi các cờ song công trình điều khiển máy in hoạt động trước khi gọi của từ PrintOut chức năng.

Bài viết này chứng tỏ làm thế nào để sử dụng Windows API để thay đổi các thiết lập song của máy in hoạt động và cho phép một tài liệu Word để được in trong song.
THÔNG TIN THÊM
Mã này sử dụng DocumentProperties API để thay đổi các thiết đặt in của trình điều khiển máy in cho phép in ấn song. Đối với mã này để làm việc thành công, người dùng sẽ cần đầy đủ quyền để thay đổi các thiết đặt in ấn toàn cầu cho máy in. Nếu người dùng không có quyền thích hợp để thay đổi cài đặt trình điều khiển, họ sẽ nhận được một truy cập từ chối lỗi trên gọi OpenPrinter API.

Đối với người dùng của Microsoft Windows NT và Microsoft Windows 2000 người cần in ra máy in mạng chia sẻ, điều này có thể là một vấn đề vì trình điều khiển in không cư trú trên máy tính địa phương nhưng trên hệ phục vụ in. Mặc dù nó có thể cho người quản trị để cấu hình hệ phục vụ in để cung cấp cho người dùng cuối được sự cho phép thích hợp để thay đổi thiết đặt toàn cầu, nó không phải là mong muốn để làm như vậy trong phần lớn trường hợp. Để làm việc xung quanh vấn đề này, có thể cài đặt một trình điều khiển in địa phương cho máy in mạng, và để cho mỗi người dùng kiểm soát các thiết đặt cho hệ thống địa phương của họ.

Các bước để thêm địa phương in trình điều khiển cho máy in mạng trên Windows NT và Windows 2000

  1. Một trong những Bắt đầu trình đơn, chọn Thiết đặt, sau ñoù choïn Máy in và bấm đúp Thêm máy in để mang lại thuật sĩ thêm máy in.
  2. Khi được nhắc, chọn máy in từ"Máy tính của tôi"và không phải từ mạng. Mặc dù bạn sẽ kết nối tới máy in mạng, bạn muốn sử dụng một trình điều khiển trên máy tính của tôi. Báo chí Tiếp theo để tiếp tục.
  3. Nhấp vào"Thêm cổng."
  4. Chọn Local cảng trong danh sách thả xuống hộp và sau đó bấm Cảng mới.
  5. Gõ vị trí của máy in trên mạng. Ví dụ:
        \\printserver\printername (using the exact path name to the printer)					
  6. Chọn Ok và tiếp tục với phần còn lại của các thiết lập.
Thay đổi thuộc tính máy in cho máy in hoạt động sẽ ảnh hưởng đến tất cả các ứng dụng sử dụng mà máy in, và không chỉ từ. Nếu bạn có kế hoạch thay đổi các thiết lập cho công việc in cụ thể, hãy chắc chắn rằng bạn khôi phục lại các thiết lập khi công việc được hoàn tất.

Bước để xây dựng mẫu

  1. Mở Visual Basic và tạo ra một dự án mới. Form1 được tạo ra theo mặc định.
  2. Thêm một mô-đun BAS tiêu chuẩn vào các dự án và thêm mã sau vào cửa sổ của mô-đun mã:
       Option Explicit   Public Type PRINTER_DEFAULTS       pDatatype As Long       pDevmode As Long       DesiredAccess As Long   End Type   Public Type PRINTER_INFO_2       pServerName As Long       pPrinterName As Long       pShareName As Long       pPortName As Long       pDriverName As Long       pComment As Long       pLocation As Long       pDevmode As Long       ' Pointer to DEVMODE       pSepFile As Long       pPrintProcessor As Long       pDatatype As Long       pParameters As Long       pSecurityDescriptor As Long  ' Pointer to SECURITY_DESCRIPTOR       Attributes As Long       Priority As Long       DefaultPriority As Long       StartTime As Long       UntilTime As Long       Status As Long       cJobs As Long       AveragePPM As Long   End Type   Public Type DEVMODE       dmDeviceName As String * 32       dmSpecVersion As Integer       dmDriverVersion As Integer       dmSize As Integer       dmDriverExtra As Integer       dmFields As Long       dmOrientation As Integer       dmPaperSize As Integer       dmPaperLength As Integer       dmPaperWidth As Integer       dmScale As Integer       dmCopies As Integer       dmDefaultSource As Integer       dmPrintQuality As Integer       dmColor As Integer       dmDuplex As Integer       dmYResolution As Integer       dmTTOption As Integer       dmCollate As Integer       dmFormName As String * 32       dmUnusedPadding As Integer       dmBitsPerPel As Integer       dmPelsWidth As Long       dmPelsHeight As Long       dmDisplayFlags As Long       dmDisplayFrequency As Long       dmICMMethod As Long       dmICMIntent As Long       dmMediaType As Long       dmDitherType As Long       dmReserved1 As Long       dmReserved2 As Long   End Type   Public Const DM_DUPLEX = &H1000&   Public Const DM_IN_BUFFER = 8   Public Const DM_OUT_BUFFER = 2   Public Const PRINTER_ACCESS_ADMINISTER = &H4   Public Const PRINTER_ACCESS_USE = &H8   Public Const STANDARD_RIGHTS_REQUIRED = &HF0000   Public Const PRINTER_ALL_ACCESS = (STANDARD_RIGHTS_REQUIRED Or _             PRINTER_ACCESS_ADMINISTER Or PRINTER_ACCESS_USE)   Public Declare Function ClosePrinter Lib "winspool.drv" _    (ByVal hPrinter As Long) As Long   Public Declare Function DocumentProperties Lib "winspool.drv" _     Alias "DocumentPropertiesA" (ByVal hwnd As Long, _     ByVal hPrinter As Long, ByVal pDeviceName As String, _     ByVal pDevModeOutput As Long, ByVal pDevModeInput As Long, _     ByVal fMode As Long) As Long   Public Declare Function GetPrinter Lib "winspool.drv" Alias _     "GetPrinterA" (ByVal hPrinter As Long, ByVal Level As Long, _     pPrinter As Byte, ByVal cbBuf As Long, pcbNeeded As Long) As Long   Public Declare Function OpenPrinter Lib "winspool.drv" Alias _     "OpenPrinterA" (ByVal pPrinterName As String, phPrinter As Long, _     pDefault As PRINTER_DEFAULTS) As Long   Public Declare Function SetPrinter Lib "winspool.drv" Alias _     "SetPrinterA" (ByVal hPrinter As Long, ByVal Level As Long, _     pPrinter As Byte, ByVal Command As Long) As Long   Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" _    (pDest As Any, pSource As Any, ByVal cbLength As Long)    ' ==================================================================   ' SetPrinterDuplex    '   '  Programmatically set the Duplex flag for the specified printer   '  driver's default properties.   '   '  Returns: True on success, False on error. (An error will also   '  display a message box. This is done for informational value   '  only. You should modify the code to support better error   '  handling in your production application.)   '   '  Parameters:   '    sPrinterName - The name of the printer to be used.   '   '    nDuplexSetting - One of the following standard settings:   '       1 = None   '       2 = Duplex on long edge (book)   '       3 = Duplex on short edge (legal)   '   ' ==================================================================   Public Function SetPrinterDuplex(ByVal sPrinterName As String, _       ByVal nDuplexSetting As Long) As Boolean      Dim hPrinter As Long      Dim pd As PRINTER_DEFAULTS      Dim pinfo As PRINTER_INFO_2      Dim dm As DEVMODE         Dim yDevModeData() As Byte      Dim yPInfoMemory() As Byte      Dim nBytesNeeded As Long      Dim nRet As Long, nJunk As Long         On Error GoTo cleanup         If (nDuplexSetting < 1) Or (nDuplexSetting > 3) Then         MsgBox "Error: dwDuplexSetting is incorrect."         Exit Function      End If            pd.DesiredAccess = PRINTER_ALL_ACCESS      nRet = OpenPrinter(sPrinterName, hPrinter, pd)      If (nRet = 0) Or (hPrinter = 0) Then         If Err.LastDllError = 5 Then            MsgBox "Access denied -- See the article for more info."         Else            MsgBox "Cannot open the printer specified " & _              "(make sure the printer name is correct)."         End If         Exit Function      End If         nRet = DocumentProperties(0, hPrinter, sPrinterName, 0, 0, 0)      If (nRet < 0) Then         MsgBox "Cannot get the size of the DEVMODE structure."         GoTo cleanup      End If         ReDim yDevModeData(nRet + 100) As Byte      nRet = DocumentProperties(0, hPrinter, sPrinterName, _                  VarPtr(yDevModeData(0)), 0, DM_OUT_BUFFER)      If (nRet < 0) Then         MsgBox "Cannot get the DEVMODE structure."         GoTo cleanup      End If         Call CopyMemory(dm, yDevModeData(0), Len(dm))         If Not CBool(dm.dmFields And DM_DUPLEX) Then        MsgBox "You cannot modify the duplex flag for this printer " & _               "because it does not support duplex or the driver " & _               "does not support setting it from the Windows API."         GoTo cleanup      End If         dm.dmDuplex = nDuplexSetting      Call CopyMemory(yDevModeData(0), dm, Len(dm))         nRet = DocumentProperties(0, hPrinter, sPrinterName, _        VarPtr(yDevModeData(0)), VarPtr(yDevModeData(0)), _        DM_IN_BUFFER Or DM_OUT_BUFFER)      If (nRet < 0) Then        MsgBox "Unable to set duplex setting to this printer."        GoTo cleanup      End If         Call GetPrinter(hPrinter, 2, 0, 0, nBytesNeeded)      If (nBytesNeeded = 0) Then GoTo cleanup         ReDim yPInfoMemory(nBytesNeeded + 100) As Byte      nRet = GetPrinter(hPrinter, 2, yPInfoMemory(0), nBytesNeeded, nJunk)      If (nRet = 0) Then         MsgBox "Unable to get shared printer settings."         GoTo cleanup      End If         Call CopyMemory(pinfo, yPInfoMemory(0), Len(pinfo))      pinfo.pDevmode = VarPtr(yDevModeData(0))      pinfo.pSecurityDescriptor = 0      Call CopyMemory(yPInfoMemory(0), pinfo, Len(pinfo))         nRet = SetPrinter(hPrinter, 2, yPInfoMemory(0), 0)      If (nRet = 0) Then         MsgBox "Unable to set shared printer settings."      End If         SetPrinterDuplex = CBool(nRet)   cleanup:      If (hPrinter <> 0) Then Call ClosePrinter(hPrinter)   End Function					
  3. Ngày Form1, thêm một nút lệnh tiêu chuẩn.
  4. Thêm mã sau vào cửa sổ mã cho Form1:
       Option Explicit      Private Sub Command1_Click()      Dim oWord As Object      Dim oDoc As Object            Set oWord = CreateObject("Word.application")      oWord.Visible = True            Set oDoc = oWord.Documents.Add      oDoc.Range.Select            oWord.Selection.TypeText "This is on page 1" & vbCr      oWord.Selection.InsertBreak 1      oWord.Selection.TypeText "This is page 2"            SetPrinterDuplex Printer.DeviceName, 2            oDoc.PrintOut Background:=False            SetPrinterDuplex Printer.DeviceName, 1            MsgBox "Print Done", vbMsgBoxSetForeground            oDoc.Saved = True      oDoc.Close      Set oDoc = Nothing         oWord.Quit      Set oWord = Nothing   End Sub					
  5. Chạy mẫu. Nếu bạn có một máy in hỗ trợ song in ấn, tài liệu kiểm tra nên in trên cả hai mặt của trang.
THAM KHẢO
Để biết thêm về vấn đề bạn có thể thấy trong khi thử in tài liệu Word bằng cách sử dụng một máy in song, xin vui lòng xem các bài viết sau trong cơ sở kiến thức Microsoft:

176189 WD97: Bóng của rắn màu đen hoặc màu xám sẽ không in Duplex trên NT

196857 WD97: Đầu tiên trang in trên mặt sau của trang cuối cùng với Duplex

214683 WD97: Song in ấn Does không kép với các đối tượng trên trang

Cảnh báo: Bài viết này được dịch tự động

Thuộc tính

ID Bài viết: 230743 - Xem lại Lần cuối: 12/05/2015 14:24:30 - Bản sửa đổi: 2.0

Microsoft Visual Basic 5.0 Professional Edition, Microsoft Visual Basic 6.0 Professional Edition, Microsoft Visual Basic 5.0 Enterprise Edition, Microsoft Word 2002 Standard Edition, Microsoft Word 2000 Standard Edition, Microsoft Word 97 Standard Edition, Microsoft Office XP Developer Edition, Microsoft Office 2000 Developer Edition

  • kbnosurvey kbarchive kbapi kbautomation kbhowto kbprint kbmt KB230743 KbMtvi
Phản hồi