Определение событий в элементах управления Windows Forms
Дополнительные сведения о пользовательских событиях см. в разделе события. При определении события, не имеющего связанных данных, необходимо использовать базовый тип данных о событиях, EventArgs и EventHandler в качестве делегата события. Все, что остается только определить член события и защищенный On
EventName метод, который вызывает событие.
В следующем фрагменте кода показано, как пользовательский элемент управления 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)
{
ValueChanged?.Invoke(this, e);
}
}