From f945ee38fea7b85957cfc5572f7826acc3d959b4 Mon Sep 17 00:00:00 2001 From: Ivan Matkov Date: Tue, 23 Apr 2024 10:55:03 +0200 Subject: [PATCH] Use z-sorted traverse in `InteropContainer` --- .../androidx/compose/ui/node/InteropContainer.kt | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/compose/ui/ui/src/skikoMain/kotlin/androidx/compose/ui/node/InteropContainer.kt b/compose/ui/ui/src/skikoMain/kotlin/androidx/compose/ui/node/InteropContainer.kt index b761528452f94..1f8f17e9f0283 100644 --- a/compose/ui/ui/src/skikoMain/kotlin/androidx/compose/ui/node/InteropContainer.kt +++ b/compose/ui/ui/src/skikoMain/kotlin/androidx/compose/ui/node/InteropContainer.kt @@ -18,9 +18,8 @@ package androidx.compose.ui.node import androidx.compose.runtime.Composable import androidx.compose.ui.Modifier +import androidx.compose.ui.areObjectsOfSameType import androidx.compose.ui.layout.OverlayLayout -import androidx.compose.ui.node.TraversableNode.Companion.TraverseDescendantsAction.CancelTraversal -import androidx.compose.ui.node.TraversableNode.Companion.TraverseDescendantsAction.ContinueTraversal /** * An interface for container that controls interop views/components. @@ -43,17 +42,19 @@ internal interface InteropContainer { */ internal fun InteropContainer.countInteropComponentsBefore(nativeView: T): Int { var componentsBefore = 0 - rootModifier?.traverseDescendants { - if (it.nativeView != nativeView) { + rootModifier?.visitSubtreeIf(Nodes.Traversable, zOrder = true) { + if (TRAVERSAL_NODE_KEY == it.traverseKey && areObjectsOfSameType(this, it)) { + @Suppress("UNCHECKED_CAST") + val interopModifierNode = it as TrackInteropModifierNode + if (interopModifierNode.nativeView == nativeView) return componentsBefore + // It might be inside Compose tree before adding in InteropContainer in case // if it was initiated out of scroll visible bounds for example. if (it.nativeView in interopViews) { componentsBefore++ } - ContinueTraversal - } else { - CancelTraversal } + true } return componentsBefore }