CreateThread関数でスレッドを作成できます。
ただし、C ランタイム ライブラリを使用する場合は、
_beginthreadexを使用します。
ウィンドウで、左クリックすると、
カップが描画されます。
描画は、CreateThreadで作成されたスレッド関数から行われます。
〇実行結果
〇プログラム例
#include <windows.h>
typedef struct _ThreadParam {
HWND owner;
HDC hMemDC;
SIZE size;
POINT point;
} ThreadParam;
DWORD WINAPI ThreadFunc(LPVOID vdParam) {
HDC hdc;
RECT rect;
ThreadParam param;
BOOL xIncrease=TRUE, yIncrease=TRUE;
param.owner = ((ThreadParam *)vdParam)->owner;
param.size.cx = ((ThreadParam *)vdParam)->size.cx;
param.size.cy = ((ThreadParam*)vdParam)->size.cy;
param.point.x = ((ThreadParam*)vdParam)->point.x;
param.point.y = ((ThreadParam*)vdParam)->point.y;
param.hMemDC= ((ThreadParam*)vdParam)->hMemDC;
GetClientRect(param.owner, &rect);
hdc = GetDC(param.owner);
GetClientRect(param.owner, &rect);
BitBlt(hdc, param.point.x, param.point.y,
param.point.x + param.size.cx, param.point.y + param.size.cy,
param.hMemDC, 0, 0, SRCCOPY);
ReleaseDC(param.owner, hdc);
return TRUE;
}
static LRESULT CALLBACK WndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
HDC hdc;
static HDC hMemDC;
PAINTSTRUCT ps;
LPSTR str = TEXT("こんにちは、日本");
static HBITMAP hForeBmp;
static HFONT hFont[2];
LPSTR FORE_BitMapFile = TEXT("sカップ.bmp");
static BITMAP bmpFore;
static HBRUSH hBrush;
RECT rect;
static POINT pt;
static BOOL xIncrease, yIncrease;
ThreadParam param;
DWORD dwID;
switch (uMsg)
{
case WM_DESTROY:
DeleteDC(hMemDC);
DeleteObject(hForeBmp);
DeleteObject(hFont[0]);
PostQuitMessage(0);
return 0;
case WM_LBUTTONDOWN:
param.owner = hWnd;
param.point.x = LOWORD(lParam);
param.point.y = HIWORD(lParam);
param.size.cx = bmpFore.bmWidth;
param.size.cy = bmpFore.bmHeight;
param.hMemDC = hMemDC;
CreateThread(NULL, 0, ThreadFunc, (LPVOID)¶m, 0, &dwID);
return 0;
case WM_CREATE:
hFont[0] = CreateFont(
40, 0, 0, 0,
FW_NORMAL, FALSE, FALSE, FALSE,
SHIFTJIS_CHARSET, OUT_DEFAULT_PRECIS,
CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY,
VARIABLE_PITCH | FF_DONTCARE, L"メイリオ"
);
ShowWindow(hWnd, SW_SHOW);
hdc = GetDC(hWnd);
hMemDC = CreateCompatibleDC(hdc);
hForeBmp = LoadImage(NULL, FORE_BitMapFile, IMAGE_BITMAP, 0, 0, LR_LOADFROMFILE);
GetObject(hForeBmp, sizeof(BITMAP), &bmpFore);
SelectObject(hMemDC, hForeBmp);
return 0;
case WM_PAINT:
hdc = BeginPaint(hWnd, &ps);
SelectObject(hdc, hFont[0]);
SetTextColor(hdc, RGB(0, 0xFF, 0));
TextOut(hdc, 0, 0, str, lstrlen(str));
EndPaint(hWnd, &ps);
return 0;
}
return DefWindowProc(hWnd, uMsg, wParam, lParam);
}
int APIENTRY wWinMain(
_In_ HINSTANCE hInstance,
_In_opt_ HINSTANCE hPrevInstance,
_In_ LPWSTR ipCmdLine,
_In_ int nCmdShow
) {
WNDCLASSEXW wcex;
wcex.cbSize = sizeof(WNDCLASSEX);
wcex.style = CS_HREDRAW | CS_VREDRAW;
wcex.lpfnWndProc = WndProc;
wcex.cbClsExtra = 0;
wcex.cbWndExtra = 0;
wcex.hInstance = hInstance;
wcex.hIcon = NULL;
wcex.hCursor = NULL;
wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1);
wcex.lpszMenuName = NULL;
wcex.lpszClassName = TEXT("TestWindow");
wcex.hIconSm = NULL;
RegisterClassExW(&wcex);
HWND hWnd = CreateWindowEx(0UL, TEXT("TestWindow"), TEXT("日本"), WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, 0, 500, 400, NULL, NULL, hInstance, NULL);
if (!hWnd)
{
return FALSE;
}
MSG msg;
while (GetMessage(&msg, NULL, 0, 0) > 0) {
DispatchMessage(&msg);
}
return (int)msg.wParam;
}