Auf Englisch lesen

Teilen über


DependencyPropertyChangedEventArgs Struktur

Definition

Stellt Daten für verschiedene durch geänderte Eigenschaften ausgelöste Ereignisse bereit. Diese Ereignisse melden normalerweise effektive Änderungen beim Wert einer schreibgeschützten Abhängigkeitseigenschaft. Eine weitere Verwendungsmöglichkeit ist als Teil einer PropertyChangedCallback-Implementierung.

C#
public struct DependencyPropertyChangedEventArgs
Vererbung
DependencyPropertyChangedEventArgs

Beispiele

Im folgenden Beispiel wird die DependencyPropertyChangedEventArgs -Klasse im Kontext einer PropertyChangedCallback für eine bestimmte Eigenschaft einer benutzerdefinierten Klasse verwendet, die auch Ereignisse definiert. Der Rückruf übernimmt die Ergebnisse alter und neuer Werte aus dem Eigenschaftensystem, wie von DependencyPropertyChangedEventArgskommuniziert, und packt diese in eine andere Ereignisargumentklasse RoutedPropertyChangedEventArgs<T>. Die neuen Argumente werden dann als Daten für ein "ValueChanged"-Ereignis verwendet, das von der benutzerdefinierten Klasse definiert und ausgelöst wird.

C#
public static readonly DependencyProperty ValueProperty =
    DependencyProperty.Register(
        "Value", typeof(decimal), typeof(NumericUpDown),
        new FrameworkPropertyMetadata(MinValue, new PropertyChangedCallback(OnValueChanged),
                                      new CoerceValueCallback(CoerceValue)));

private static object CoerceValue(DependencyObject element, object value)
{
    decimal newValue = (decimal)value;

    newValue = Math.Max(MinValue, Math.Min(MaxValue, newValue));

    return newValue;
}

private static void OnValueChanged(DependencyObject obj, DependencyPropertyChangedEventArgs args)
{
    NumericUpDown control = (NumericUpDown)obj;

    RoutedPropertyChangedEventArgs<decimal> e = new RoutedPropertyChangedEventArgs<decimal>(
        (decimal)args.OldValue, (decimal)args.NewValue, ValueChangedEvent);
    control.OnValueChanged(e);
}
/// <summary>
/// Identifies the ValueChanged routed event.
/// </summary>
public static readonly RoutedEvent ValueChangedEvent = EventManager.RegisterRoutedEvent(
    "ValueChanged", RoutingStrategy.Bubble,
    typeof(RoutedPropertyChangedEventHandler<decimal>), typeof(NumericUpDown));

/// <summary>
/// Occurs when the Value property changes.
/// </summary>
public event RoutedPropertyChangedEventHandler<decimal> ValueChanged
{
    add { AddHandler(ValueChangedEvent, value); }
    remove { RemoveHandler(ValueChangedEvent, value); }
}
/// <summary>
/// Raises the ValueChanged event.
/// </summary>
/// <param name="args">Arguments associated with the ValueChanged event.</param>
protected virtual void OnValueChanged(RoutedPropertyChangedEventArgs<decimal> args)
{
    RaiseEvent(args);
}

Hinweise

Die Ereignisse, die die DependencyPropertyChangedEventArgs -Klasse für Ereignisdaten und die DependencyPropertyChangedEventHandler Methodenimplementierungen für Handler verwenden, folgen im Allgemeinen dem Benennungsmuster Is*Changedund werden im Allgemeinen als CLR-Ereignisse (Common Language Runtime) ohne RoutedEvent Unterstützung implementiert (es handelt sich nicht um Routingereignisse). Einige Methoden zur Klassenbehandlung, die andernfalls nicht angezeigte Ereignisse "verarbeiten", die eine Zustandsänderung über eine Eigenschaftsänderung melden, z ButtonBase.OnIsPressedChanged. B. , verwenden auch die DependencyPropertyChangedEventArgs -Klasse für Ereignisdaten.

Das Szenario für PropertyChangedCallback besteht darin, die Argumente zu verwenden, um alte und neue Werte zu melden, die aus der Eigenschaftensystembewertung der Eigenschaft stammen. Ein Rückruf, der alte und neue Werte verarbeitet, kann je nach diesen Werten eine spezielle Behandlung auswählen, z. B. die Auswahl, nicht auf Wertänderungen zu reagieren, die als unbedeutend gelten.

Konstruktoren

Eigenschaften

NewValue

Ruft den Wert der Eigenschaft nach der Änderung ab.

OldValue

Ruft den Wert der Eigenschaft vor der Änderung ab.

Property

Ruft den Bezeichner für die Abhängigkeitseigenschaft ab, für die die Änderung des Werts aufgetreten ist.

Methoden

Equals(DependencyPropertyChangedEventArgs)

Bestimmt, ob das angegebene DependencyPropertyChangedEventArgs dem aktuellen DependencyPropertyChangedEventArgs entspricht.

Equals(Object)

Bestimmt, ob das angegebene Objekt dem aktuellen DependencyPropertyChangedEventArgs entspricht.

GetHashCode()

Ruft einen Hashcode für diese DependencyPropertyChangedEventArgs ab.

Operatoren

Gilt für:

Produkt Versionen
.NET Framework 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

Weitere Informationen