Cursor.Current と this.Cursor: カーソル制御の際立った違い
.Net プログラミングの領域では、開発者はよく依存します。ユーザーエクスペリエンスを向上させるためのカーソルのカスタマイズ。 this.Cursor プロパティは WinForms 内で広く使用されていますが、CodeRush での Cursor.Current プロパティの導入により、それらの違いについて疑問が生じています。
主な違いは、それらの動作メカニズムにあります。 Cursor.Current は、Windows から送信される WM_SETCURSOR メッセージに対する通常の応答をバイパスして、カーソルの形状を直接変更します。対照的に、this.Cursor は、WM_SETCURSOR メッセージの受信時に使用されるカーソルの形状を定義します。
Cursor.Current はカーソルの形状を即座に制御しますが、その寿命は短命である可能性があります。ユーザーがマウスを移動すると、カーソルは WM_SETCURSOR 処理を通じて Control.Cursor で指定された形状に戻ります。
この動作を説明するために、Cursor.Current を に設定してフォーム上のボタンをクリックするシナリオを考えてみましょう。 Cursors.WaitCursor を実行し、別のフォームを表示します。このような場合、Windows は引き続き WM_SETCURSOR メッセージをコントロールに送信し、指定された形状を使用するため、カーソルはデフォルト (ポインター) 状態のままになります。
待機カーソルを効果的に表示するには、Cursor.Current を組み合わせます。および .NET 2.0 で導入された Application.UseWaitCursor を利用できます。ただし、このアプローチでは、特に長時間の操作が含まれる場合には、常に望ましい結果が得られるとは限りません。
この制限を克服するために、開発者は、回答で提供されている HourGlass ヘルパー クラスを使用できます。このクラスは、時間のかかるタスクの実行中に砂時計カーソルを一時的に表示できるようにし、Cursor.Current と WM_SETCURSOR の両方を利用して適切なカーソル処理を保証します。
以上がCursor.Current と this.Cursor: .NET でのカーソル制御にそれぞれを使用する必要があるのはどのような場合ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。