HBITMAP CreateDIBitmap( HDC hdc , CONST BITMAPINFOHEADER *lpbmih , DWORD fdwInit , CONST VOID *lpbInit , CONST BITMAPINFO *lpbmi , UINT fuUsage );hdc には、デバイスコンテキストのハンドルを指定します
#include <windows.h>
BITMAPFILEHEADER bmpFileHeader;
BITMAPINFO * bmpInfo;
BYTE * bPixelBits;
LRESULT CALLBACK WndProc(HWND hWnd , UINT msg , WPARAM wp , LPARAM lp) {
HDC hdc;
PAINTSTRUCT ps;
static BITMAP bitmap;
static HBITMAP hBitmap;
static HDC hBuffer;
switch (msg) {
case WM_DESTROY:
free(bPixelBits);
free(bmpInfo);
DeleteDC(hBuffer);
DeleteObject(hBitmap);
PostQuitMessage(0);
return 0;
case WM_CREATE:
hdc = GetDC(hWnd);
hBitmap = CreateDIBitmap(
hdc , &bmpInfo->bmiHeader ,
CBM_INIT , bPixelBits , bmpInfo , DIB_RGB_COLORS
);
hBuffer = CreateCompatibleDC(hdc);
SelectObject(hBuffer , hBitmap);
GetObject(hBitmap , sizeof (BITMAP) , &bitmap);
ReleaseDC(hWnd , hdc);
return 0;
case WM_PAINT:
hdc = BeginPaint(hWnd , &ps);
BitBlt( hdc , 0 , 0 , bitmap.bmWidth , bitmap.bmHeight ,
hBuffer , 0 , 0 , SRCCOPY
);
EndPaint(hWnd , &ps);
return 0;
}
return DefWindowProc(hWnd , msg , wp , lp);
}
int WINAPI WinMain(HINSTANCE hInstance , HINSTANCE hPrevInstance ,
PSTR lpCmdLine , int nCmdShow) {
HWND hWnd;
MSG msg;
WNDCLASS winc;
HANDLE hFile;
DWORD dwBytes;
hFile = CreateFile(lpCmdLine , GENERIC_READ , 0 , NULL ,
OPEN_EXISTING , FILE_ATTRIBUTE_NORMAL , NULL);
if (hFile == INVALID_HANDLE_VALUE) return 1;
ReadFile(hFile , &bmpFileHeader , sizeof (BITMAPFILEHEADER) , &dwBytes , NULL);
if (bmpFileHeader.bfType != 0x4D42) {
MessageBox(NULL , TEXT("This is not a bitmap file") , NULL , MB_OK);
return 1;
}
bmpInfo = (BITMAPINFO *) malloc (bmpFileHeader.bfOffBits - dwBytes);
ReadFile(hFile , bmpInfo , bmpFileHeader.bfOffBits - dwBytes , &dwBytes , NULL);
bPixelBits = (BYTE *) malloc (bmpFileHeader.bfSize - bmpFileHeader.bfOffBits);
ReadFile(hFile ,bPixelBits ,
bmpFileHeader.bfSize - bmpFileHeader.bfOffBits , &dwBytes , NULL);
CloseHandle(hFile);
winc.style = CS_HREDRAW | CS_VREDRAW;
winc.lpfnWndProc = WndProc;
winc.cbClsExtra = winc.cbWndExtra = 0;
winc.hInstance = hInstance;
winc.hIcon = LoadIcon(NULL , IDI_APPLICATION);
winc.hCursor = LoadCursor(NULL , IDC_ARROW);
winc.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
winc.lpszMenuName = NULL;
winc.lpszClassName = TEXT("KITTY");
if (!RegisterClass(&winc)) return 1;
hWnd = CreateWindow(
TEXT("KITTY") , TEXT("Kitty on your lap") ,
WS_OVERLAPPEDWINDOW | WS_VISIBLE ,
CW_USEDEFAULT , CW_USEDEFAULT ,
CW_USEDEFAULT , CW_USEDEFAULT ,
NULL , NULL , hInstance , NULL
);
if (hWnd == NULL) return 1;
while (GetMessage(&msg , NULL , 0 , 0 )) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return msg.wParam;
}
これまでのように、コマンドライン引数でビットマップファイルを指定するとint SetDIBits( HDC hdc, HBITMAP hbmp, UINT uStartScan, UINT cScanLines, CONST VOID *lpvBits, CONST BITMAPINFO *lpbmi, UINT fuColorUse );hdc にはデバイスコンテキストを指定します
#include <windows.h>
BITMAPFILEHEADER bmpFileHeader;
BITMAPINFO * bmpInfo;
BYTE * bPixelBits;
LRESULT CALLBACK WndProc(HWND hWnd , UINT msg , WPARAM wp , LPARAM lp) {
HDC hdc;
PAINTSTRUCT ps;
static BITMAP bitmap;
static HBITMAP hBitmap;
static HDC hBuffer;
switch (msg) {
case WM_DESTROY:
free(bPixelBits);
free(bmpInfo);
if (hBuffer) DeleteDC(hBuffer);
DeleteObject(hBitmap);
PostQuitMessage(0);
return 0;
case WM_CREATE:
hdc = GetDC(hWnd);
hBitmap = CreateDIBitmap(
hdc , &bmpInfo->bmiHeader , 0 , NULL , NULL , 0
);
GetObject(hBitmap , sizeof (BITMAP) , &bitmap);
ReleaseDC(hWnd , hdc);
return 0;
case WM_LBUTTONDOWN:
if (hBuffer) return 0;
hdc = GetDC(hWnd);
SetDIBits(
hdc , hBitmap , 0 , bitmap.bmHeight ,
bPixelBits , bmpInfo , DIB_RGB_COLORS
);
hBuffer = CreateCompatibleDC(hdc);
SelectObject(hBuffer , hBitmap);
ReleaseDC(hWnd , hdc);
return 0;
case WM_PAINT:
if (!hBuffer) return 0;
hdc = BeginPaint(hWnd , &ps);
BitBlt( hdc , 0 , 0 , bitmap.bmWidth , bitmap.bmHeight ,
hBuffer , 0 , 0 , SRCCOPY
);
EndPaint(hWnd , &ps);
return 0;
}
return DefWindowProc(hWnd , msg , wp , lp);
}
int WINAPI WinMain(HINSTANCE hInstance , HINSTANCE hPrevInstance ,
PSTR lpCmdLine , int nCmdShow) {
HWND hWnd;
MSG msg;
WNDCLASS winc;
HANDLE hFile;
DWORD dwBytes;
hFile = CreateFile(lpCmdLine , GENERIC_READ , 0 , NULL ,
OPEN_EXISTING , FILE_ATTRIBUTE_NORMAL , NULL);
if (hFile == INVALID_HANDLE_VALUE) return 1;
ReadFile(hFile , &bmpFileHeader , sizeof (BITMAPFILEHEADER) , &dwBytes , NULL);
if (bmpFileHeader.bfType != 0x4D42) {
MessageBox(NULL , TEXT("This is not a bitmap file") , NULL , MB_OK);
return 1;
}
bmpInfo = (BITMAPINFO *) malloc (bmpFileHeader.bfOffBits - dwBytes);
ReadFile(hFile , bmpInfo , bmpFileHeader.bfOffBits - dwBytes , &dwBytes , NULL);
bPixelBits = (BYTE *) malloc (bmpFileHeader.bfSize - bmpFileHeader.bfOffBits);
ReadFile(hFile ,bPixelBits ,
bmpFileHeader.bfSize - bmpFileHeader.bfOffBits , &dwBytes , NULL);
CloseHandle(hFile);
winc.style = CS_HREDRAW | CS_VREDRAW;
winc.lpfnWndProc = WndProc;
winc.cbClsExtra = winc.cbWndExtra = 0;
winc.hInstance = hInstance;
winc.hIcon = LoadIcon(NULL , IDI_APPLICATION);
winc.hCursor = LoadCursor(NULL , IDC_ARROW);
winc.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
winc.lpszMenuName = NULL;
winc.lpszClassName = TEXT("KITTY");
if (!RegisterClass(&winc)) return 1;
hWnd = CreateWindow(
TEXT("KITTY") , TEXT("Kitty on your lap") ,
WS_OVERLAPPEDWINDOW | WS_VISIBLE ,
CW_USEDEFAULT , CW_USEDEFAULT ,
CW_USEDEFAULT , CW_USEDEFAULT ,
NULL , NULL , hInstance , NULL
);
if (hWnd == NULL) return 1;
while (GetMessage(&msg , NULL , 0 , 0 )) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return msg.wParam;
}
このプログラムは、先ほどのプログラムの一部を改良したものですint GetDIBits( HDC hdc , HBITMAP hbmp , UINT uStartScan , UINT cScanLines , LPVOID lpvBits , LPBITMAPINFO lpbi, UINT uUsage );hdc はデバイスコンテキストのハンドル、
#include <windows.h>
TCHAR strFileName[1024];
BITMAPFILEHEADER bmpFileHeader;
BITMAPINFO * bmpInfo;
BYTE * bPixelBits;
LRESULT CALLBACK WndProc(HWND hWnd , UINT msg , WPARAM wp , LPARAM lp) {
HDC hdc;
HANDLE hFile;
PAINTSTRUCT ps;
DWORD dwBytes;
static BITMAP bitmap;
static HBITMAP hBitmap;
static HDC hBuffer;
switch (msg) {
case WM_DESTROY:
free(bPixelBits);
free(bmpInfo);
DeleteDC(hBuffer);
DeleteObject(hBitmap);
PostQuitMessage(0);
return 0;
case WM_CREATE:
hdc = GetDC(hWnd);
hBitmap = CreateDIBitmap(
hdc , &bmpInfo->bmiHeader ,
CBM_INIT , bPixelBits , bmpInfo , DIB_RGB_COLORS
);
hBuffer = CreateCompatibleDC(hdc);
SelectObject(hBuffer , hBitmap);
GetObject(hBitmap , sizeof (BITMAP) , &bitmap);
BitBlt( hBuffer , 0 , 0 , bitmap.bmWidth , bitmap.bmHeight ,
hBuffer , 0 , 0 , NOTSRCCOPY
);
GetDIBits(
hdc , hBitmap , 0 , bitmap.bmHeight ,
bPixelBits , bmpInfo , DIB_RGB_COLORS
);
ReleaseDC(hWnd , hdc);
hFile = CreateFile(strFileName , GENERIC_WRITE , 0 , NULL ,
CREATE_NEW , FILE_ATTRIBUTE_NORMAL , NULL);
if (hFile == INVALID_HANDLE_VALUE) return 0;
WriteFile( hFile , &bmpFileHeader ,
sizeof (BITMAPFILEHEADER) , &dwBytes , NULL);
WriteFile( hFile , bmpInfo ,
bmpFileHeader.bfOffBits - sizeof (BITMAPFILEHEADER) ,
&dwBytes , NULL);
WriteFile( hFile , bPixelBits ,
bmpFileHeader.bfSize - bmpFileHeader.bfOffBits ,
&dwBytes , NULL);
CloseHandle(hFile);
return 0;
case WM_PAINT:
hdc = BeginPaint(hWnd , &ps);
BitBlt( hdc , 0 , 0 , bitmap.bmWidth , bitmap.bmHeight ,
hBuffer , 0 , 0 , SRCCOPY
);
EndPaint(hWnd , &ps);
return 0;
}
return DefWindowProc(hWnd , msg , wp , lp);
}
int WINAPI WinMain(HINSTANCE hInstance , HINSTANCE hPrevInstance ,
PSTR lpCmdLine , int nCmdShow) {
HWND hWnd;
MSG msg;
WNDCLASS winc;
HANDLE hFile;
DWORD dwBytes;
hFile = CreateFile(lpCmdLine , GENERIC_READ , 0 , NULL ,
OPEN_EXISTING , FILE_ATTRIBUTE_NORMAL , NULL);
if (hFile == INVALID_HANDLE_VALUE) return 1;
ReadFile(hFile , &bmpFileHeader , sizeof (BITMAPFILEHEADER) , &dwBytes , NULL);
if (bmpFileHeader.bfType != 0x4D42) {
MessageBox(NULL , TEXT("This is not a bitmap file") , NULL , MB_OK);
return 1;
}
bmpInfo = (BITMAPINFO *) malloc (bmpFileHeader.bfOffBits - dwBytes);
ReadFile(hFile , bmpInfo , bmpFileHeader.bfOffBits - dwBytes , &dwBytes , NULL);
bPixelBits = (BYTE *) malloc (bmpFileHeader.bfSize - bmpFileHeader.bfOffBits);
ReadFile(hFile ,bPixelBits ,
bmpFileHeader.bfSize - bmpFileHeader.bfOffBits , &dwBytes , NULL);
CloseHandle(hFile);
*(lpCmdLine + lstrlen(lpCmdLine) - 4) = 0;
wsprintf(strFileName , TEXT("%s_not.bmp") , lpCmdLine);
winc.style = CS_HREDRAW | CS_VREDRAW;
winc.lpfnWndProc = WndProc;
winc.cbClsExtra = winc.cbWndExtra = 0;
winc.hInstance = hInstance;
winc.hIcon = LoadIcon(NULL , IDI_APPLICATION);
winc.hCursor = LoadCursor(NULL , IDC_ARROW);
winc.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
winc.lpszMenuName = NULL;
winc.lpszClassName = TEXT("KITTY");
if (!RegisterClass(&winc)) return 1;
hWnd = CreateWindow(
TEXT("KITTY") , TEXT("Kitty on your lap") ,
WS_OVERLAPPEDWINDOW | WS_VISIBLE ,
CW_USEDEFAULT , CW_USEDEFAULT ,
CW_USEDEFAULT , CW_USEDEFAULT ,
NULL , NULL , hInstance , NULL
);
if (hWnd == NULL) return 1;
while (GetMessage(&msg , NULL , 0 , 0 )) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return msg.wParam;
}
このプログラムは、コマンドラインで指定した Windows DIB を読み込み
HBITMAP CreateDIBitmap( HDC hdc , CONST BITMAPINFOHEADER *lpbmih , DWORD fdwInit , CONST VOID *lpbInit , CONST BITMAPINFO *lpbmi , UINT fuUsage );デバイス独立ビットマップ (DIB) からデバイス依存ビットマップ (DDB) を作成します
| 定数 | 解説 |
|---|---|
| DIB_PAL_COLORS | カラーテーブルに論理パレットに対する 16 ビットインデックスが格納されている |
| DIB_RGB_COLORS | カラーテーブルに RGB 値が格納されている |
int SetDIBits( HDC hdc, HBITMAP hbmp, UINT uStartScan, UINT cScanLines, CONST VOID *lpvBits, CONST BITMAPINFO *lpbmi, UINT fuColorUse );指定されたデバイス独立ビットマップ (DIB) の色データを使って
| 定数 | 解説 |
|---|---|
| DIB_PAL_COLORS | カラーテーブルに論理パレットに対する 16 ビットインデックスが格納されている |
| DIB_RGB_COLORS | カラーテーブルに RGB 値が格納されている |
int GetDIBits( HDC hdc , HBITMAP hbmp , UINT uStartScan , UINT cScanLines , LPVOID lpvBits , LPBITMAPINFO lpbi , UINT uUsage );指定されたビットマップのビットを取得し、指定された形式でバッファにコピーします
| 定数 | 解説 |
|---|---|
| DIB_PAL_COLORS | カラーテーブルに論理パレットに対する 16 ビットインデックスが格納されている |
| DIB_RGB_COLORS | カラーテーブルに RGB 値が格納されている |