Αυτήν τη στιγμή είστε εκτός σύνδεσης, σε αναμονή για επανασύνδεση στο Internet

ΔΙΑΔΙΚΑΣΙΕΣ: Ρύθμιση αμφίδρομη λειτουργία εκτύπωσης για το Word αυτοματισμού

ΣΗΜΑΝΤΙΚΟ: Αυτό το άρθρο είναι προϊόν λογισμικού μηχανικής μετάφρασης της Microsoft και όχι ανθρώπινης μετάφρασης. Η Microsoft σάς προσφέρει άρθρα που είναι προϊόντα ανθρώπινης αλλά και μηχανικής μετάφρασης έτσι ώστε να έχετε πρόσβαση σε όλα τα άρθρα της Γνωσιακής Βάσης μας στη δική σας γλώσσα. Ωστόσο, ένα άρθρο που έχει προκύψει από μηχανική μετάφραση δεν είναι πάντα άριστης ποιότητας. Ενδέχεται να περιέχει λεξιλογικά, συντακτικά ή γραμματικά λάθη, όπως ακριβώς τα λάθη που θα έκανε ένας μη φυσικός ομιλητής επιχειρώντας να μιλήσει τη γλώσσα σας. Η Microsoft δεν φέρει καμία ευθύνη για τυχόν ανακρίβειες, σφάλματα ή ζημίες που προκύψουν λόγω τυχόν παρερμηνειών στη μετάφραση του περιεχομένου ή χρήσης του από τους πελάτες της. Επίσης, η Microsoft πραγματοποιεί συχνά ενημερώσεις στο λογισμικό μηχανικής μετάφρασης.

Η αγγλική έκδοση αυτού του άρθρου είναι η ακόλουθη:230743
Αυτό το αρχείο έχει αρχειοθετηθεί. Προσφέρεται “ως έχει” και δεν θα ενημερώνεται πια.
Περίληψη
Το Microsoft Word για Windows δεν παρέχει μια μέθοδο για προγράμματα-πελάτες αυτοματισμού για να ορίσετε τη σημαία εκτύπωσης διπλής όψης εκτύπωσης πριν από την έναρξη μιας εργασίας εκτύπωσης. Αν και υπάρχει μια παράμετρο με τοΕκτύπωσημέθοδος που δηλώνει υποστήριξη για εκτύπωση διπλής όψης, η παράμετρος δεν παρέχει πραγματική εκτύπωση διπλής όψης και ενδέχεται να μην είναι διαθέσιμη ανάλογα με το λειτουργικό σύστημα ή μια εγκατεστημένη γλώσσα. Ωστόσο, οι προγραμματιστές μπορούν να αντιμετωπίσετε αυτόν τον περιορισμό σε Windows συστήματα αλλάζοντας τη σημαία εκτύπωσης διπλής όψης για το ενεργό πρόγραμμα οδήγησης πριν από την κλήση του WordΕκτύπωσηFunction.

Αυτό το άρθρο παρουσιάζει τον τρόπο χρήσης του API των Windows για να αλλάξετε τη ρύθμιση διπλής όψης του ενεργού εκτυπωτή και να επιτρέπεται σε ένα έγγραφο του Word που θα εκτυπωθούν σε διπλή όψη.
Περισσότερες πληροφορίες
Αυτός ο κώδικας χρησιμοποιεί το API DocumentProperties για να αλλάξετε τις ρυθμίσεις εκτύπωσης του προγράμματος οδήγησης εκτυπωτή για να ενεργοποιήσετε την εκτύπωση διπλής όψης. Για αυτόν τον κωδικό για να εργαστείτε με επιτυχία, ο τελικός χρήστης θα χρειαστείτε επαρκή δικαιώματα για να αλλάξετε τις καθολικές ρυθμίσεις εκτύπωσης του εκτυπωτή. Εάν ένας χρήστης δεν έχει τα κατάλληλα δικαιώματα για να αλλάξετε τις ρυθμίσεις του προγράμματος οδήγησης, θα λαμβάνουν ένα σφάλμα που δεν επιτρέπεται Η πρόσβαση στην κλήση OpenPrinter API.

