ダイアログのみを表示する Win7-Aero にダイアログ ベースの Win32 アプリがあります。ダイアログにはタイトル バーが必要です。ユーザーが画面上でダイアログを移動できるようにしたくありません。
私は今のところ運が悪い... 取り扱いWM_NCHITTEST
、WM_SYSCOMMAND
... 設定SWP_NOMOVE
。
達成するための最良の方法は何NoMove
ですか? DWM は Win7 で何かを変更すると思います。
ダイアログのみを表示する Win7-Aero にダイアログ ベースの Win32 アプリがあります。ダイアログにはタイトル バーが必要です。ユーザーが画面上でダイアログを移動できるようにしたくありません。
私は今のところ運が悪い... 取り扱いWM_NCHITTEST
、WM_SYSCOMMAND
... 設定SWP_NOMOVE
。
達成するための最良の方法は何NoMove
ですか? DWM は Win7 で何かを変更すると思います。
ハンドリングによってこれを行うことができWM_WINDOWPOSCHANGING
、移動の試みが見られたら、座標を本来あるべき場所に戻します。例えば
switch (uMsg)
{
case WM_WINDOWPOSCHANGING:
if (!(reinterpret_cast<LPWINDOWPOS>(lParam)->flags & SWP_NOMOVE))
{
reinterpret_cast<LPWINDOWPOS>(lParam)->x = g_iMyXCoord;
reinterpret_cast<LPWINDOWPOS>(lParam)->y = g_iMyYCoord;
}
return 0;
}
ユーザーが試みた移動と、独自のプログラムが行った移動 (または、必要に応じてシステムが行った移動 - たとえば、モニターが消えた場合など) を区別するために、おそらくこれにある程度のインテリジェンスを追加する必要があります。
うまくいかないと言っても、返されたときはいつでもトラップWM_NCHITTEST
して返すことでこれを行うこともできると思いました-ただし、ウィンドウではなくウィンドウをサブクラス化することでこれを行う必要があります(最初にデフォルトのハンドラーを呼び出してから、戻り値を処理/変更する必要があります)。(システムメニューを介してユーザーが試みた動きをキャッチするため)についても同じです。HTBORDER
HTCAPTION
DialogProc
WM_SYSCOMMAND