COMO: Definir para automatização do Word de impressão duplex

IMPORTANTE: Este artigo foi traduzido por um sistema de tradução automática (também designado por Machine translation ou MT), não tendo sido portanto revisto ou traduzido por humanos. A Microsoft tem artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais. O objectivo é simples: oferecer em Português a totalidade dos artigos existentes na base de dados do suporte. Sabemos no entanto que a tradução automática não é sempre perfeita. Esta pode conter erros de vocabulário, sintaxe ou gramática… erros semelhantes aos que um estrangeiro realiza ao falar em Português. A Microsoft não é responsável por incoerências, erros ou estragos realizados na sequência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza actualizações frequentes ao software de tradução automática (MT). Obrigado.

Clique aqui para ver a versão em Inglês deste artigo: 230743
Este artigo foi arquivado. Este artigo é oferecido "tal como está" e deixará de ser actualizado.
Sumário
Microsoft Word para o Windows não fornece um método para clientes de automatização definir o sinalizador de impressão em frente e verso antes de iniciar uma tarefa de impressão. Embora não exista um parâmetro no método Imprimir que indica o suporte para impressão em frente e verso, o parâmetro não fornece a verdadeira impressão em frente e verso e poderão não estar disponível dependendo do sistema operativo ou idioma instalado. No entanto, os programadores podem contornar esta limitação em sistemas Windows alterando o sinalizador de frente e verso para o controlador de impressora activa antes de chamar a função de Imprimir do Word.

Este artigo demonstra como utilizar a API do Windows para alterar a definição da impressora activa em frente e verso e permitir que um documento do Word sejam impressas em frente e verso.
Mais Informação
Este código utiliza a API DocumentProperties para alterar as definições de impressão do controlador de impressora para activar a impressão em frente e verso. Para este código trabalhar com êxito, o utilizador final precisará das permissões adequadas para alterar as definições globais de impressão para a impressora. Se um utilizador não tiver a permissão adequada para alterar definições de controlador, vão obter um erro de acesso negado na chamada API OpenPrinter.

Para utilizadores do Microsoft Windows NT e Microsoft Windows 2000 que necessitem de imprimir numa impressora de rede partilhada, pode ser um problema porque o controlador de impressora não reside num computador local mas o servidor de impressão. Embora seja possível para um administrador configurar o servidor de impressão para conceder a permissão adequada para alterar as definições globais de utilizadores de fim, se não aconselhável para o fazer na maior parte dos casos. Para contornar este problema, é possível instalar um controlador de impressão local para a impressora de rede e permitir que cada utilizador controlar as definições para os seus sistemas locais.

Passos para adicionar local controlador de impressora para impressora de rede no Windows NT e Windows 2000

  1. Um menu Iniciar , seleccione definições , em seguida, seleccione impressoras e faça duplo clique em Adicionar impressora para abrir o Assistente para adicionar impressoras.
  2. Quando lhe for pedido, seleccione impressora a partir de " meu computador " e não a partir da rede. Ainda que vai ligar uma impressora de rede, que pretende utilizar um controlador no meu computador. Prima seguinte para continuar.
  3. Clique em ' Adicionar porta '.
  4. Seleccione a Porta Local na caixa de lista pendente e clique em Nova porta .
  5. Escreva a localização da impressora na rede. Por exemplo:
        \\printserver\printername (using the exact path name to the printer)					
  6. Seleccione OK e continuar com o resto do programa de configuração.
Alterar as propriedades da impressora para a impressora activa afectará todas as aplicações que utilizam essa impressora e não apenas o Word. Se pretender alterar a definição para uma determinada tarefa de impressão, certifique-se de que restaurar a definição quando a tarefa estiver concluída.

Passos para criar o exemplo

  1. Abra o Visual Basic e crie um novo projecto. É criado o Form1 por predefinição.
  2. Adicione um módulo BAS padrão ao projecto e adicione o seguinte código à janela de código do módulo:
       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. No Form1, adicione um botão de comando padrão.
  4. Adicione o seguinte código à janela de código de 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. Execute o exemplo. Se tiver uma impressora que suporta a impressão em frente e verso, o documento de teste deve imprimir em ambos os lados da página.
Referências
Para obter mais informações sobre problemas poderá ser apresentada ao tentar imprimir documentos do Word utilizar uma impressora duplex, consulte os seguintes artigos na base de dados de conhecimento da Microsoft:

176189WD97: Sombreado de preto sólido ou cinzento Won't impressão duplex no NT

196857WD97: Primeira página imprime no verso da última página com duplex

214683É impressão frente e verso WD97: Não frente e verso com objectos na página

Aviso: Este artigo foi traduzido automaticamente

Propriedades

ID do Artigo: 230743 - Última Revisão: 12/05/2015 14:24:28 - Revisão: 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 KbMtpt
Comentários