Application.AddMessageFilter(IMessageFilter) 方法

定義

新增訊息過濾器,監控 Windows 訊息被路由到目的地的過程。

public:
 static void AddMessageFilter(System::Windows::Forms::IMessageFilter ^ value);
public static void AddMessageFilter(System.Windows.Forms.IMessageFilter value);
public static void AddMessageFilter(System.Windows.Forms.IMessageFilter? value);
static member AddMessageFilter : System.Windows.Forms.IMessageFilter -> unit
Public Shared Sub AddMessageFilter (value As IMessageFilter)

參數

value
IMessageFilter

你想安裝的介面實作 IMessageFilter

範例

以下程式碼範例會產生一個稱為 TestMessageFilter的訊息過濾器。 此過濾器會阻擋所有與左鍵相關的訊息。 在使用訊息過濾器之前,必須先提供介面的 IMessageFilter 實作。

// Creates a  message filter.
ref class TestMessageFilter: public IMessageFilter
{
public:
   [SecurityPermission(SecurityAction::LinkDemand, Flags = SecurityPermissionFlag::UnmanagedCode)]
   virtual bool PreFilterMessage( Message % m )
   {
      
      // Blocks all the messages relating to the left mouse button.
      if ( m.Msg >= 513 && m.Msg <= 515 )
      {
         Console::WriteLine( "Processing the messages : {0}", m.Msg );
         return true;
      }

      return false;
   }

};
// Creates a  message filter.
public class TestMessageFilter : IMessageFilter
{
    public bool PreFilterMessage(ref Message m)
    {
        // Blocks all the messages relating to the left mouse button.
        if (m.Msg >= 513 && m.Msg <= 515)
        {
            Console.WriteLine("Processing the messages : " + m.Msg);
            return true;
        }
        return false;
    }
}
' Creates a message filter.
<SecurityPermission(SecurityAction.LinkDemand, Flags := SecurityPermissionFlag.UnmanagedCode)> _
Public Class TestMessageFilter
    Implements IMessageFilter

    <SecurityPermission(SecurityAction.Demand)> _
    Public Function PreFilterMessage(ByRef m As System.Windows.Forms.Message) _
    As Boolean Implements IMessageFilter.PreFilterMessage
        ' Blocks all the messages relating to the left mouse button.
        If ((m.Msg >= 513) And (m.Msg <= 515)) Then
            Console.WriteLine("Processing the messages : " & m.Msg)
            Return True
        End If
        Return False
    End Function
End Class

備註

使用訊息過濾器防止特定事件被觸發,或在事件傳遞給事件處理器前執行特殊操作。 訊息過濾器是特定主題獨有的。

為了防止訊息被派遣 value ,你傳遞給此方法的參數實例必須用處理該訊息的程式碼覆蓋該 PreFilterMessage 方法。 該方法必須返回 false

注意事項

在應用程式的訊息泵中加入訊息過濾器可能會降低效能。

適用於