HOWTO: Impostazione duplex di stampa per l'automazione di Word

Il presente articolo è stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell’utente. Tuttavia, un articolo tradotto in modo automatico non è sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, più o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non è la sua. Microsoft non è responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell’utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.

Clicca qui per visualizzare la versione originale in inglese dell’articolo: 230743
Questo articolo è stato archiviato. L’articolo, quindi, viene offerto “così come è” e non verrà più aggiornato.
Sommario
Microsoft Word per Windows non fornisce un metodo per impostare il flag di stampa fronte retro prima di avviare un processo di stampa i client di automazione. Sebbene non vi sia un parametro nel metodo PrintOut che indica il supporto per la stampa fronte retro, il parametro non è disponibile la stampa fronte retro true e potrebbe non essere disponibile a seconda del sistema operativo in o lingua installata. Tuttavia, gli sviluppatori possono aggirare questa limitazione nei sistemi Windows modificando il flag duplex per il driver della stampante attiva prima di chiamare funzione di Stampa di Word.

In questo articolo viene illustrato come utilizzare l'API di Windows per modificare l'impostazione duplex della stampante attiva e consentire a un documento da stampare in fronte retro.
Informazioni
Viene utilizzata l'API DocumentProperties per modificare le impostazioni di stampa del driver della stampante per attivare la stampa fronte retro. Di questo codice funziona correttamente, è necessario che l'utente finale dovrà autorizzazioni sufficienti modificare le impostazioni stampa globale per la stampante. Se un utente non dispone dell'autorizzazione corretta per modificare le impostazioni del driver, verrà visualizzato un errore di accesso negato durante la chiamata OpenPrinter API.

Per gli utenti di Microsoft Windows NT e Microsoft Windows 2000 che desiderano stampare su una stampante di rete condivisa, questo è un problema poiché il driver di stampa non risiede su computer locale ma su server di stampa. Sebbene sia possibile che un amministratore di configurare il server di stampa per concedere agli utenti finali all'autorizzazione corretta per modificare le impostazioni globali, è non consigliabile farlo nella maggior parte dei casi. Per risolvere questo problema, è possibile installare un driver di stampa locale per la stampante di rete e consentire ogni utente di controllare le impostazioni per i sistemi locali.

Procedura per aggiungere driver di stampa locale per stampante di rete in Windows NT e Windows 2000

  1. Un menu di avvio selezionare Impostazioni , quindi selezionare stampanti e fare doppio clic su Aggiungi stampante per visualizzare l'installazione guidata stampante.
  2. Quando richiesto, selezionare stampante da " computer " e non dalla rete. Anche se si si connette a una stampante di rete, che si desidera utilizzare un driver nel computer. Premere Avanti per continuare.
  3. Fare clic su " Aggiungi porta ".
  4. Selezionare Porta locale nella casella di riepilogo a discesa e quindi scegliere Nuova porta .
  5. Digitare il percorso della stampante sulla rete. Ad esempio:
        \\printserver\printername (using the exact path name to the printer)					
  6. Scegliere OK e proseguire con il resto del programma di installazione.
Modifica delle proprietà della stampante per la stampante attiva influiranno tutte le applicazioni che utilizzano tale stampante e non solo di Word. Se si desidera modificare l'impostazione per un particolare processo di stampa, accertarsi di che ripristinare l'impostazione di una volta completato il processo.

Procedura per compilare il progetto di esempio

  1. Aprire Visual Basic e creare un nuovo progetto. In base all'impostazione predefinita, viene creato il progetto Form1.
  2. Aggiungere un modulo BAS standard del progetto e aggiungere il codice riportato di seguito finestra del codice del modulo:
       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. In Form1, è necessario aggiungere un pulsante di comando standard.
  4. Aggiungere il seguente codice alla finestra del codice per 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. Esecuzione del codice di esempio. Se si dispone di una stampante che supporta la stampa fronte retro, il documento di test deve stampa fronte retro della pagina.
Riferimenti
Per ulteriori informazioni sui problemi che potrebbero essere visualizzati durante il tentativo di stampare documenti di Word utilizzando una stampante fronte retro, vedere i seguenti articoli della Microsoft Knowledge Base riportato di seguito:

176189WD97: Sfondo di tinta del nero o grigio non stampa duplex in NT

196857WD97: Prima pagina stampa dell'ultima pagina con duplex

214683È di stampa duplex WD97: Non è duplex con gli oggetti nella pagina

Proprietà

ID articolo: 230743 - Ultima revisione: 12/05/2015 14:24:25 - Revisione: 2.3

Microsoft Visual Basic 5.0 Professional Edition, Microsoft Visual Basic 6.0 Professional Edition, Microsoft Visual Basic 5.0 Enterprise Edition, Microsoft Visual Basic Enterprise Edition for Windows 6.0, 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 kbmt kbapi kbautomation kbhowto kbprint KB230743 KbMtit
Feedback