"mspgui",
"Window",
style,
- CW_USEDEFAULT, CW_USEDEFAULT,
+ (options.user_position ? options.x : CW_USEDEFAULT),
+ (options.user_position ? options.y : CW_USEDEFAULT),
rect.right-rect.left, rect.bottom-rect.top,
0,
0,
if(options.fullscreen)
SetWindowPos(priv->window, 0, 0, 0, rect.right-rect.left, rect.bottom-rect.top, SWP_NOZORDER);
+ else if(options.user_position)
+ SetWindowPos(priv->window, 0, options.x, options.y, rect.right-rect.left, rect.bottom-rect.top, SWP_NOZORDER);
else
SetWindowPos(priv->window, 0, 0, 0, rect.right-rect.left, rect.bottom-rect.top, SWP_NOMOVE|SWP_NOZORDER);
}
{
case WM_KEYDOWN:
case WM_KEYUP:
+ case WM_CHAR:
case WM_LBUTTONDOWN:
case WM_LBUTTONUP:
case WM_MBUTTONDOWN:
case WM_RBUTTONUP:
case WM_MOUSEWHEEL:
case WM_MOUSEMOVE:
- case WM_TOUCHMOVE:
+ case WM_TOUCH:
signal_input_event.emit(evnt);
break;
case WM_SIZE:
resizing = false;
signal_resize.emit(options.width, options.height);
break;
+ case WM_MOVE:
+ options.x = static_cast<short>(LOWORD(evnt.lparam));
+ options.y = static_cast<short>(HIWORD(evnt.lparam));
+ moving = false;
+ signal_move.emit(options.x, options.y);
+ break;
case WM_CLOSE:
signal_close.emit();
break;
+ case WM_PAINT:
+ {
+ RECT update_rect;
+ GetUpdateRect(priv->window, &update_rect, false);
+ unsigned width = update_rect.right-update_rect.left;
+ unsigned height = update_rect.bottom-update_rect.top;
+ signal_expose.emit(update_rect.left, update_rect.top, width, height, evnt);
+ }
+ break;
+ case WM_SETFOCUS:
+ signal_got_focus.emit();
+ break;
+ case WM_KILLFOCUS:
+ signal_lost_focus.emit();
+ break;
default:
return false;
}