Dica do SistemaEste artigo aplica-se a um sistema operativo diferente do que está a utilizar. Foi desactivado o conteúdo do artigo, que pode não ser relevante para si.
Microsoft Word para Windows não fornece um método para clientes de automação definir o sinalizador de impressão duplex antes de iniciar um trabalho de impressão. Embora não haja um parâmetro no método PrintOut que indica o suporte para impressão em frente e verso, o parâmetro não oferece impressão duplex true e pode não estar disponível dependendo do seu sistema operacional ou idioma instalado. No entanto, os desenvolvedores podem contornar essa limitação em sistemas Windows alterando o sinalizador duplex para o driver de impressora ativa antes de chamar função de Imprimir do Word.
Este artigo demonstra como usar a API do Windows para alterar a configuração da impressora ativa duplex e permitir que um documento do Word a ser impresso em duplex.
Esse código usa a API DocumentProperties para alterar as configurações de impressão do driver de impressora para habilitar a impressão em frente e verso. Para este código para trabalhar com êxito, o usuário final precisará as permissões adequadas para alterar as configurações globais de impressão para a impressora. Se um usuário não tiver a permissão apropriada para alterar as configurações do driver, elas receberão um erro acesso negado a chamada da API OpenPrinter.
Para usuários do Microsoft Windows NT e Microsoft Windows 2000 que precisa imprimir para uma impressora de rede compartilhada, isso pode ser um problema porque o driver de impressão não reside no computador local, mas no servidor de impressão. Embora seja possível para o administrador configurar o servidor de impressão para dar aos usuários finais permissão apropriada para alterar as configurações globais, não é desejável para isso na maioria dos casos. Para contornar este problema, é possível instalar um driver de impressão local para a impressora de rede e permitir que cada usuário controlar as configurações para seus sistemas locais.
Etapas para adicionar driver de impressão local para a impressora de rede no Windows NT e Windows 2000
Um menu Iniciar , selecione configurações , selecione impressoras e clique duas vezes em Adicionar impressora para exibir o Assistente para adicionar impressora.
Quando for solicitado, selecione a impressora de ' Meu computador ' e não da rede. Embora você irá se conecta a uma impressora de rede, você deseja usar um driver no meu computador. Pressione Avançar para continuar.
Clique em ' Adicionar porta '.
Selecione a Porta Local na caixa de listagem drop-down e clique em Nova porta .
Digite o local da impressora na rede. Por exemplo:
\\printserver\printername (using the exact path name to the printer)
Selecione OK e continue com o restante da configuração.
As propriedades da impressora para a impressora ativa a alteração afetará todos os aplicativos que usam essa impressora e não apenas o Word. Se você planeja alterar a configuração para um determinado trabalho de impressão, verifique se que você restaura a configuração quando o trabalho for concluído.
Abra o Visual Basic e crie um novo projeto. O Form1 é criado por padrão.
Adicione um módulo padrão do BAS para o projeto 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
No Form1, adicione um botão de comando padrão.
Adicione o seguinte código à janela de código para 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
Execute a amostra. Se você tiver uma impressora que ofereça suporte a impressão em frente e verso, o documento de teste deve imprimir nos dois lados da página.
Para obter mais informações sobre problemas, você poderá receber ao tentar imprimir documentos do Word usando uma impressora duplex, consulte os seguintes artigos na Base de dados de Conhecimento da Microsoft:
176189
(http://support.microsoft.com/kb/176189/EN-US/
)
WD97: O sombreamento de cinza ou preto sólido não imprimir duplex no NT
196857
(http://support.microsoft.com/kb/196857/EN-US/
)
WD97: Primeira página imprime no verso da última página com duplex
214683
(http://support.microsoft.com/kb/214683/EN-US/
)
WD97: Faz de impressão duplex não duplex com objetos na página
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 traduzido ou revisto por pessoas. A Microsoft possui artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais, com o objetivo de oferecer em português a totalidade dos artigos existentes na base de dados de suporte. No entanto, a tradução automática não é sempre perfeita, podendo conter erros de vocabulário, sintaxe ou gramática. A Microsoft não é responsável por incoerências, erros ou prejuízos ocorridos em decorrência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza atualizações freqüentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 230743
(http://support.microsoft.com/kb/230743/en-us/
)
Quanto esforço foi necessário para seguir os procedimentos deste artigo?
Muito baixo
Baixo
Moderado
Alto
Muito alto
Diga-nos o porque e o que podemos fazer para melhorar esta informação
Obrigado! Seus comentários são usados para nos ajudar a aperfeiçoar o conteúdo de suporte. Para obter mais opções de ajuda, visite a Home Page de Ajuda e Suporte.