/* コントラストを上げる 1999/ 9/24 宍戸 輝光 */ #include LRESULT CALLBACK WndProc (HWND, UINT, WPARAM, LPARAM); BOOL readBMP(LPBYTE); void cont(int); BYTE high(BYTE,int); HINSTANCE hInst; HWND hwnd; DWORD dwWidth,dwHeight,dwLength; BOOL loaded=FALSE; LPVOID lpDIB; LPBYTE lpPixel; LPBITMAPINFO lpInfo; int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, PSTR szCmdLine, int iCmdShow){ MSG msg; WNDCLASSEX wndclass ; hInst=hInstance; /* プロセスのハンドルを保存 */ wndclass.cbSize = sizeof(wndclass); wndclass.style = CS_HREDRAW | CS_VREDRAW; wndclass.lpfnWndProc = WndProc; wndclass.cbClsExtra = 0; wndclass.cbWndExtra = 0; wndclass.hInstance = hInstance; wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION); wndclass.hCursor = LoadCursor (NULL, IDC_ARROW); wndclass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH); wndclass.lpszMenuName = NULL; wndclass.lpszClassName = "CWindow"; wndclass.hIconSm = LoadIcon (NULL, IDI_APPLICATION); RegisterClassEx (&wndclass); hwnd = CreateWindow ("CWindow","コントラストを上げる", WS_OVERLAPPEDWINDOW,CW_USEDEFAULT,CW_USEDEFAULT,560,480, NULL,NULL,hInstance,NULL); ShowWindow (hwnd,iCmdShow); /* ウインドウを表示 */ UpdateWindow (hwnd); /* 再描画 */ while (GetMessage (&msg,NULL,0,0)) { /* メッセージループ */ TranslateMessage(&msg); DispatchMessage(&msg); } return msg.wParam ; } LRESULT CALLBACK WndProc (HWND hwnd, UINT iMsg, WPARAM wParam, LPARAM lParam) { HDC hdc; HDROP hDrop; PAINTSTRUCT ps; static HWND hwDoB,hwNumE; static BYTE lpszFn[256],lpszStr[16]; DWORD d; switch (iMsg) { case WM_CREATE: hwDoB=CreateWindow("Button","処理開始", /* ボタン作成 */ WS_CHILD |WS_VISIBLE,16,8,96,32,hwnd, (HMENU)0,hInst,NULL); hwNumE=CreateWindow("Edit",NULL, /* ボタン作成 */ WS_CHILD |WS_VISIBLE |WS_BORDER| ES_NUMBER,128,8,96,32,hwnd, (HMENU)1,hInst,NULL); DragAcceptFiles(hwnd,TRUE); /* ドラッグ&ドロップ受入 */ break; case WM_COMMAND: switch (LOWORD(wParam)) { case 0: /* 処理開始ボタン */ GetWindowText(hwNumE,lpszStr,16); d=atoi(lpszStr); cont(d); /* コントラストを上げる */ break; } break; case WM_DROPFILES: /* ファイルがドロップされた時の処理 */ hDrop=(HDROP)wParam; /* HDROPを取得 */ DragQueryFile(hDrop,0,lpszFn,256); /* ファイル名を取得 */ readBMP(lpszFn); DragFinish(hDrop); /* 終了処理 */ break; case WM_PAINT: hdc=BeginPaint(hwnd,&ps); if (loaded) /* ビットマップが読み込まれていれば */ StretchDIBits(hdc,4,48,dwWidth,dwHeight, 0,0,dwWidth,dwHeight,lpPixel,lpInfo, DIB_RGB_COLORS,SRCCOPY); /* DIBを画面に描画 */ EndPaint(hwnd,&ps); break; case WM_DESTROY : if (loaded) GlobalFree(lpDIB); PostQuitMessage(0); break; } return DefWindowProc (hwnd, iMsg, wParam, lParam) ; } BOOL readBMP(LPBYTE fn) { /* ビットマップ読み込み */ DWORD offset,dummy; HANDLE fh; fh=CreateFile(fn,GENERIC_READ,0,NULL,OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL,NULL); /* ファイルオープン */ if (fh==INVALID_HANDLE_VALUE) return FALSE; lpDIB=GlobalAlloc(GPTR,GetFileSize(fh,NULL)); /* バッファ確保 */ ReadFile(fh,lpDIB,GetFileSize(fh,NULL),&dummy,NULL); lpInfo=(LPBITMAPINFO)((LPBYTE)lpDIB+sizeof(BITMAPFILEHEADER)); offset=*(LPDWORD)((LPBYTE)lpDIB+10); lpPixel=(LPBYTE)lpDIB+offset; /* ビットマップバッファの先頭アドレス */ CloseHandle(fh); /* 24ビットフルカラービットマップでなければ無効 */ if (lpInfo->bmiHeader.biBitCount!=24) { GlobalFree(lpDIB); loaded=FALSE; return FALSE; } /* ビットマップの大きさ保存 */ dwWidth=lpInfo->bmiHeader.biWidth; dwHeight=lpInfo->bmiHeader.biHeight; if ((dwWidth*3) % 4==0) /* バッファの1ラインの長さを計算 */ dwLength=dwWidth*3; else dwLength=dwWidth*3+(4-(dwWidth*3) % 4); loaded=TRUE; /* 読み込みフラグセット */ InvalidateRgn(hwnd,NULL,FALSE); UpdateWindow (hwnd); /* 再描画 */ return TRUE; } void cont(int d) { /* コントラストを上げる */ DWORD i,j; for (i=0;i127) return 0; if (c(255-d)) return 255; return (BYTE)((c-d)*(double)((double)256/(double)(256-d*2))); }