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


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

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

Следующий фрагмент кода показывает, как пользовательский элемент управления 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) {
      if (ValueChanged != null) {
         ValueChanged(this, e);
      }
   }
}

См. также

Основные понятия

События элементов управления Windows Forms

Вызов события

Другие ресурсы

Обработка и вызов событий