Skip to content

[0.84] fix: cancel active touches in onPointerCaptureLost to prevent zombie touch state#16087

Open
gmacmaster wants to merge 2 commits intomicrosoft:0.84-stablefrom
Virtual-Fulfillment-Technologies-Inc:cherry/onPointerCaptureLost
Open

[0.84] fix: cancel active touches in onPointerCaptureLost to prevent zombie touch state#16087
gmacmaster wants to merge 2 commits intomicrosoft:0.84-stablefrom
Virtual-Fulfillment-Technologies-Inc:cherry/onPointerCaptureLost

Conversation

@gmacmaster
Copy link
Copy Markdown
Contributor

@gmacmaster gmacmaster commented May 6, 2026

Port #16086 to 0.84

Microsoft Reviewers: Open in CodeFlow

…touch state (microsoft#16086)

* fix: cancel active touches in onPointerCaptureLost to prevent zombie touch state (#2)

* fix: cancel active touches in onPointerCaptureLost to prevent zombie touch state

When the OS reclaims pointer capture mid-gesture (system back swipe, Alt+Tab,
  another window coming foreground), onPointerCaptureLost fired but never removed
  entries from m_activeTouches or dispatched a touchcancel to React Native JS.
  The result was a zombie active touch — RN JS believed a finger was still down,
  leaving Pressables and TouchableOpacities stuck in a pressed state until the
  next touch happened to reuse the same pointer ID and trigger the stale-touch
  cleanup in onPointerPressed.

  Fix: for each captured pointer in the lost-capture set, copy and erase the
  m_activeTouches entry before calling DispatchSynthesizedTouchCancelForActiveTouch,
  mirroring the pattern already used in onPointerPressed and onPointerReleased.
  The erase-before-dispatch ordering is required because
  DispatchSynthesizedTouchCancelForActiveTouch iterates m_activeTouches internally.

* match the m_pointerCapturingComponentTag != -1 check already used in CapturePointer

* Create react-native-windows-f47bdf2a-0807-483f-b63e-3c2c086bee92.json
@gmacmaster gmacmaster requested a review from a team as a code owner May 6, 2026 00:24
@acoates-ms
Copy link
Copy Markdown
Contributor

/azp run

@azure-pipelines
Copy link
Copy Markdown
Contributor

Azure Pipelines successfully started running 1 pipeline(s).

@acoates-ms
Copy link
Copy Markdown
Contributor

/azp run

@azure-pipelines
Copy link
Copy Markdown
Contributor

Azure Pipelines successfully started running 1 pipeline(s).

@github-actions
Copy link
Copy Markdown

github-actions Bot commented May 6, 2026

Performance Test Results

Branch: cherry/onPointerCaptureLost
Commit: 3e86541e
Time: 2026-05-06T16:12:10.107Z
Tests: 161/161 passed

✅ Passed

161 scenario(s) across 28 suite(s) — no regressions

SectionList

Scenario Mean Median StdDev Renders vs Baseline
SectionList mount 5.20ms 5.00ms ±1.14ms 1 +0.0%
SectionList unmount 0.20ms 0.00ms ±0.42ms 0 +0.0%
SectionList rerender 11.10ms 11.00ms ±2.02ms 2 +4.8%
SectionList with-3-sections-15-items 5.50ms 5.00ms ±0.71ms 1 -9.1%
SectionList with-5-sections-50-items 5.80ms 5.50ms ±1.23ms 1 -8.3%
SectionList with-10-sections-200-items 6.50ms 7.00ms ±0.97ms 1 +27.3%
SectionList with-20-sections-200-items 5.50ms 5.00ms ±2.51ms 1 +0.0%
SectionList with-section-separator 1.40ms 1.00ms ±0.52ms 1 -50.0%
SectionList with-item-separator 2.30ms 2.00ms ±1.49ms 1 +0.0%
SectionList with-header-footer 1.80ms 2.00ms ±0.42ms 1 +0.0%
SectionList with-section-footer 1.80ms 2.00ms ±0.42ms 1 +0.0%
SectionList with-sticky-section-headers 2.00ms 1.50ms ±1.83ms 1 -25.0%
SectionList with-empty-list 0.50ms 0.50ms ±0.53ms 1 -50.0%
SectionList with-50-sections-1000-items 1.50ms 1.50ms ±0.53ms 1 -25.0%

FlatList

Scenario Mean Median StdDev Renders vs Baseline
FlatList mount 4.50ms 4.00ms ±0.97ms 1 +0.0%
FlatList unmount 0.10ms 0.00ms ±0.32ms 0 +0.0%
FlatList rerender 9.90ms 9.00ms ±2.13ms 2 +0.0%
FlatList with-10-items 4.40ms 4.00ms ±0.52ms 1 +0.0%
FlatList with-100-items 6.10ms 5.50ms ±1.91ms 1 +10.0%
FlatList with-500-items 4.40ms 4.50ms ±0.70ms 1 +12.5%
FlatList with-1000-items 4.70ms 4.00ms ±1.25ms 1 +0.0%
FlatList horizontal 4.10ms 4.00ms ±0.88ms 1 -20.0%
FlatList with-separator 2.50ms 2.00ms ±1.27ms 1 +0.0%
FlatList with-header-footer 1.50ms 1.50ms ±0.53ms 1 -25.0%
FlatList with-empty-list 0.40ms 0.00ms ±0.52ms 1 -100.0%
FlatList with-get-item-layout 1.30ms 1.00ms ±0.48ms 1 +0.0%
FlatList inverted 1.80ms 1.00ms ±1.55ms 1 -33.3%
FlatList with-num-columns 2.60ms 3.00ms ±0.52ms 1 +0.0%

TouchableOpacity

Scenario Mean Median StdDev Renders vs Baseline
TouchableOpacity mount 0.80ms 1.00ms ±0.42ms 1 +0.0%
TouchableOpacity unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
TouchableOpacity rerender 1.40ms 1.00ms ±1.71ms 2 +0.0%
TouchableOpacity custom-active-opacity 0.70ms 1.00ms ±0.48ms 1 +0.0%
TouchableOpacity disabled 0.50ms 0.50ms ±0.53ms 1 -50.0%
TouchableOpacity with-all-handlers 0.50ms 0.50ms ±0.53ms 1 -50.0%
TouchableOpacity with-hit-slop 0.90ms 1.00ms ±0.32ms 1 +0.0%
TouchableOpacity with-delay 0.50ms 0.50ms ±0.53ms 1 -50.0%
TouchableOpacity nested 1.40ms 1.00ms ±0.52ms 1 +0.0%
TouchableOpacity multiple-10 5.93ms 5.00ms ±2.63ms 1 -16.7%
TouchableOpacity multiple-50 25.87ms 25.00ms ±3.14ms 1 -13.8%
TouchableOpacity multiple-100 34.00ms 30.00ms ±11.63ms 1 -40.0%

ScrollView

Scenario Mean Median StdDev Renders vs Baseline
ScrollView mount 0.20ms 0.00ms ±0.42ms 1 +0.0%
ScrollView unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
ScrollView rerender 0.60ms 1.00ms ±0.52ms 2 +0.0%
ScrollView children-20 3.27ms 3.00ms ±0.59ms 1 -25.0%
ScrollView children-100 16.20ms 16.00ms ±2.14ms 1 +0.0%
ScrollView horizontal 3.10ms 3.00ms ±0.57ms 1 -25.0%
ScrollView sticky-headers 3.30ms 3.00ms ±1.70ms 1 +0.0%
ScrollView scroll-indicators 0.90ms 1.00ms ±0.32ms 1 +0.0%
ScrollView nested 1.30ms 1.00ms ±0.67ms 1 +0.0%
ScrollView content-container-style 0.70ms 1.00ms ±0.48ms 1 +0.0%
ScrollView children-500 26.67ms 24.00ms ±14.20ms 1 +26.3%

TouchableHighlight

Scenario Mean Median StdDev Renders vs Baseline
TouchableHighlight mount 0.90ms 0.50ms ±1.52ms 1 +0.0%
TouchableHighlight unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
TouchableHighlight rerender 0.50ms 0.50ms ±0.53ms 2 -50.0%
TouchableHighlight custom-underlay-color 0.40ms 0.00ms ±0.52ms 1 +0.0%
TouchableHighlight custom-active-opacity 0.40ms 0.00ms ±0.52ms 1 +0.0%
TouchableHighlight disabled 0.40ms 0.00ms ±0.52ms 1 +0.0%
TouchableHighlight with-all-handlers 0.40ms 0.00ms ±0.52ms 1 +0.0%
TouchableHighlight with-hit-slop 0.50ms 0.50ms ±0.53ms 1 +Infinity%
TouchableHighlight nested-touchables 0.70ms 1.00ms ±0.48ms 1 +0.0%
TouchableHighlight multiple-touchables-10 2.70ms 2.00ms ±1.57ms 1 -33.3%
TouchableHighlight multiple-touchables-50 13.80ms 13.00ms ±1.32ms 1 +4.0%
TouchableHighlight multiple-touchables-100 24.70ms 24.50ms ±2.06ms 1 +8.9%

Pressable

Scenario Mean Median StdDev Renders vs Baseline
Pressable mount 0.50ms 0.50ms ±0.53ms 1 +Infinity%
Pressable unmount 0.10ms 0.00ms ±0.32ms 0 +0.0%
Pressable rerender 0.50ms 0.50ms ±0.53ms 2 +0.0%
Pressable with-all-handlers 0.40ms 0.00ms ±0.52ms 1 +0.0%
Pressable with-style-function 0.20ms 0.00ms ±0.42ms 1 +0.0%
Pressable disabled 0.40ms 0.00ms ±0.52ms 1 +0.0%
Pressable with-hit-slop 0.40ms 0.00ms ±0.52ms 1 +0.0%
Pressable nested 0.80ms 1.00ms ±0.42ms 1 +0.0%
Pressable multiple-10 3.00ms 3.00ms ±0.53ms 1 +0.0%
Pressable multiple-50 14.93ms 15.00ms ±1.49ms 1 +7.1%
Pressable multiple-100 17.20ms 13.00ms ±10.02ms 1 +8.3%

Modal

Scenario Mean Median StdDev Renders vs Baseline
Modal mount 0.20ms 0.00ms ±0.42ms 1 +0.0%
Modal unmount 0.10ms 0.00ms ±0.32ms 0 +0.0%
Modal rerender 0.40ms 0.00ms ±0.52ms 2 +0.0%
Modal slide-animation 0.40ms 0.00ms ±0.52ms 1 +0.0%
Modal fade-animation 0.30ms 0.00ms ±0.48ms 1 +0.0%
Modal transparent 0.20ms 0.00ms ±0.42ms 1 +0.0%
Modal with-callbacks 0.30ms 0.00ms ±0.48ms 1 +0.0%
Modal rich-content 1.70ms 2.00ms ±0.48ms 1 +0.0%
Modal with-accessibility 0.30ms 0.00ms ±0.48ms 1 +0.0%

Image

Scenario Mean Median StdDev Renders vs Baseline
Image mount 0.00ms 0.00ms ±0.00ms 1 +0.0%
Image unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
Image rerender 0.10ms 0.00ms ±0.32ms 2 +0.0%
Image with-resize-mode 0.20ms 0.00ms ±0.42ms 1 +0.0%
Image with-border-radius 0.30ms 0.00ms ±0.48ms 1 +0.0%
Image with-tint-color 0.20ms 0.00ms ±0.42ms 1 +0.0%
Image with-blur-radius 0.10ms 0.00ms ±0.32ms 1 +0.0%
Image with-accessibility 0.30ms 0.00ms ±0.48ms 1 +0.0%
Image multiple-10 1.00ms 1.00ms ±0.00ms 1 +0.0%
Image multiple-50 3.93ms 4.00ms ±0.96ms 1 +33.3%
Image multiple-100 8.27ms 8.00ms ±1.10ms 1 +0.0%

ActivityIndicator

Scenario Mean Median StdDev Renders vs Baseline
ActivityIndicator mount 0.20ms 0.00ms ±0.42ms 1 +0.0%
ActivityIndicator unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
ActivityIndicator rerender 0.40ms 0.00ms ±0.52ms 2 +0.0%
ActivityIndicator size-large 0.00ms 0.00ms ±0.00ms 1 +0.0%
ActivityIndicator size-small 0.10ms 0.00ms ±0.32ms 1 +0.0%
ActivityIndicator with-color 0.00ms 0.00ms ±0.00ms 1 +0.0%
ActivityIndicator not-animating 0.10ms 0.00ms ±0.32ms 1 +0.0%
ActivityIndicator with-accessibility 0.20ms 0.00ms ±0.42ms 1 +0.0%
ActivityIndicator multiple-10 0.60ms 1.00ms ±0.51ms 1 +0.0%
ActivityIndicator multiple-50 3.80ms 4.00ms ±0.68ms 1 +0.0%
ActivityIndicator multiple-100 8.00ms 8.00ms ±1.31ms 1 +14.3%

Switch

Scenario Mean Median StdDev Renders vs Baseline
Switch mount 0.30ms 0.00ms ±0.48ms 1 +0.0%
Switch unmount 0.10ms 0.00ms ±0.32ms 0 +0.0%
Switch rerender 0.20ms 0.00ms ±0.42ms 2 -100.0%
Switch value-true 0.20ms 0.00ms ±0.42ms 1 +0.0%
Switch disabled 0.20ms 0.00ms ±0.42ms 1 +0.0%
Switch custom-colors 0.30ms 0.00ms ±0.48ms 1 +0.0%
Switch on-value-change 0.20ms 0.00ms ±0.42ms 1 +0.0%
Switch with-accessibility 0.20ms 0.00ms ±0.42ms 1 +0.0%
Switch multiple-10 1.93ms 2.00ms ±1.22ms 1 +0.0%
Switch multiple-50 9.67ms 9.00ms ±2.94ms 1 +0.0%
Switch multiple-100 19.20ms 18.00ms ±3.05ms 1 +12.5%

Button

Scenario Mean Median StdDev Renders vs Baseline
Button mount 0.70ms 1.00ms ±0.48ms 1 +0.0%
Button unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
Button rerender 0.80ms 1.00ms ±0.79ms 2 +0.0%
Button disabled 0.90ms 0.50ms ±1.52ms 1 -50.0%
Button with-color 0.40ms 0.00ms ±0.52ms 1 -100.0%
Button with-accessibility 0.50ms 0.50ms ±0.53ms 1 -50.0%
Button multiple-10 5.40ms 5.00ms ±0.99ms 1 -16.7%
Button multiple-50 20.93ms 25.00ms ±8.51ms 1 -7.4%
Button multiple-100 16.00ms 15.00ms ±3.42ms 1 -21.1%

TextInput

Scenario Mean Median StdDev Renders vs Baseline
TextInput mount 0.20ms 0.00ms ±0.42ms 1 +0.0%
TextInput unmount 0.10ms 0.00ms ±0.32ms 0 +0.0%
TextInput rerender 0.20ms 0.00ms ±0.42ms 2 +0.0%
TextInput multiline 0.20ms 0.00ms ±0.42ms 1 +0.0%
TextInput with-value 0.10ms 0.00ms ±0.32ms 1 +0.0%
TextInput styled 0.10ms 0.00ms ±0.32ms 1 +0.0%
TextInput multiple-100 8.13ms 8.00ms ±1.68ms 1 +14.3%

View

Scenario Mean Median StdDev Renders vs Baseline
View mount 0.20ms 0.00ms ±0.42ms 1 +0.0%
View unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
View rerender 0.20ms 0.00ms ±0.42ms 2 +0.0%
View nested-50 3.40ms 3.00ms ±0.63ms 1 +0.0%
View nested-100 7.73ms 8.00ms ±1.03ms 1 +14.3%
View shadow 0.10ms 0.00ms ±0.32ms 1 +0.0%
View border-radius 0.10ms 0.00ms ±0.32ms 1 +0.0%
View nested-500 16.67ms 10.00ms ±12.51ms 1 +0.0%

Text

Scenario Mean Median StdDev Renders vs Baseline
Text mount 0.30ms 0.00ms ±0.48ms 1 +0.0%
Text unmount 0.00ms 0.00ms ±0.00ms 0 +0.0%
Text rerender 0.20ms 0.00ms ±0.42ms 2 +0.0%
Text long-1000 0.20ms 0.00ms ±0.42ms 1 +0.0%
Text nested 0.30ms 0.00ms ±0.48ms 1 +0.0%
Text styled 0.10ms 0.00ms ±0.32ms 1 +0.0%
Text multiple-100 8.93ms 9.00ms ±1.62ms 1 +28.6%

SectionList.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
SectionList native mount 4.49ms 4.35ms ±0.40ms 1 -33.1%

FlatList.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
FlatList native mount 4.32ms 4.29ms ±0.38ms 1 -53.5%

TouchableHighlight.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
TouchableHighlight native mount 1.42ms 1.43ms ±0.08ms 1 -31.4%

TouchableOpacity.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
TouchableOpacity native mount 1.82ms 1.51ms ±0.69ms 1 -51.8%

Pressable.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
Pressable native mount 1.43ms 1.35ms ±0.25ms 1 -46.2%

ScrollView.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
ScrollView native mount 3.41ms 3.35ms ±0.36ms 1 -17.2%

ActivityIndicator.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
ActivityIndicator native mount 1.28ms 1.19ms ±0.22ms 1 -51.9%

TextInput.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
TextInput native mount 1.97ms 1.88ms ±0.24ms 1 -54.0%

Switch.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
Switch native mount 1.17ms 1.03ms ±0.44ms 1 -40.9%

Button.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
Button native mount 1.65ms 1.63ms ±0.13ms 1 -37.2%

Modal.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
Modal native mount 1.02ms 0.86ms ±0.50ms 1 -29.0%

Image.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
Image native mount 1.97ms 1.67ms ±0.90ms 1 -26.0%

View.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
View native mount 0.97ms 0.95ms ±0.13ms 1 -33.5%

Text.native-perf-test.ts

Scenario Mean Median StdDev Renders vs Baseline
Text native mount 1.22ms 1.13ms ±0.25ms 1 -35.0%

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants