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 に対応する色 (デフォルトは白) で コピー先の長方形を塗りつぶします |