Visual.RemoveVisualChild(Visual) Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
İki görsel arasındaki üst-alt öğe ilişkisini kaldırır.
protected:
void RemoveVisualChild(System::Windows::Media::Visual ^ child);
protected void RemoveVisualChild (System.Windows.Media.Visual child);
member this.RemoveVisualChild : System.Windows.Media.Visual -> unit
Protected Sub RemoveVisualChild (child As Visual)
Parametreler
- child
- Visual
Üst görselden kaldırılacak alt görsel nesnesi.
Örnekler
Aşağıdaki örnekte görsel alt öğe için özel depolama gereksinimlerinin nasıl tanımlanacağı gösterilmektedir. Örnek, üst görsel ile arasında üst-alt ilişkiyi ayarlamak için ve RemoveVisualChildchild
yöntemlerini kullanırAddVisualChild. Görsel ağacının doğru numaralandırılabilmesi için örnek, yöntemin ve VisualChildrenCount özelliğin GetVisualChild geçersiz kılınan uygulamalarını sağlar.
Not
Görsel nesneler arasında üst-alt ilişki oluşturmak için kullanmak VisualCollection mümkün olsa da, bir üst öğeye yalnızca bir alt öğe bağlandığında kendi özel depolama uygulamanızı sağlamak daha verimlidir.
// Create a host visual derived from the FrameworkElement class.
// This class provides layout, event handling, and container support for
// the child visual object.
public class MyVisualHost : FrameworkElement
{
private DrawingVisual _child;
public MyVisualHost(DrawingVisual drawingVisual)
{
_child = drawingVisual;
this.AddVisualChild(_child);
}
public DrawingVisual Child
{
get
{
return _child;
}
set
{
if (_child != value)
{
this.RemoveVisualChild(_child);
_child = value;
this.AddVisualChild(_child);
}
}
}
// Provide a required override for the VisualChildrenCount property.
protected override int VisualChildrenCount
{
get { return _child == null ? 0 : 1; }
}
// Provide a required override for the GetVisualChild method.
protected override Visual GetVisualChild(int index)
{
if (_child == null)
{
throw new ArgumentOutOfRangeException();
}
return _child;
}
' Create a host visual derived from the FrameworkElement class.
' This class provides layout, event handling, and container support for
' the child visual object.
Public Class MyVisualHost
Inherits FrameworkElement
Private _child As DrawingVisual
Public Sub New(ByVal drawingVisual As DrawingVisual)
_child = drawingVisual
Me.AddVisualChild(_child)
End Sub
Public Property Child() As DrawingVisual
Get
Return _child
End Get
Set(ByVal value As DrawingVisual)
If _child IsNot value Then
Me.RemoveVisualChild(_child)
_child = value
Me.AddVisualChild(_child)
End If
End Set
End Property
' Provide a required override for the VisualChildrenCount property.
Protected Overrides ReadOnly Property VisualChildrenCount() As Integer
Get
Return If(_child Is Nothing, 0, 1)
End Get
End Property
' Provide a required override for the GetVisualChild method.
Protected Overrides Function GetVisualChild(ByVal index As Integer) As Visual
If _child Is Nothing Then
Throw New ArgumentOutOfRangeException()
End If
Return _child
End Function
Açıklamalar
yöntemi, RemoveVisualChild iki görsel arasındaki üst-alt öğe ilişkisini kaldırır. Bu yöntem, yöntemiyle AddVisualChild birlikte görsel alt nesnelerin temel depolama uygulaması üzerinde daha düşük düzeyde denetime ihtiyacınız olduğunda kullanılmalıdır. VisualCollection alt nesneleri depolamak için varsayılan uygulama olarak kullanılabilir.