Функция EnumPrinterDrivers
Функция EnumPrinterDrivers перечисляет драйверы принтеров, установленные на указанном сервере принтера.
Синтаксис
BOOL EnumPrinterDrivers(
_In_ LPTSTR pName,
_In_ LPTSTR pEnvironment,
_In_ DWORD Level,
_Out_ LPBYTE pDriverInfo,
_In_ DWORD cbBuf,
_Out_ LPDWORD pcbNeeded,
_Out_ LPDWORD pcReturned
);
Параметры
-
pName [in]
-
Указатель на строку, завершающуюся null, которая указывает имя сервера, на котором перечисляются драйверы принтера.
Если pName имеет значение NULL, функция перечисляет локальные драйверы принтера.
-
pEnvironment [in]
-
Указатель на строку, завершающуюся null, которая указывает среду (например, Windows x86, Windows IA64, Windows x64 или Windows NT R4000). Если этот параметр имеет значение NULL, функция использует текущую среду вызывающего объекта или клиента (а не назначения или сервера).
Если строка pEnvironment указывает "all", EnumPrinterDrivers перечисляет драйверы принтеров для всех платформ, установленных на указанном сервере.
-
Level [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]
-
Указатель на буфер, получающий массив структур DRIVER_INFO_*, как указано в параметре Level. Каждая структура содержит данные, описывающие доступный драйвер принтера. Буфер должен быть достаточно большим для получения массива структур и любых строк или других данных, на которые указывают элементы структуры.
Чтобы определить требуемый размер буфера, вызовите EnumPrinterDrivers с параметром cbBuf , равным нулю. EnumPrinterDrivers завершается сбоем, GetLastError возвращает ERROR_INSUFFICIENT_BUFFER, а параметр pcbNeeded возвращает размер буфера в байтах, необходимого для хранения массива структур и их данных.
-
cbBuf [in]
-
Размер (в байтах) буфера, на который указывает pDriverInfo
-
pcbNeeded [ out]
-
Указатель на переменную, которая получает количество байтов, скопированных в буфер pDriverInfo при успешном выполнении функции. Если буфер слишком мал, функция завершается сбоем, и переменная получает необходимое количество байтов.
-
pcReturned [out]
-
Указатель на переменную, которая получает количество структур, возвращаемых в буфере pDriverInfo . Это число драйверов принтеров, установленных на указанном сервере печати.
Возвращаемое значение
Если функция выполнена успешно, возвращаемое значение будет ненулевым.
Если функция выполняется неудачно, возвращается нулевое значение.
Комментарии
Примечание
Это блокирующая или синхронная функция, возвращаемая не сразу. Скорость возврата этой функции зависит от факторов времени выполнения, таких как состояние сети, конфигурация сервера печати и факторы реализации драйвера принтера, которые трудно предсказать при написании приложения. Вызов этой функции из потока, который управляет взаимодействием с пользовательским интерфейсом, может привести к тому, что приложение не отвечает.
Требования
Требование | Значение |
---|---|
Минимальная версия клиента |
Windows 2000 Professional [только классические приложения] |
Минимальная версия сервера |
Windows 2000 Server [только классические приложения] |
Заголовок |
|
Библиотека |
|
DLL |
|
Имя в кодировке Юникод и ANSI |
EnumPrinterDriversW (Юникод) и EnumPrinterDriversA (ANSI) |