Condividi tramite


FrameworkElement.RemoveLogicalChild(Object) Metodo

Definizione

Rimuove l'oggetto fornito dall'albero logico dell'elemento. FrameworkElement aggiorna i puntatori padre dell'albero logico interessato per mantenerlo sincronizzati con l'eliminazione.

protected public:
 void RemoveLogicalChild(System::Object ^ child);
protected internal void RemoveLogicalChild (object child);
member this.RemoveLogicalChild : obj -> unit
Protected Friend Sub RemoveLogicalChild (child As Object)

Parametri

child
Object

Elemento da rimuovere.

Esempio

Nell'esempio seguente viene implementata una Child proprietà in un'implementazione personalizzata FrameworkElement del livello visivo. Il setter della proprietà è progettato in modo che, se il valore cambia, il valore precedente viene rimosso dall'albero logico e da una raccolta visiva specifica della classe. I valori vengono memorizzati nella cache e quindi il nuovo valore viene aggiunto all'albero logico a livello di framework WPF standard e alla raccolta visiva personalizzata.

public virtual UIElement Child
{
    get
    {
        return _child;
    }
    set
    {
        if (_child != value)
        {
            //need to remove old element from logical tree
            if (_child != null)
            {
                OnDetachChild(_child);
                RemoveLogicalChild(_child);
            }

            _vc.Clear();

            if (value != null)
            {
                //add to visual
                _vc.Add(value);
                //add to logical
                AddLogicalChild(value);
            }

            //always add the overlay child back into the visual tree if its set
            if (_overlayVisual != null)
                _vc.Add(_overlayVisual);

            //cache the new child
            _child = value;

            //notify derived types of the new child
            if (value != null)
                OnAttachChild(_child);

            InvalidateMeasure();
        }
    }
}
<System.ComponentModel.DefaultValue(GetType(Object), Nothing)>
Public Overridable Property Child() As UIElement
    Get
        Return _child
    End Get
    Set(ByVal value As UIElement)
        If _child IsNot value Then
            'need to remove old element from logical tree
            If _child IsNot Nothing Then
                OnDetachChild(_child)
                RemoveLogicalChild(_child)
            End If

            _vc.Clear()

            If value IsNot Nothing Then
                'add to visual
                _vc.Add(value)
                'add to logical
                AddLogicalChild(value)
            End If

            'always add the overlay child back into the visual tree if its set
            If _overlayVisual IsNot Nothing Then
                _vc.Add(_overlayVisual)
            End If

            'cache the new child
            _child = value

            'notify derived types of the new child
            If value IsNot Nothing Then
                OnAttachChild(_child)
            End If

            InvalidateMeasure()
        End If
    End Set
End Property

Commenti

Usare questo metodo per l'implementazione di raccolte su oggetti che rappresentano elementi figlio logici di un elemento. Questa operazione può essere eseguita in getters o setters di proprietà, gestori di classi di Changed eventi, costruttori o all'interno dei tipi di raccolta stessi.

Per gli autori di controlli, la modifica dell'albero logico a questo livello non è la procedura consigliata, a meno che nessuno dei modelli di contenuto della classe di controllo di base forniti sia appropriato. Prendere in considerazione la sottoclasse a livello di ContentControl, ItemsControle HeaderedItemsControl. Queste classi forniscono un modello di contenuto con un'applicazione particolare degli elementi figlio logici tramite API dedicate, nonché il supporto per altre funzionalità in genere auspicabili in un controllo WPF, ad esempio lo stile tramite modelli.

Si applica a

Vedi anche