3

AppBar を作成しました。AppBar は、フォーカスを失うと常に一番上に表示されたままになり、AppBar に戻るには 1 回ではなく 2 回のクリックが必要になります。最初のクリックでフォームがアクティブになり、2 回目のクリックでマウス クリック イベントが発生すると思います (予想どおり)。ここで何が間違っている可能性がありますか?私の問題は、このAppbar and focus issuesに似ています。残念ながら、そのリンクの OP は彼のソリューションを投稿していません。

CodeProject C# does Shell, Part 3のこの記事に従って AppBar を作成しました 。

Spy++ で調べましたが、なぜこれが起こっているのかわかりません。これは、このシナリオをテストして取得した Spy++ ログです (最初のクリックは機能しませんが、2 番目のクリックは機能します)。

<00001> 00090CFE S WM_PARENTNOTIFY fwEvent:WM_LBUTTONDOWN xPos:25 yPos:17
<00002> 00090CFE R WM_PARENTNOTIFY
<00003> 00090CFE S WM_WINDOWPOSCHANGING lpwp:0418EAE4
<00004> 00090CFE R WM_WINDOWPOSCHANGING
<00005> 00090CFE S WM_ACTIVATEAPP fActive:True dwThreadID:00000000
<00006> 00090CFE R WM_ACTIVATEAPP
<00007> 00090CFE S WM_NCACTIVATE fActive:True
<00008> 00090CFE R WM_NCACTIVATE
<00009> 00090CFE S WM_ACTIVATE fActive:WA_CLICKACTIVE fMinimized:False hwndPrevious:(null)
<00010> 00090CFE S WM_IME_SETCONTEXT fSet:1 iShow:C000000F
<00011> 00090CFE S WM_IME_NOTIFY dwCommand:IMN_OPENSTATUSWINDOW dwCommand:00000002 dwData:00000000
<00012> 00090CFE R WM_IME_NOTIFY
<00013> 00090CFE R WM_IME_SETCONTEXT
<00014> 00090CFE S WM_SETFOCUS hwndLoseFocus:(null)
<00015> 00090CFE R WM_SETFOCUS
<00016> 00090CFE R WM_ACTIVATE

Now happens the second click (which works)
<00017> 00090CFE S WM_PARENTNOTIFY fwEvent:WM_LBUTTONDOWN xPos:25 yPos:17
<00018> 00090CFE R WM_PARENTNOTIFY
<00019> 00090CFE S WM_WINDOWPOSCHANGING lpwp:0418E40C
<00020> 00090CFE R WM_WINDOWPOSCHANGING

Spy++ のログを見ると、問題はアクティブ化にあると思います。ウィンドウがアクティブ化されている場合にのみWM_LBUTTONDOWNイベントを受け取ると思います。しかし、他のウィンドウがアクティブ化されていないのに、ワンクリックで機能するのはなぜですか (つまり、最初にクリックする必要はありません)。

編集:問題はToolStripにあると思います。AppBarにToolStripがあります。これをどのように確認しましたか?同じフォームでボタンを作成し、クリックイベントでメッセージボックスを表示しましたが、正常に動作しています。では、それをどのように改善するのでしょうか。

4

1 に答える 1

2

よし、私は最終的にそれを理解しました.(後世のために)これが起こっていることです. 問題はフォームではなく、ToolStripにあります(Word で再現できると思います)。この機能は設計によるものであり、バグではありません。ToolStrip の WndProc内のWM_MOUSEACTIVATEメッセージでは、ウィンドウをアクティブにする (つまりフォーカスを与える) MA_ACTIVATEANDEATを返しますが、マウス メッセージを破棄します。最初のマウス メッセージが破棄されるため、2 回クリックする必要があります。

今、解決策は?派生クラスでToolStripのWndProcをオーバーライドし、 Message.Result プロパティをMA_ACTIVATEANDEATに設定する代わりに、 MA_ACTIVATEに設定します。ここにそれを行う方法に関するチュートリアルがあります。.NET 2.0 ToolStrip および MenuStrip の「クリック スルー」を有効にする方法

それが役立つことを願っています:)

于 2010-06-25T11:59:41.667 に答える