Partilhar via


Função StartPagePrinter

A função StartPagePrinter notifica o spooler de que uma página está prestes a ser impressa na impressora especificada.

Sintaxe

BOOL StartPagePrinter(
  _In_ HANDLE hPrinter
);

Parâmetros

hPrinter [em]

Manipule uma impressora. Use a função OpenPrinter ou AddPrinter para recuperar uma alça de impressora.

Valor de retorno

Se a função for bem-sucedida, o valor de retorno será um valor diferente de zero.

Se a função falhar, o valor de retorno será zero.

Observações

Observação

Esta é uma função de bloqueio ou síncrona e pode não retornar imediatamente. A rapidez com que essa função retorna depende de fatores de tempo de execução, como status da rede, configuração do servidor de impressão e fatores de implementação do driver de impressora que são difíceis de prever ao escrever um aplicativo. Chamar essa função a partir de um thread que gerencia a interação com a interface do usuário pode fazer com que o aplicativo pareça não estar respondendo.

A sequência para um trabalho de impressão é a seguinte:

  1. Para iniciar um trabalho de impressão, chame StartDocPrinter.
  2. Para começar cada página, chame StartPagePrinter.
  3. Para gravar dados em uma página, chame WritePrinter.
  4. Para encerrar cada página, chame EndPagePrinter.
  5. Repita 2, 3 e 4 por quantas páginas forem necessárias.
  6. Para terminar o trabalho de impressão, chame EndDocPrinter.

Quando uma página em um arquivo spooled excede aproximadamente 350 MB, ele pode falhar ao imprimir e não enviar uma mensagem de erro. Por exemplo, isso pode ocorrer ao imprimir arquivos EMF grandes. O limite de tamanho de página depende de muitos fatores, incluindo a quantidade de memória virtual disponível, a quantidade de memória alocada por processos de chamada e a quantidade de fragmentação no heap do processo.

Exemplos

Para obter um programa de exemplo que usa essa função, consulte Como imprimir usando a API de impressão GDI.

Requerimentos

Requisito Valor
Cliente mínimo suportado
Windows 2000 Professional [apenas aplicações de ambiente de trabalho]
Servidor mínimo suportado
Windows 2000 Server [apenas aplicações de ambiente de trabalho]
Cabeçalho
Winspool.h (inclui Windows.h)
Biblioteca
Winspool.lib
DLL
Spoolss.dll

Ver também

Impressão

Funções da API do Spooler de Impressão

EndDocPrinter

EndPagePrinter

OpenImpressora

StartDocPrinter

EscreverNaImpressora