На главную

On-line справка по Win32 API

Написать письмо
БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО!
Список всех статей A-B-C-D-E-F-G-H-I-J-K-L-M-N-O-P-Q-R-S-T-U-V-W-X-Y-Z | Скачать Вниз

GetDIBits



The GetDIBits function retrieves the bits of the specified bitmap and copies them into a buffer using the specified format.

int GetDIBits(

HDC hdc, // handle of device context
HBITMAP hbmp, // handle of bitmap
UINT uStartScan, // first scan line to set in destination bitmap
UINT cScanLines, // number of scan lines to copy
LPVOID lpvBits, // address of array for bitmap bits
LPBITMAPINFO lpbi, // address of structure with bitmap data
UINT uUsage // RGB or palette index
);


Parameters

hdc

Identifies the device context.

hbmp

Identifies the bitmap.

uStartScan

Specifies the first scan line to retrieve.

cScanLines

Specifies the number of scan lines to retrieve.

lpvBits

Points to a buffer to receive the bitmap data. If this parameter is NULL, the function passes the dimensions and format of the bitmap to the BITMAPINFO structure pointed to by the lpbi parameter.

lpbi

Points to a BITMAPINFO structure that specifies the desired format for the device-independent bitmap (DIB) data.

uUsage

Specifies the format of the bmiColors member of the BITMAPINFO structure. It must be one of the following values:

Value Meaning
DIB_PAL_COLORS The color table should consist of an array of 16-bit indices into the current logical palette.
DIB_RGB_COLORS The color table should consist of literal red, green, blue (RGB) values.


Return Values

If the lpvBits parameter is non-NULL and the function succeeds, the return value is the number of scan lines copied from the bitmap.

Windows 95:

If the lpvBits parameter is NULL and GetDIBits successfully fills the BITMAPINFO structure, the return value is the total number of scan lines in the bitmap.

Windows NT:

If the lpvBits parameter is NULL and GetDIBits successfully fills the BITMAPINFO structure, the return value is non-zero.

If the function fails, the return value is zero.

Remarks

If the requested format for the DIB matches its internal format, the RGB values for the bitmap are copied. If the requested format doesn't match the internal format, a color table is synthesized. The following table describes the color table synthesized for each format.

Value Meaning
1_BPP The color table consists of a black and a white entry.
4_BPP The color table consists of a mix of colors identical to the standard VGA palette.
8_BPP The color table consists of a general mix of 256 colors defined by GDI. (Included in these 256 colors are the 20 colors found in the default logical palette.)
24_BPP No color table is returned.


If the lpvBits parameter is a valid pointer, the first six members of the BITMAPINFOHEADER structure must be initialized to specify the size and format of the DIB. Note that a bottom-up DIB is specified by setting the height to a positive number, while a top-down DIB is specified by setting the height to a negative number. The bitmap's color table will be appended to the BITMAPINFO structure.
If lpvBits is NULL, GetDIBits examines the first member of the first structure pointed to by lpbi. This member must specify the size, in bytes, of a BITMAPCOREHEADER or a BITMAPINFOHEADER structure. The function uses the specified size to determine how the remaining members should be initialized.

If lpvBits is NULL and the bit count member of BITMAPINFO is initialized to zero, GetDIBits fills in BITMAPINFOHEADER or BITMAPCOREHEADER without the color table. This technique can be used to query bitmap attributes.
The bitmap identified by the hbmp parameter must not be selected into a device context when the application calls this function.
The origin for a bottom-up DIB is the lower-left corner of the bitmap; the origin for a top-down DIB is the upper-left corner.

See Also

BITMAPCOREHEADER, BITMAPINFO, BITMAPINFOHEADER, SetDIBits


Пригласи друзей и счет твоего мобильника всегда будет положительным!
Предыдущая статья
 
Сайт Народ.Ру Интернет
Следующая статья
Пригласи друзей и счет твоего мобильника всегда будет положительным!

GetDIBits



Функция GetDIBits извлекает биты определенного побитового отображения и копирует их в буфер, использовавший определенный формат.

