Поделиться через


Определение события в элементах управления Windows Forms

Для получения дополнительных сведений об определении пользовательских событий см. в разделе События. Если вы определяете событие, которое не имеет связанных данных, используйте базовый тип для данных событий, EventArgsи используйте EventHandler в качестве делегата события. Все, что еще предстоит сделать, заключается в определении члена события и защищенного метода OnEventName, который вызывает событие.

В следующем фрагменте кода показано, как элемент управления FlashTrackBar определяет пользовательское событие ValueChanged. Полный код примера FlashTrackBar можно найти в разделе Создание элемента управления Windows Forms, отображающего процесс выполнения.

Option Explicit  
Option Strict  
  
Imports System  
Imports System.Windows.Forms  
Imports System.Drawing  
  
Public Class FlashTrackBar  
   Inherits Control  
  
   ' The event does not have any data, so EventHandler is adequate
   ' as the event delegate.
   ' Define the event member using the event keyword.  
   ' In this case, for efficiency, the event is defined
   ' using the event property construct.  
   Public Event ValueChanged As EventHandler  
   ' The protected method that raises the ValueChanged
   ' event when the value has actually
   ' changed. Derived controls can override this method.
   Protected Overridable Sub OnValueChanged(e As EventArgs)  
      RaiseEvent ValueChanged(Me, e)  
   End Sub  
End Class  
using System;  
using System.Windows.Forms;  
using System.Drawing;  
  
public class FlashTrackBar : Control {  
   // The event does not have any data, so EventHandler is adequate
   // as the event delegate.  
   private EventHandler onValueChanged;  
   // Define the event member using the event keyword.  
   // In this case, for efficiency, the event is defined
   // using the event property construct.  
   public event EventHandler ValueChanged {  
            add {  
                onValueChanged += value;  
            }  
            remove {  
                onValueChanged -= value;  
            }  
        }  
   // The protected method that raises the ValueChanged  
   // event when the value has actually
   // changed. Derived controls can override this method.
   protected virtual void OnValueChanged(EventArgs e)
   {  
       onValueChanged?.Invoke(this, e);  
   }  
}  

См. также