csharpc-sharpdotnetxamlavaloniauicross-platformcross-platform-xamlavaloniaguimulti-platformuser-interfacedotnetcore
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
2.7 KiB
87 lines
2.7 KiB
using Avalonia.Layout;
|
|
using Avalonia.Metadata;
|
|
|
|
namespace Avalonia.Controls
|
|
{
|
|
/// <summary>
|
|
/// Base class for controls which decorate a single child control.
|
|
/// </summary>
|
|
public class Decorator : Control
|
|
{
|
|
/// <summary>
|
|
/// Defines the <see cref="Child"/> property.
|
|
/// </summary>
|
|
public static readonly StyledProperty<IControl?> ChildProperty =
|
|
AvaloniaProperty.Register<Decorator, IControl?>(nameof(Child));
|
|
|
|
/// <summary>
|
|
/// Defines the <see cref="Padding"/> property.
|
|
/// </summary>
|
|
public static readonly StyledProperty<Thickness> PaddingProperty =
|
|
AvaloniaProperty.Register<Decorator, Thickness>(nameof(Padding));
|
|
|
|
/// <summary>
|
|
/// Initializes static members of the <see cref="Decorator"/> class.
|
|
/// </summary>
|
|
static Decorator()
|
|
{
|
|
AffectsMeasure<Decorator>(ChildProperty, PaddingProperty);
|
|
ChildProperty.Changed.AddClassHandler<Decorator>((x, e) => x.ChildChanged(e));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets or sets the decorated control.
|
|
/// </summary>
|
|
[Content]
|
|
public IControl? Child
|
|
{
|
|
get { return GetValue(ChildProperty); }
|
|
set { SetValue(ChildProperty, value); }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets or sets the padding to place around the <see cref="Child"/> control.
|
|
/// </summary>
|
|
public Thickness Padding
|
|
{
|
|
get { return GetValue(PaddingProperty); }
|
|
set { SetValue(PaddingProperty, value); }
|
|
}
|
|
|
|
/// <inheritdoc/>
|
|
protected override Size MeasureOverride(Size availableSize)
|
|
{
|
|
return LayoutHelper.MeasureChild(Child, availableSize, Padding);
|
|
}
|
|
|
|
/// <inheritdoc/>
|
|
protected override Size ArrangeOverride(Size finalSize)
|
|
{
|
|
return LayoutHelper.ArrangeChild(Child, finalSize, Padding);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Called when the <see cref="Child"/> property changes.
|
|
/// </summary>
|
|
/// <param name="e">The event args.</param>
|
|
private void ChildChanged(AvaloniaPropertyChangedEventArgs e)
|
|
{
|
|
var oldChild = (Control?)e.OldValue;
|
|
var newChild = (Control?)e.NewValue;
|
|
|
|
if (oldChild != null)
|
|
{
|
|
((ISetLogicalParent)oldChild).SetParent(null);
|
|
LogicalChildren.Clear();
|
|
VisualChildren.Remove(oldChild);
|
|
}
|
|
|
|
if (newChild != null)
|
|
{
|
|
((ISetLogicalParent)newChild).SetParent(this);
|
|
VisualChildren.Add(newChild);
|
|
LogicalChildren.Add(newChild);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|