int GetDIBits(

HDC hdc, // РУЧКА контекста устройства HBITMAP hbmp, // ручка побитового отображения UINT uStartScan, // строки сканирования первого, чтобы устанавливаться в побитовом отображении расположения UINT cScanLines, // номера строк сканирования, чтобы копировать LPVOID lpvBits, // адресу массива для битов побитового отображения LPBITMAPINFO lpbi, // адрес структуры с данными побитового отображения UINT uUsage // RGB или индекс палитры
);


Параметры

hdc

Идентифицирует контекст устройства.

hbmp

Идентифицирует побитовое отображение.

uStartScan

Определяет первую строку сканирования, чтобы извлекаться.

cScanLines

Определяет номер строк сканирования, чтобы извлекаться.

lpvBits

Точки на буфер, чтобы получать данные побитового отображения. Если этот параметр НЕДЕЙСТВИТЕЛЕН, функция передает измерения и формат побитового отображения в структуру BITMAPINFO указанную, чтобы параметром lpbi.

lpbi

Точки на структуру BITMAPINFO, которые определяют желаемый формат для машинонезависимого побитового отображения (DIB) данных.

uUsage

Определяет формат элемента bmiColors структуры BITMAPINFO. Это должно быть одним из следующего величин:

Значение Величины
DIB_PAL_COLORS цветная таблица должна состоять из массива 16- битовых индексов в текущую логическую палитру.
DIB_RGB_COLORS цветная таблица должна состоять из буквальных красных, зеленых, синих величин (RGB).


Обратные Величины

Если параметр lpvBits не-НЕДЕЙСТВИТЕЛЕН и функция добивается успеха, обратная величина является номером строк сканирования скопированного из побитового отображения.

Windows 95:

Если параметр lpvBits НЕДЕЙСТВИТЕЛЕН и GetDIBits успешно заполняет структуру BITMAPINFO, обратная величина является общим числом строк сканирования в побитовом отображении.

Windows NT:

Если параметр lpvBits НЕДЕЙСТВИТЕЛЕН и GetDIBits успешно заполняет структуру BITMAPINFO, обратная величина - не равным нулю.

Если функция терпит неудачу, обратная величина нулевая.

Замечания

Если запрошенный формат о DIB соответствует своему внутреннему формату, величины RGB для побитового отображения скопированы. Если запрошенный формат не соответствует внутреннему формату, цветная таблица синтезирована. Следующая таблица описывает цветную таблицу синтезированную для каждого формата.

Значение Величины
1_BPP цветная таблица состоит из черного и белого входа.
4_BPP цветная таблица состоит из смешивания цветов идентичного стандартной палитре VGA.
8_BPP цветная таблица состоит из общего смешивания 256 цветов определенного GDI. (Включенное в эти 256 цветов - 20 цветов обнаруженных в по умолчанию логической палитре.)
No цветная таблица 24_BPP возвращана.


Если параметр lpvBits является правильным указателем, первые шесть участников структуры BITMAPINFOHEADER должны быть инициализированы, чтобы определять размер и формат DIB. Отметьте, что восходящий DIB определен установкой высоты в положительное число, тогда как нисходящий DIB определен установкой высоты в отрицательный номер. Цветная таблица побитового отображения будет добавлена в структуру BITMAPINFO.
Если lpvBits НЕДЕЙСТВИТЕЛЕН, GetDIBits изучает первый элемент первой структуры указанной, чтобы lpbi. Этот элемент должен определить размер, в байтах, BITMAPCOREHEADER или структуры BITMAPINFOHEADER. Функция использует определенный размер, чтобы определять как остальные участники должны быть инициализированы.

Если lpvBits НЕДЕЙСТВИТЕЛЕН и битовый элемент счета BITMAPINFO инициализирован в нуль, GetDIBits заполняет BITMAPINFOHEADER или BITMAPCOREHEADER без цветной таблицы. Эта техника может быть использована в атрибуты побитового отображения запроса.
Побитовое отображение идентифицированное параметром hbmp не должно выбирано в контекст устройства когда приложение называет эту функцию.
Начало для восходящего DIB - левый более низкий угол побитового отображения; начало для нисходящего DIB - верхний левый угол.

Смотри Также

BITMAPCOREHEADER, BITMAPINFO, BITMAPINFOHEADER, SetDIBits


Вверх Version 1.3, Oct 26 2010 © 2007, 2010, mrhx Вверх
 mrhx software  Русский перевод OpenGL  Русский перевод Win32 API
 
Используются технологии uCoz