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 値が格納されている |