From 571c30ec6e3b1989312a8977868e9fc3e0e29b46 Mon Sep 17 00:00:00 2001 From: Martin Zikmund Date: Tue, 7 Jan 2025 16:54:23 +0100 Subject: [PATCH] chore: Adjust for better tracking --- .../Pointers/PointerEvent_Timestamp.xaml.cs | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/src/SamplesApp/UITests.Shared/Windows_UI_Xaml_Input/Pointers/PointerEvent_Timestamp.xaml.cs b/src/SamplesApp/UITests.Shared/Windows_UI_Xaml_Input/Pointers/PointerEvent_Timestamp.xaml.cs index 22156963576b..daedf90f034e 100644 --- a/src/SamplesApp/UITests.Shared/Windows_UI_Xaml_Input/Pointers/PointerEvent_Timestamp.xaml.cs +++ b/src/SamplesApp/UITests.Shared/Windows_UI_Xaml_Input/Pointers/PointerEvent_Timestamp.xaml.cs @@ -27,12 +27,15 @@ public sealed partial class PointerEvent_Timestamp : UserControl { private ulong? _lastTimestamp; private uint? _lastFrameId; - private DateTimeOffset? _lastTime; + private double? _lastElapsedTime; + private readonly Stopwatch _stopwatch = new(); public PointerEvent_Timestamp() { this.InitializeComponent(); TestBorder.PointerPressed += PointerEventArgsTests_PointerPressed; + _stopwatch.Start(); + Unloaded += (s, e) => _stopwatch.Stop(); } public ObservableCollection Logs { get; } = new ObservableCollection(); @@ -42,22 +45,23 @@ private void PointerEventArgsTests_PointerPressed(object sender, PointerRoutedEv var point = e.GetCurrentPoint(TestBorder); var timestamp = point.Timestamp; var frameId = point.FrameId; - var time = DateTimeOffset.Now; + var time = _stopwatch.Elapsed.TotalMicroseconds; var log = $"Timestamp: {timestamp}, FrameId: {frameId}" + Environment.NewLine; if (_lastTimestamp.HasValue) { - var timeDelta = (time - _lastTime.Value).TotalMicroseconds; - var timestampDelta = timestamp - _lastTimestamp.Value; + var timeDelta = (ulong)(time - _lastElapsedTime.Value); + var timestampDelta = (timestamp - _lastTimestamp.Value); log += $"Time Δ: {timeDelta}"; - var seemsCorrect = Math.Abs(timeDelta - timestampDelta) < 1000; - log += $", Timestamp Δ: {timeDelta} {(seemsCorrect ? "✔️" : "❌")}"; + // As long as the delta differs by less than 100ms, it probably is correct. + var seemsCorrect = Math.Abs((double)timeDelta - timestampDelta) < 50_000; + log += $", Timestamp Δ: {timestampDelta} {(seemsCorrect ? "✔️" : "❌")}"; var frameIdDelta = frameId - _lastFrameId.Value; log += $", FrameId Δ: {frameIdDelta}"; } - _lastTime = time; + _lastElapsedTime = time; _lastTimestamp = timestamp; _lastFrameId = frameId; Logs.Add(log);