:詳細は
チェックこのアウトその上の車輪。
これは解決するために比較的進んだ問題です。これは、含まれるフォームのIMessageFilter
インターフェイスを実装し、WM_MOUSEWHEEL
イベントを探して、マウスがホバーオーバーしているコントロールにそれらを誘導します。このコードは、アプリケーション内のすべてのフォームだけでなく、メインフォームのためにアクティブであることを
using System;
using System.ComponentModel;
using System.Drawing;
using System.Windows.Forms;
using System.Runtime.InteropServices;
namespace WindowsApplication1 {
public partial class Form1 : Form, IMessageFilter {
public Form1() {
InitializeComponent();
Application.AddMessageFilter(this);
}
public bool PreFilterMessage(ref Message m) {
if (m.Msg == 0x20a) {
// WM_MOUSEWHEEL, find the control at screen position m.LParam
Point pos = new Point(m.LParam.ToInt32());
IntPtr hWnd = WindowFromPoint(pos);
if (hWnd != IntPtr.Zero && hWnd != m.HWnd && Control.FromHandle(hWnd) != null) {
SendMessage(hWnd, m.Msg, m.WParam, m.LParam);
return true;
}
}
return false;
}
// P/Invoke declarations
[DllImport("user32.dll")]
private static extern IntPtr WindowFromPoint(Point pt);
[DllImport("user32.dll")]
private static extern IntPtr SendMessage(IntPtr hWnd, int msg, IntPtr wp, IntPtr lp);
}
}
注:
はここ(hereから)例です。
ありがとう、そこにそれを見ましたが、なぜWM_MOUSEWHEELの取り扱いがあまり望ましくないのかわかりません。 – n0ter
ねえ、それは私のコードです!必要な属性がここで適切であるかどうかは分かりませんが、そうすべきです。 –
ポスターが投稿するコメントは、「WindowsのMouseWheelイベントの処理はあまり望ましくない」ということです。つまり、マウスホイールのデフォルトのWindows実装は、マウスがホバーしているコントロールではなく、フォーカスを持ったコントロールにイベントを送信することを意味します。ほとんどの人が期待するか、望むように、 –