int StretchDIBits( HDC hdc, int XDest , int YDest , int nDestWidth , int nDestHeight , int XSrc , int YSrc , int nSrcWidth , int nSrcHeight , CONST VOID *lpBits, CONST BITMAPINFO *lpBitsInfo, UINT iUsage , DWORD dwRop );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;
RECT rect;
switch (msg) {
case WM_DESTROY:
free(bPixelBits);
free(bmpInfo);
PostQuitMessage(0);
return 0;
case WM_PAINT:
hdc = BeginPaint(hWnd , &ps);
GetClientRect(hWnd , &rect);
SetStretchBltMode(hdc , COLORONCOLOR);
StretchDIBits(
hdc , 0 , 0 , rect.right , rect.bottom , 0 , 0 ,
bmpInfo->bmiHeader.biWidth , bmpInfo->bmiHeader.biHeight ,
bPixelBits , bmpInfo , DIB_RGB_COLORS , 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 StretchDIBits( HDC hdc, int XDest , int YDest , int nDestWidth , int nDestHeight , int XSrc , int YSrc , int nSrcWidth , int nSrcHeight , CONST VOID *lpBits, CONST BITMAPINFO *lpBitsInfo, UINT iUsage , DWORD dwRop );hdc - コピー先のデバイスコンテキストを指定します
| 定数 | 解説 |
|---|---|
| DIB_PAL_COLORS | カラーテーブルに論理パレットに対する 16 ビットインデックスが格納されている |
| DIB_RGB_COLORS | カラーテーブルに RGB 値が格納されている |
| 定数 | 解説 |
|---|---|
| BLACKNESS | 物理パレットのインデックス 0 に対応する色 (デフォルトは黒) で コピー先の長方形を塗りつぶします |
| DSTINVERT | コピー先長方形の色を反転します |
| MERGECOPY | コピー元の色と、コピー先の色を 論理 AND 演算子で結合します |
| MERGEPAINT | コピー元の色を反転した色と コピー先の色を、論理 OR 演算子で結合します |
| NOTSRCCOPY | コピー元の色を反転して コピー先にコピーします |
| NOTSRCERASE | コピー元の色と、コピー先の色を 論理 OR 演算子で結合し、さらに反転します |
| PATCOPY | 指定したパターンをコピー先にコピーします |
| PATINVERT | 指定したパターンの色と、コピー先の色を 論理 XOR 演算子で結合します |
| PATPAINT | 指定したパターンの色と、コピー元の色を反転した色を 論理 OR 演算子で結合し、さらにその結果を コピー先の色と論理 OR 演算子で結合します |
| SRCAND | コピー元の色と、コピー先の色を 論理 AND 演算子で結合します |
| SRCCOPY | コピー元をコピー先にそのままコピーします |
| SRCERASE | コピー先の色を反転した色と、コピー元の色を 論理 AND 演算子で結合します |
| SRCINVERT | コピー元の色と、コピー先の色を 論理 XOR 演算子で結合します |
| SRCPAINT | コピー元の色と、コピー先の色を 論理 OR 演算子で結合します |
| WHITENESS | 物理パレットのインデックス 1 に対応する色 (デフォルトは白) で コピー先の長方形を塗りつぶします |