Condividi tramite


DependencyObject.GetLocalValueEnumerator Metodo

Definizione

Crea un enumeratore specializzato per determinare le proprietà di dipendenza che presentano valori impostati localmente nell'oggetto DependencyObject.

public:
 System::Windows::LocalValueEnumerator GetLocalValueEnumerator();
public System.Windows.LocalValueEnumerator GetLocalValueEnumerator ();
member this.GetLocalValueEnumerator : unit -> System.Windows.LocalValueEnumerator
Public Function GetLocalValueEnumerator () As LocalValueEnumerator

Restituisce

LocalValueEnumerator

Enumeratore specializzato dei valori locali.

Esempio

Nell'esempio seguente vengono iterizzate tutte le proprietà con valori locali impostati su un oggetto e quindi viene chiamato ClearValue per cancellare i valori di ogni proprietà.

void RestoreDefaultProperties(object sender, RoutedEventArgs e)
{
    UIElementCollection uic = Sandbox.Children;
    foreach (Shape uie in uic)
    {
        LocalValueEnumerator locallySetProperties = uie.GetLocalValueEnumerator();
        while (locallySetProperties.MoveNext())
        {
            DependencyProperty propertyToClear = locallySetProperties.Current.Property;
            if (!propertyToClear.ReadOnly) { uie.ClearValue(propertyToClear); }
        }
    }
}
Private Sub RestoreDefaultProperties(ByVal sender As Object, ByVal e As RoutedEventArgs)
    Dim uic As UIElementCollection = Sandbox.Children
    For Each uie As Shape In uic
        Dim locallySetProperties As LocalValueEnumerator = uie.GetLocalValueEnumerator()
        While locallySetProperties.MoveNext()
            Dim propertyToClear As DependencyProperty = locallySetProperties.Current.Property
            If Not propertyToClear.ReadOnly Then
                uie.ClearValue(propertyToClear)
            End If
        End While
    Next
End Sub

Commenti

Un valore locale è qualsiasi valore della proprietà di dipendenza impostato da SetValue, anziché da altri aspetti del sistema di proprietà.

L'oggetto LocalValueEnumerator ottenuto chiamando GetLocalValueEnumerator può essere usato per enumerare le proprietà con un valore impostato localmente in un'istanza DependencyObject di . Ogni proprietà di questo tipo è rappresentata nell'enumeratore da un LocalValueEntry oggetto , che dispone di proprietà che fanno riferimento ai valori specifici DependencyProperty e ai relativi valori. Questa tecnica di enumerazione sui valori impostati localmente può essere usata per l'ottimizzazione o per altre operazioni di gestione dei valori locali, ad esempio per determinare quali valori di proprietà di un DependencyObject oggetto cambierebbero se fossero stati cancellati.

Importante

L'oggetto restituito LocalValueEnumerator può contenere LocalValueEntry record per le proprietà di dipendenza di sola lettura o le proprietà di dipendenza in cui i valori vengono calcolati dal sistema di proprietà. Ad esempio, un elemento del framework visivo con larghezza stabilita tramite layout segnala un valore locale per ActualWidth. Se si ottengono valori locali per reimpostarli, controllare il ReadOnly valore sull'identificatore della proprietà di ognuno LocalValueEntry per verificare che l'oggetto DependencyProperty in questione non sia di sola lettura.

Si applica a

Vedi anche