GetPrinterDriver 함수

GetPrinterDriver 함수는 지정된 프린터에 대한 드라이버 데이터를 검색합니다. 로컬 컴퓨터에 드라이버가 설치되어 있지 않으면 GetPrinterDriver 에서 설치합니다.

구문

BOOL GetPrinterDriver(
  _In_  HANDLE  hPrinter,
  _In_  LPTSTR  pEnvironment,
  _In_  DWORD   Level,
  _Out_ LPBYTE  pDriverInfo,
  _In_  DWORD   cbBuf,
  _Out_ LPDWORD pcbNeeded
);

매개 변수

hPrinter [in]

드라이버 데이터를 검색해야 하는 프린터에 대한 핸들입니다. OpenPrinter 또는 AddPrinter 함수를 사용하여 프린터 핸들을 검색합니다.

pEnvironment [in]

환경을 지정하는 null로 끝나는 문자열에 대한 포인터입니다(예: Windows x86, Windows IA64 또는 Windows x64). 이 매개 변수가 NULL이면 호출하는 애플리케이션 및 클라이언트 컴퓨터의 현재 환경(대상 애플리케이션 및 인쇄 서버가 아님)이 사용됩니다.

수준 [in]

pDriverInfo 버퍼에 반환된 프린터 드라이버 구조입니다. 이 매개 변수는 다음 값 중 하나일 수 있습니다.

의미
1
DRIVER_INFO_1
2
DRIVER_INFO_2
3
DRIVER_INFO_3
4
DRIVER_INFO_4
5
DRIVER_INFO_5
6
DRIVER_INFO_6
8
DRIVER_INFO_8

pDriverInfo [out]

Level에서 지정한 대로 드라이버에 대한 정보가 포함된 구조를 수신하는 버퍼에 대한 포인터입니다. 버퍼는 구조체 멤버가 가리키는 문자열을 저장할 수 있을 만큼 커야 합니다.

필요한 버퍼 크기를 확인하려면 cbBuf가 0으로 설정된 GetPrinterDriver를 호출합니다. GetPrinterDriver가 실패하고 GetLastError 가 ERROR_INSUFFICIENT_BUFFER 반환하고 pcbNeeded 매개 변수는 구조체 및 해당 데이터의 배열을 보유하는 데 필요한 버퍼의 크기를 바이트 단위로 반환합니다.

cbBuf [in]

pDriverInfo가 가리키는 배열의 크기(바이트)입니다.

pcbNeeded [out]

함수가 성공하면 복사된 바이트 수를 받는 값에 대한 포인터이거나 cbBuf 가 너무 작은 경우 필요한 바이트 수입니다.

반환 값

함수가 성공하면 반환 값은 0이 아닌 값입니다.

함수가 실패하면 반환 값은 0입니다.

존재하지 않는 드라이버의 경우 함수는 ERROR_UNKNOWN_PRINTER_DRIVER 반환합니다.

설명

참고

이는 차단 또는 동기 함수이며 즉시 반환되지 않을 수 있습니다. 이 함수가 반환되는 빈도는 애플리케이션을 작성할 때 예측하기 어려운 네트워크 상태, 인쇄 서버 구성 및 프린터 드라이버 구현 요소와 같은 런타임 요인에 따라 달라집니다. 사용자 인터페이스와의 상호 작용을 관리하는 스레드에서 이 함수를 호출하면 애플리케이션이 응답하지 않는 것처럼 보일 수 있습니다.

DRIVER_INFO_2, DRIVER_INFO_3, DRIVER_INFO_4, DRIVER_INFO_5DRIVER_INFO_6 구조체에는 pDriverPath 멤버에 있는 프린터 드라이버의 파일 이름 또는 전체 경로 및 파일 이름이 포함됩니다. 애플리케이션은 경로 및 파일 이름을 사용하여 LoadLibrary 함수를 호출하고 경로와 파일 이름을 단일 인수로 제공하여 프린터 드라이버를 로드할 수 있습니다.

요구 사항

요구 사항
지원되는 최소 클라이언트
Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버
Windows 2000 Server[데스크톱 앱만]
헤더
Winspool.h(Windows.h 포함)
라이브러리
Winspool.lib
DLL
Winspool.drv
유니코드 및 ANSI 이름
GetPrinterDriverW (유니코드) 및 GETPrinterDriverA (ANSI)

추가 정보

인쇄

인쇄 스풀러 API 함수

AddPrinterDriver

DRIVER_INFO_1

DRIVER_INFO_2

DRIVER_INFO_3

DRIVER_INFO_4

DRIVER_INFO_5

DRIVER_INFO_6

EnumPrinterDrivers

OpenPrinter