Merge pull request #662 from gehongyan/fix-badge-arrange
Fix Badge position miscalculation
This commit is contained in:
@@ -2,7 +2,6 @@ using Avalonia;
|
|||||||
using Avalonia.Controls;
|
using Avalonia.Controls;
|
||||||
using Avalonia.Controls.Metadata;
|
using Avalonia.Controls.Metadata;
|
||||||
using Avalonia.Controls.Primitives;
|
using Avalonia.Controls.Primitives;
|
||||||
using Avalonia.Interactivity;
|
|
||||||
using Avalonia.Media;
|
using Avalonia.Media;
|
||||||
using Avalonia.Styling;
|
using Avalonia.Styling;
|
||||||
using Ursa.Common;
|
using Ursa.Common;
|
||||||
@@ -65,29 +64,19 @@ public class Badge : HeaderedContentControl
|
|||||||
|
|
||||||
static Badge()
|
static Badge()
|
||||||
{
|
{
|
||||||
HeaderProperty.Changed.AddClassHandler<Badge>((badge, _) => badge.UpdateBadgePosition());
|
|
||||||
CornerPositionProperty.Changed.AddClassHandler<Badge>((badge, _) => badge.UpdateBadgePosition());
|
CornerPositionProperty.Changed.AddClassHandler<Badge>((badge, _) => badge.UpdateBadgePosition());
|
||||||
DotProperty.Changed.AddClassHandler<Badge>((badge, _) => badge.UpdateBadgePosition());
|
DotProperty.Changed.AddClassHandler<Badge>((badge, _) => badge.UpdateBadgePosition());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnApplyTemplate(TemplateAppliedEventArgs e)
|
protected override void OnApplyTemplate(TemplateAppliedEventArgs e)
|
||||||
{
|
{
|
||||||
|
_badgeContainer?.RemoveHandler(SizeChangedEvent, OnBadgeSizeChanged);
|
||||||
base.OnApplyTemplate(e);
|
base.OnApplyTemplate(e);
|
||||||
_badgeContainer = e.NameScope.Find<Border>(PART_BadgeContainer);
|
_badgeContainer = e.NameScope.Find<Border>(PART_BadgeContainer);
|
||||||
|
_badgeContainer?.AddHandler(SizeChangedEvent, OnBadgeSizeChanged);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnLoaded(RoutedEventArgs e)
|
private void OnBadgeSizeChanged(object? sender, SizeChangedEventArgs e) => UpdateBadgePosition();
|
||||||
{
|
|
||||||
base.OnLoaded(e);
|
|
||||||
UpdateBadgePosition();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override Size ArrangeOverride(Size finalSize)
|
|
||||||
{
|
|
||||||
var size = base.ArrangeOverride(finalSize);
|
|
||||||
UpdateBadgePosition();
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void UpdateBadgePosition()
|
private void UpdateBadgePosition()
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user