Procedura: creare un elemento Panel personalizzato

Aggiornamento: novembre 2007

Esempio

In questo esempio viene illustrato come eseguire l'override del comportamento di layout predefinito dell'elemento Panel e creare elementi di layout personalizzati derivati da Panel.

Viene definito un semplice elemento Panel personalizzato denominato PlotPanel che posiziona gli elementi figlio in base a due coordinate x e y specificate a livello di codice (hard-coded). In questo caso x e y sono entrambi impostate su 50; pertanto, tutti gli elementi figlio sono situati in tale posizione sugli assi x e y.

Per implementare i comportamenti personalizzati di Panel, vengono utilizzati i metodi MeasureOverride e ArrangeOverride. Ogni metodo restituisce i dati Size che sono necessari per il posizionamento e il rendering degli elementi figlio.

Public Class PlotPanel
    Inherits Panel
    'Override the default Measure method of Panel.

    Protected Overrides Function MeasureOverride(ByVal availableSize As System.Windows.Size) As System.Windows.Size
        Dim childSize As Size = CType(availableSize, Size)
        For Each child As UIElement In InternalChildren
            child.Measure(childSize)
        Next
        Return MyBase.MeasureOverride(availableSize)
    End Function
    Protected Overrides Function ArrangeOverride(ByVal finalSize As System.Windows.Size) As System.Windows.Size
        For Each child As UIElement In InternalChildren
            Dim x As Double = 50
            Dim y As Double = 50
            child.Arrange(New Rect(New System.Windows.Point(x, y), child.DesiredSize))
        Next
        Return MyBase.ArrangeOverride(finalSize)
    End Function
End Class
public class PlotPanel : Panel
{
    // Default public constructor
    public PlotPanel()
        : base()
    {
    }

    // Override the default Measure method of Panel
    protected override Size MeasureOverride(Size availableSize)
    {
        Size panelDesiredSize = new Size();

        // In our example, we just have one child. 
        // Report that our panel requires just the size of its only child.
        foreach (UIElement child in InternalChildren)
        {
            child.Measure(availableSize);
            panelDesiredSize = child.DesiredSize;
        }

        return panelDesiredSize ;
    }
    protected override Size ArrangeOverride(Size finalSize)
    {
        foreach (UIElement child in InternalChildren)
        {
            double x = 50;
            double y = 50;

            child.Arrange(new Rect(new Point(x, y), child.DesiredSize));
        }
        return finalSize; // Returns the final Arranged size
    }
}

Per l'esempio completo, vedere Esempio di creazione di un elemento Panel semplice personalizzato.

Vedere anche

Attività

Esempio di creazione di un elemento Panel personalizzato con ritorno a capo del contenuto

Concetti

Cenni preliminari sugli elementi Panel

Riferimenti

Panel