From 2c9896720cdaa386ab7484c0b0028a561100f442 Mon Sep 17 00:00:00 2001 From: David Date: Wed, 20 Nov 2024 17:57:40 -0500 Subject: [PATCH] fix: Fix HRI not being draggable --- .../Diagnostics/DiagnosticsOverlay.cs | 21 ++++++++++++------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/src/Uno.UI.Toolkit/Diagnostics/DiagnosticsOverlay.cs b/src/Uno.UI.Toolkit/Diagnostics/DiagnosticsOverlay.cs index b26d78949ad9..33259a0db442 100644 --- a/src/Uno.UI.Toolkit/Diagnostics/DiagnosticsOverlay.cs +++ b/src/Uno.UI.Toolkit/Diagnostics/DiagnosticsOverlay.cs @@ -352,11 +352,11 @@ protected override void OnVisibilityChanged(Visibility oldValue, Visibility newV /// protected override void OnApplyTemplate() { - if (_anchor is not null) + if (_toolbar is not null) { //_anchor.Tapped -= OnAnchorTapped; - _anchor.ManipulationDelta -= OnAnchorManipulated; - _anchor.ManipulationCompleted -= OnAnchorManipulatedCompleted; + _toolbar.ManipulationDelta -= OnAnchorManipulated; + _toolbar.ManipulationCompleted -= OnAnchorManipulatedCompleted; } if (_notificationPresenter is not null) { @@ -377,12 +377,12 @@ protected override void OnApplyTemplate() _anchor = GetTemplateChild(AnchorPartName) as UIElement; _notificationPresenter = GetTemplateChild(NotificationPartName) as ContentPresenter; - if (_anchor is not null) + if (_toolbar is not null) { //_anchor.Tapped += OnAnchorTapped; - _anchor.ManipulationDelta += OnAnchorManipulated; - _anchor.ManipulationCompleted += OnAnchorManipulatedCompleted; - _anchor.ManipulationMode = ManipulationModes.TranslateX | ManipulationModes.TranslateY | ManipulationModes.TranslateInertia; + _toolbar.ManipulationDelta += OnAnchorManipulated; + _toolbar.ManipulationCompleted += OnAnchorManipulatedCompleted; + _toolbar.ManipulationMode = ManipulationModes.TranslateX | ManipulationModes.TranslateY | ManipulationModes.TranslateInertia; RenderTransform = new TranslateTransform(); } if (_notificationPresenter is not null) @@ -399,9 +399,14 @@ protected override void OnApplyTemplate() static void OnToolBarSizeChanged(object sender, SizeChangedEventArgs args) { // Patches pointer event dispatch on a 0x0 Canvas - if (sender is UIElement uie && uie.GetTemplatedParent() is DiagnosticsOverlay { TemplatedRoot: Canvas canvas }) + if (sender is UIElement uie && uie.GetTemplatedParent() is DiagnosticsOverlay { TemplatedRoot: Canvas canvas } overlay) { canvas.Width = args.NewSize.Width; + +#if __ANDROID__ + // Required for Android to effectively update the ActualSize allowing the RenderTransformAdapter to accept to apply the transform. + overlay.DispatcherQueue.TryEnqueue(() => canvas.InvalidateMeasure()); +#endif } } #endif