Comment faire pour définir duplex impression pour l'automatisation de Word

IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d’articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d’avoir accès, dans votre propre langue, à l’ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s’exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s’efforce aussi continuellement de faire évoluer son système de traduction automatique.

La version anglaise de cet article est la suivante: 230743
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Résumé
Microsoft Word pour Windows ne fournit pas une méthode pour les clients Automation définir l'indicateur impression recto verso avant de démarrer un travail d'impression. Bien que la méthode PrintOut qui indique la prise en charge l'impression recto verso soit un paramètre, le paramètre ne fournit pas cette propriété a la valeur true l'impression recto verso et peuvent ne pas être disponible en fonction de votre système d'exploitation ou langue installée. Toutefois, les développeurs peuvent contourner cette limitation sur les systèmes Windows en modifiant l'indicateur recto verso pour le pilote d'imprimante active avant d'appeler la fonction imprimer de Word.

Cet article explique comment utiliser l'API Windows pour modifier le paramétrage duplex de l'imprimante active et autoriser un document Word soient imprimés en recto verso.
Plus d'informations
Ce code utilise l'API DocumentProperties pour modifier les paramètres d'impression du pilote d'imprimante pour activer l'impression recto verso. Pour que ce code fonctionne correctement, l'utilisateur final devra suffisamment d'autorisations modifier les paramètres d'impression globales de l'imprimante. Si un utilisateur n'a pas l'autorisation appropriée pour modifier les paramètres du pilote, ils obtiendrez une erreur Accès refusé sur l'appel OpenPrinter API.

Pour les utilisateurs de Microsoft Windows NT et Microsoft Windows 2000 qui souhaitent imprimer sur une imprimante réseau partagé, il peut avoir un problème car le pilote d'imprimante ne réside pas sur l'ordinateur local mais sur le serveur d'impression. Bien qu'il soit possible pour un administrateur configure le serveur d'impression pour autoriser les utilisateurs finaux le appropriée pour modifier les paramètres globaux, il est pas souhaitable pour cela, dans la plupart des cas. Pour contourner ce problème, il est possible d'installer un pilote d'impression local pour l'imprimante réseau et permettre à chaque utilisateur de contrôler les paramètres pour les systèmes locaux.

Étapes pour ajouter local imprimer pilote pour une imprimante réseau sur Windows NT et Windows 2000

  1. 1 Le menu Démarrer , sélectionnez paramètres , sélectionnez imprimantes puis double-cliquez sur Ajout d'imprimante pour ouvrir l'Assistant Ajout d'imprimante.
  2. Lorsque vous y êtes invité, sélectionnez imprimante à partir du « Poste de travail » et non à partir du réseau. Bien que vous vous connecter à une imprimante réseau, vous souhaitez utiliser un pilote sur Poste de travail. Appuyez sur suivant pour continuer.
  3. Cliquez sur « Ajouter de port ».
  4. Sélectionnez le port local dans la zone de liste déroulante et cliquez sur nouveau port .
  5. Tapez l'emplacement de l'imprimante sur le réseau. Par exemple :
        \\printserver\printername (using the exact path name to the printer)					
  6. Sélectionnez OK et poursuivez avec le reste de l'installation.
La modification de propriétés de l'imprimante active imprimante affectera toutes les applications qui utilisent cette imprimante et pas uniquement Word. Si vous prévoyez de modifier le paramètre pour un travail d'impression particulière, assurez-vous que vous restaurez le paramètre lorsque le travail est terminé.

Étapes pour créer l'exemple

  1. Ouvrir Visual Basic et créez un nouveau projet. Form1 est créé par défaut.
  2. Ajoutez un module standard BAS au projet et ajoutez le code suivant à fenêtre de code du module :
       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. Sur Form1, ajoutez un bouton de commande standard.
  4. Ajoutez le code suivant dans la fenêtre de code pour 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. Exécutez l'exemple. Si vous avez une imprimante qui prend en charge l'impression recto verso, le document test doit imprimer des deux côtés de la page.
Références
Pour plus d'informations sur des problèmes peuvent s'afficher lors de la tentative imprimer des documents Word en utilisant une imprimante recto verso, consultez les articles suivants dans la Base de connaissances :

176189 WD97 : trame de fond de noir uni ou gris Won't impression duplex sur NT

196857 WD97 : première page imprime en arrière de la dernière page avec duplex

214683 Ne l'impression recto verso WD97 : non recto verso avec des objets sur page

Avertissement : Cet article a été traduit automatiquement.

Propriétés

ID d'article : 230743 - Dernière mise à jour : 12/05/2015 14:24:24 - Révision : 2.3

Microsoft Visual Basic 5.0 Édition professionnelle, Microsoft Visual Basic 6.0 Édition professionnelle, Microsoft Visual Basic 5.0 Édition Entreprise, 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, Microsoft Office 2000 Developer

  • kbnosurvey kbarchive kbmt kbapi kbautomation kbhowto kbprint KB230743 KbMtfr
Commentaires