Για χρήστες των Microsoft Windows NT και τα Windows 2000, οι οποίοι πρέπει να εκτυπώσετε σε έναν κοινόχρηστο εκτυπωτή δικτύου, αυτό μπορεί να είναι ένα ζήτημα, επειδή το πρόγραμμα οδήγησης εκτυπωτή δεν βρίσκεται στον τοπικό υπολογιστή, αλλά στο διακομιστή εκτύπωσης. Παρόλο που είναι δυνατόν διαχειριστή, για να ρυθμίσετε τις παραμέτρους του διακομιστή εκτύπωσης για να δώσετε στους τελικούς χρήστες το κατάλληλο δικαίωμα αλλαγής των καθολικών ρυθμίσεων, είναι δεν ενδείκνυται για να γίνει αυτό, στις περισσότερες περιπτώσεις. Για να επιλύσετε αυτό το ζήτημα, είναι δυνατό να εγκαταστήσετε ένα τοπικό πρόγραμμα οδήγησης εκτυπωτή για τον εκτυπωτή δικτύου και να επιτρέψετε σε κάθε χρήστη να ελέγχει τις ρυθμίσεις για το τοπικό του σύστημα.

Βήματα για την προσθήκη τοπικού προγράμματος οδήγησης εκτυπωτή για τον εκτυπωτή δικτύου από τα Windows NT και Windows 2000

  1. Μία τουStartμενού επιλογήςρυθμίσεις, έπειτα επιλέξτεOffice Systems Printerκαι κάντε διπλό κλικΠροσθήκη εκτυπωτήΓια να ενεργοποιήσετε τον "Οδηγό προσθήκης εκτυπωτή".
  2. Όταν σας ζητηθεί, επιλέξτε εκτυπωτή από"Ο Υπολογιστής μου (My Computer)"και δεν από το δίκτυο. Παρόλο που θα συνδεθείτε σε έναν εκτυπωτή δικτύου που θέλετε να χρησιμοποιήσετε ένα πρόγραμμα οδήγησης στον υπολογιστή μου. Πιέστε το πλήκτροΕπόμενοΓια να συνεχίσετε.
  3. Κάντε κλικ στο"Προσθήκη θύρας."
  4. ΕπιλογήLocal Portστο πλαίσιο αναπτυσσόμενης λίστας και στη συνέχεια κάντε κλικΝέα θύρα.
  5. Πληκτρολογήστε τη θέση του εκτυπωτή στο δίκτυο. Για παράδειγμα:
        \\printserver\printername (using the exact path name to the printer)					
  6. ΕπιλογήOkκαι να συνεχίσετε με το υπόλοιπο της εγκατάστασης.
Αλλαγή των ιδιοτήτων του εκτυπωτή για τον ενεργό εκτυπωτή θα επηρεάσει όλες τις εφαρμογές που χρησιμοποιούν συγκεκριμένο εκτυπωτή και όχι μόνο το Word. Εάν σχεδιάζετε να αλλάξουν τις ρυθμίσεις για μια συγκεκριμένη εργασία εκτύπωσης, βεβαιωθείτε ότι μπορείτε να επαναφέρετε τη ρύθμιση όταν ολοκληρωθεί η εργασία.

Βήματα για τη δημιουργία του δείγματος

  1. Άνοιγμα της Visual Basic και να δημιουργήσετε ένα νέο έργο. Φόρμα1 δημιουργείται από προεπιλογή.
  2. Προσθέστε μια τυπική λειτουργική μονάδα BAS στο έργο και προσθέστε τον ακόλουθο κώδικα στο παράθυρο κώδικα της λειτουργικής μονάδας:
       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. Σε Φόρμα1, να προσθέσετε μια τυπική κουμπί εντολής.
  4. Προσθέστε τον ακόλουθο κώδικα στο παράθυρο κώδικα Φόρμα1:
       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. Εκτελέστε το δείγμα. If you have a printer that supports duplex printing, the test document should print on both sides of the page.
Αναφορές
For more information on problems you might see while trying to print Word documents using a duplex printer, please see the following articles in the Microsoft Knowledge Base:

176189WD97: Shading of Solid Black or Gray Won't Print Duplex on NT

196857WD97: First Page Prints on Back of Last Page with Duplex

214683WD97: Duplex Printing Does Not Duplex with Objects on Page

Προειδοποίηση: Αυτό το άρθρο έχει μεταφραστεί αυτόματα

Ιδιότητες

Αναγνωριστικό άρθρου: 230743 - Τελευταία αναθεώρηση: 12/05/2015 14:24:21 - Αναθεώρηση: 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 KbMtel
Σχόλια