Visual.AddVisualChild(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 ilişkiyi tanımlar.
protected:
void AddVisualChild(System::Windows::Media::Visual ^ child);
protected void AddVisualChild (System.Windows.Media.Visual child);
member this.AddVisualChild : System.Windows.Media.Visual -> unit
Protected Sub AddVisualChild (child As Visual)
Parametreler
- child
- Visual
Üst görsele eklenecek 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, ve yöntemlerini kullanarak AddVisualChild RemoveVisualChild üst görsel ile child
arasında üst-alt ilişkiyi ayarlar. 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, AddVisualChild iki görsel nesne arasındaki üst-alt ilişkiyi ayarlar. Görsel alt nesnelerin temel depolama uygulaması üzerinde daha düşük düzeyde denetime ihtiyaç duyduğunuzda bu yöntem kullanılmalıdır. VisualCollection alt nesneleri depolamak için varsayılan uygulama olarak kullanılabilir.