Status Update
Comments
si...@gmail.com <si...@gmail.com> #2
Branch: androidx-main
commit 2e60aef4d56a64a8d8732c543b644ff0b4b78734
Author: Sean McQuillan <seanmcq@google.com>
Date: Mon Dec 19 13:45:45 2022
Flesh out MultiParagraphPlaceholderLayoutCache
It's now a layout cache.
TextInlineContentLayoutDrawModifier now does similar debouncing
on input, and defers all cache behaviors to the cache.
Bug:
Test: ./gradlew :com:found:found-d-n-s-newtext:cAT
Change-Id: If104398da705747c6cdcaffe95ff9d2badd20324
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCacheTest.kt
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCacheWidthWithLetterSpacingTest.kt
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextLayoutResultIntegrationTest.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
D compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/InlineContentLayoutDrawModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawParams.kt
M compose/foundation/foundation-newtext/src/test/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCacheTest.kt
ma...@google.com <ma...@google.com>
vi...@dowjones.com <vi...@dowjones.com> #3
Branch: androidx-main
commit 968e10f6319d6e22d035191fa863e5b41c5ce957
Author: Sean McQuillan <seanmcq@google.com>
Date: Mon Dec 19 14:20:48 2022
Add semantics to static text modifier
Draws static text and adds appropriate semantics for non-editable text
This adds semantics to text modifier rewrite.
Bug:
Test: ./gradlew :com:found--d-n-s-newtext:cAT
Change-Id: I05c30a3ba21b4b409f15b15e06c271b2d759de0a
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/TextLayoutTest.kt
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/BasicTextSemanticsTest.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
ma...@google.com <ma...@google.com> #4
Branch: androidx-main
commit 56d766d1f2e2735425cf9cd20ed802c203223f56
Author: Sean McQuillan <seanmcq@google.com>
Date: Tue Dec 20 11:25:08 2022
Code cleanup for text modifiers
- Semantics allocation caching
- various logic cleanup
- cache added more invalidation branches
Bug:
Test: ./gradlew :com:found--d-n-s-newtext:cAT
Change-Id: Ice59bdee908cedb2ad7a5756a1c5810de3823bb2
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
vi...@dowjones.com <vi...@dowjones.com> #5
Branch: androidx-main
commit 48a03c8e31e7ae37924b173b7396f1087740024b
Author: Sean McQuillan <seanmcq@google.com>
Date: Tue Dec 20 14:04:38 2022
Port heightInLines behavior to new modifier
Adds support for minLines/maxLines to TextUsingModifier
Bug:
Test: ./gradlew :com:found--d-n-s-newtext:cAT
Change-Id: Ic2823ce15f10cafb180aca46e80f62d6b6abd9e0
A compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifierMinMaxLinesTest.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MinMaxLinesUtils.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawParams.kt
jr...@gmail.com <jr...@gmail.com> #6
[Deleted User] <[Deleted User]> #7
Branch: androidx-main
commit 596ad9439f540ba37416b492e991dfc90b5177b3
Author: Sean McQuillan <seanmcq@google.com>
Date: Mon Jan 09 15:03:13 2023
Fix restart behavior in TextUsingModifier
Use new restarting methods correctly
Bug:
Test: Manual - integrated with Sample app
Change-Id: I0cf75a543927280fcc1efb5b0460c50f3bc37088
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextModifier.kt
ma...@google.com <ma...@google.com> #8
Branch: androidx-main
commit b930c4eaebb6b0405197e31122c2b5cc3ac2cc38
Author: Sean McQuillan <seanmcq@google.com>
Date: Fri Jan 06 13:31:11 2023
Remove excess allocs from TextUsingModifier
- AnnotatedString overload is no-alloc for no-inline content
- Both overloads use cheaper Layout call when possible
- Cache MeasurePolicy to avoid realloc
- Merge both modifiers into StaticTextModifier
- Make semantics allocation lazy
- Cache FirstBaseline and LastBaseline calcs & map
- Don't box MultParagraphLayoutCache Pair<Int, Int>
- Don't box MinMaxLinesCoercer<Float, Float> (use NaN as sentinal instead)
Add new AnnotatedString.hasStringAnnotations zero-alloc query method
Relnote: "Add AnnotatedString.hasStringAnnotations to query for annotations with zero-allocations."
Bug:
Test: ./gradlew :com:ui:ui-text:test
Change-Id: I94dfec1e10e72e2fdc2eb482c74f8c058095b348
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCacheTest.kt
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCacheWidthWithLetterSpacingTest.kt
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextLayoutResultIntegrationTest.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/AnnotatedStringResolveInlineContent.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MinMaxLinesCoercer.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextLayoutDrawParams.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextModifier.kt
D compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
D compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawParams.kt
M compose/foundation/foundation-newtext/src/test/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCacheTest.kt
A compose/foundation/foundation-newtext/src/test/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextLayouDrawParamsTest.kt
M compose/ui/ui-text/api/current.txt
M compose/ui/ui-text/api/public_plus_experimental_current.txt
M compose/ui/ui-text/api/restricted_current.txt
M compose/ui/ui-text/src/commonMain/kotlin/androidx/compose/ui/text/AnnotatedString.kt
M compose/ui/ui-text/src/test/java/androidx/compose/ui/text/AnnotatedStringBuilderTest.kt
ch...@gmail.com <ch...@gmail.com> #9
Branch: androidx-main
commit 5753305834000e86fc9c886ce4941f4e5cf77dbf
Author: Sean McQuillan <seanmcq@google.com>
Date: Thu Jan 05 15:07:42 2023
Cache minMaxLines in new TextUsingModifier
This is a substantial increase in work for measure compared to short text.
Added a LRU=1 cache for same text layout params (in the common case of repeated text styling).
In addition, each Modifier caches internally as well.
For size = 2
Gain (time abs)| Gain (time pct) | Gain (alloc abs)
288,610 | 10.04% | 15
Bug:
Test: benchmarks
Change-Id: Ie7d16a91c2395f315319d88eb71931db835688f2
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MinMaxLinesCoercer.kt
D compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MinMaxLinesUtils.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
vi...@dowjones.com <vi...@dowjones.com> #10
Branch: androidx-main
commit 9b45a135e82b693385cdf79bd9fbd3d7803dc3c3
Author: Sean McQuillan <seanmcq@google.com>
Date: Wed Dec 21 15:17:03 2022
Modifier fixes:
* Selection now delegates onGloballyPositioned correctly
* invalidateDraw is now invalidateLayer (which works)
* Correctly restart when async typefaces resolve
Bug:
Test: ./gradlew :com:found--d-n-s-newtext:cAT
Change-Id: I7918144b56900e582908326556361cc033b967f2
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
v....@gmail.com <v....@gmail.com> #11
Branch: androidx-main
commit 325cdef1ab447cc50aeeed75a8b9af7865de23b6
Author: Sean McQuillan <seanmcq@google.com>
Date: Wed Dec 21 13:04:06 2022
Copypasta integrate selection with new modifier
This code depends on pointerInput to finalize.
For now, use remember to add lifecycle to node-like
StaticTextSelectionModifierController.
Also fixed typo s/ture/true/ linter found in presubmit
Bug:
Test: ./gradlew :com:found--d-n-s-newtext:cAT
Change-Id: I1992103b5e777a6e3e868080bb50081ee7d89fd7
M compose/foundation/foundation-newtext/build.gradle
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/ActualJvm.kt
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/ContextMenu.android.kt
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/StringHelpers.android.kt
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/TextPointerIcon.android.kt
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/TouchMode.kt
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/AndroidSelectionHandles.android.kt
A compose/foundation/foundation-newtext/src/androidMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionManager.android.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/ContextMenu.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/Expect.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/LongPressTextDragObserver.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/StringHelpers.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/TextLayoutResultProxy.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/TextPointerIcon.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/TouchMode.android.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/MultiWidgetSelectionDelegate.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/Selectable.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/Selection.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionAdjustment.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionContainer.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionHandles.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionMagnifier.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionManager.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionMode.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionRegistrar.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SelectionRegistrarImpl.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/SimpleLayout.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/TextPreparedSelection.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/TextSelectionColors.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/TextSelectionDelegate.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/copypasta/selection/TextSelectionMouseDetector.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextSelectionModifierController.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextInlineContentLayoutDrawParams.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/selection/SelectionAdjustment.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/selection/SelectionMode.kt
[Deleted User] <[Deleted User]> #12
Branch: androidx-main
commit c4a2afae6c6487104d4a930b8165f142cc04389b
Author: Sean McQuillan <seanmcq@google.com>
Date: Wed Dec 21 13:38:57 2022
Fix inline content and enable tests
This is feature complete TextUsingModifier
Bug:
Test: ./gradlew :com:found--d-n-s-newtext:cAT
Change-Id: I788ebe18d09d44b2ad784853e1b0e11dc7bfbee3
M compose/foundation/foundation-newtext/src/androidAndroidTest/kotlin/androidx/compose/foundation/newtext/text/CoreTextInlineContentTest.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/AnnotatedStringResolveInlineContent.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/MultiParagraphLayoutCache.kt
ub...@gmail.com <ub...@gmail.com> #13
Branch: androidx-main
commit cd4c15184eedd3ccb6136ccb1ba2c8ab53f6d9b1
Author: Sean McQuillan <seanmcq@google.com>
Date: Mon Jan 09 18:52:04 2023
AnnotatedString now stores internal nullable lists
This avoids allocations during all map/sort etc operations when empty.
In Composition this saves two allocs for Text("Ok")
// before
300 allocs
// after
298 allocs
Test: :com:ui:ui-text:cAT :com:ui:ui-text:test
Test: bench
Bug:
Change-Id: I5a0cd09e174a4e6d0842a1480b1cb55bfb0ea767
M compose/ui/ui-text/src/androidMain/kotlin/androidx/compose/ui/text/platform/AndroidAccessibilitySpannableString.android.kt
M compose/ui/ui-text/src/commonMain/kotlin/androidx/compose/ui/text/AnnotatedString.kt
M compose/ui/ui-text/src/commonMain/kotlin/androidx/compose/ui/text/Savers.kt
M compose/ui/ui-text/src/jvmMain/kotlin/androidx/compose/ui/text/JvmAnnotatedString.jvm.kt
M compose/ui/ui-text/src/test/java/androidx/compose/ui/text/AnnotatedStringBuilderTest.kt
M compose/ui/ui-text/src/test/java/androidx/compose/ui/text/AnnotatedStringTest.kt
ch...@gmail.com <ch...@gmail.com> #14
Branch: androidx-main
commit 383a62d168407ffee3590928cbe651cc87e0de80
Author: Sean McQuillan <seanmcq@google.com>
Date: Mon Jan 09 17:04:21 2023
Remove OnGloballyPositioned overhead from TextUsingBenchmark
This does not hit any profiled benchmarks, but will reduce the overall
cost of Text on a screen.
Test: bench
Bug:
Change-Id: Ic41a58bf39f02eca7b5bca998893093623ab05bf
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/SelectableStaticTextModifier.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/StaticTextModifier.kt
ub...@gmail.com <ub...@gmail.com> #15
Branch: androidx-main
commit ba0972437dc77a2da386c15f98093cf0028ae188
Author: Sean McQuillan <seanmcq@google.com>
Date: Wed Jan 11 17:20:01 2023
Rename modifier classes in preparation for String|AnnotatedString
Bug:
Change-Id: Ifa262aa01150b0cea5373881ccb51d9498ae2d2e
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/SelectableTextAnnotatedStringElement.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/SelectableTextAnnotatedStringNode.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextAnnotatedStringElement.kt
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextAnnotatedStringNode.kt
es...@gmail.com <es...@gmail.com> #16
di...@zillowgroup.com <di...@zillowgroup.com> #17
Branch: androidx-main
commit 9e1aa8ac0bf298ea252b9251930211d4a83a8dd5
Author: Sean McQuillan <seanmcq@google.com>
Date: Thu Jan 12 13:05:47 2023
Split String to a optimized path
Jump directly to Paragraph, skipping MultiParagraph
/// before
155,091 ns 127 allocs trace ModifierAllAppsSetText.recomposeOnly[size=2]
1,202,912 ns 297 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=2]
110,556 ns 126 allocs trace ModifierAllAppsSetText.recomposeOnly[size=16]
722,395 ns 296 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=16]
59,376 ns 126 allocs trace ModifierAllAppsSetText.recomposeOnly[size=32]
558,085 ns 296 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=32]
58,667 ns 126 allocs trace ModifierAllAppsSetText.recomposeOnly[size=64]
618,217 ns 322 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=64]
/// after
154,641 ns 126 allocs trace ModifierAllAppsSetText.recomposeOnly[size=2]
836,262 ns 269 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=2]
111,169 ns 125 allocs trace ModifierAllAppsSetText.recomposeOnly[size=16]
639,055 ns 268 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=16]
59,712 ns 125 allocs trace ModifierAllAppsSetText.recomposeOnly[size=32]
469,161 ns 268 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=32]
58,248 ns 125 allocs trace ModifierAllAppsSetText.recomposeOnly[size=64]
522,301 ns 294 allocs trace ModifierAllAppsSetText.recomposeMeasureLayout[size=64]
Bug:
Test: ./gradlew :com:found:found-d-n-s-newtext:cAT test
Change-Id: I39dc3eaa3e2ba585d6a57b804e6d6da3aa973966
M compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/TextUsingModifier.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/ParagraphLayoutCache.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextStringSimpleElement.kt
A compose/foundation/foundation-newtext/src/commonMain/kotlin/androidx/compose/foundation/newtext/text/modifiers/TextStringSimpleNode.kt
ya...@gmail.com <ya...@gmail.com> #18
Branch: androidx-main
commit 90f4c99038ccfcfd3f004bc54b666b936de0dda2
Author: Sean McQuillan <seanmcq@google.com>
Date: Tue Mar 21 13:16:22 2023
Modifier based Text now correctly computes maxLines
Allow Paragaraph to decide maxLines for static text, like old BasicText.
Bug:
Test: :com:found:found:cAT
Change-Id: Iba8e03806a7a69cf7558bb1a966f0c080d2288d1
M compose/foundation/foundation/src/androidAndroidTest/kotlin/androidx/compose/foundation/text/modifiers/MultiParagraphLayoutCacheTest.kt
A compose/foundation/foundation/src/androidAndroidTest/kotlin/androidx/compose/foundation/text/modifiers/ParagraphLayoutCacheTest.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/modifiers/MinLinesConstrainer.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/modifiers/MultiParagraphLayoutCache.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/modifiers/ParagraphLayoutCache.kt
ya...@gmail.com <ya...@gmail.com> #19
Branch: androidx-main
commit 3c50497658bbee90a40a88a3647ba1c485782d48
Author: Sean McQuillan <seanmcq@google.com>
Date: Mon Mar 20 14:23:18 2023
Enable the new Modifier-backed Text by default
Bug:
Test: cAT
Change-Id: Iada234d046dffb92e45c1a910f6976aa1dd339cf
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/BasicText.kt
ya...@gmail.com <ya...@gmail.com> #20
The following release(s) address this bug.It is possible this bug has only been partially addressed:
androidx.compose.foundation:foundation:1.5.0-alpha02
ya...@gmail.com <ya...@gmail.com> #21
Branch: androidx-main
commit a79c4d456ce18733d152c08a72781f84af8bb8e0
Author: Sean McQuillan <seanmcq@google.com>
Date: Wed Apr 26 13:42:00 2023
Remove old text stack, stabilizing Text for 1.5 release.
This removes the old text stack completely, in preparation for the 1.5 release.
Bug:
Test: ./gradle :com:found:found:[test|cAT]
Relnote: "New text stack is newly stable in 1.5."
Relnote: "NewTextRendering1_5 configuration option is removed"
Change-Id: Id5f40ede246efd5679fde7500a7f90e2b6faa7d9
M compose/foundation/foundation/api/current.txt
M compose/foundation/foundation/api/public_plus_experimental_current.txt
M compose/foundation/foundation/api/restricted_current.txt
M compose/foundation/foundation/src/androidAndroidTest/kotlin/androidx/compose/foundation/text/TextUsingModifierMinMaxLinesTest.kt
M compose/foundation/foundation/src/androidAndroidTest/kotlin/androidx/compose/foundation/text/modifiers/BasicTextSemanticsTest.kt
M compose/foundation/foundation/src/androidAndroidTest/kotlin/androidx/compose/foundation/text/modifiers/TextStringSimpleNodeTest.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/AnnotatedStringResolveInlineContent.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/BasicText.kt
D compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/CoreText.kt
M compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/TextDelegate.kt
D compose/foundation/foundation/src/commonMain/kotlin/androidx/compose/foundation/text/TextUsingModifier.kt
D compose/foundation/foundation/src/test/kotlin/androidx/compose/foundation/text/TextControllerTest.kt
D compose/foundation/foundation/src/test/kotlin/androidx/compose/foundation/text/TextSelectionLongPressDragTest.kt
D compose/foundation/foundation/src/test/kotlin/androidx/compose/foundation/text/TextStateTest.kt
M compose/integration-tests/demos/src/main/java/androidx/compose/integration/demos/DemoApp.kt
M tv/tv-material/src/main/java/androidx/tv/material3/Text.kt
me...@gmail.com <me...@gmail.com> #22
The following release(s) address this bug.It is possible this bug has only been partially addressed:
androidx.tv:tv-material:1.0.0-alpha07
[Deleted User] <[Deleted User]> #23
I have a simple hierarchy:
Coordinator
- AppBarLayout with height > ?actionBarSize (scrollFlags = scroll)
- ComposeView
- LazyColumn(rememberViewInteropNestedScrollConnection)
The regular scroll works fine, but when I do fling, coordinator intercepts only part of a velocity, doesn't matter how "hard" I swipe.
Don't you guys have this issue?
Are there any workaround for fling behavior?
ma...@google.com <ma...@google.com> #24
Is there any planned release for this fix? Should we hope it for 1.2.0 alpha 3?
No updates yet in this regard, we will let you know when there's a known release this will be provided in.
ni...@google.com <ni...@google.com>
ma...@google.com <ma...@google.com>
di...@swiggy.in <di...@swiggy.in> #25
NestedScrollView
ComposeView
LazyColumn
RecyclerView
The following error is thrown:
java.lang.IllegalStateException: Nesting scrollable in the same direction layouts like LazyColumn and Column(Modifier.verticalScroll()) is not allowed. If you want to add a header before the list of items please take a look on LazyColumn component which has a DSL api which allows to first add a header via item() function and then the list of items via items().
ma...@google.com <ma...@google.com> #26
This is an unrelated problem to the nested scroll in this ticket. In your case error message indicates that you are on the old compose version, newer error message explain how to fix it. Right now it says
Vertically scrollable component was measured with an infinity maximum height " +
"constraints, which is disallowed. One of the common reasons is nesting layouts " +
"like LazyColumn and Column(Modifier.verticalScroll()). If you want to add a " +
"header before the list of items please add a header as a separate item() before " +
"the main items() inside the LazyColumn scope. There are could be other reasons " +
"for this to happen: your ComposeView was added into a LinearLayout with some " +
"weight, you applied Modifier.wrapContentSize(unbounded = true) or wrote a " +
"custom layout. Please try to remove the source of infinite constraints in the " +
"hierarchy above the scrolling container.
If you observe any bug in the toolkit - please file another issue, otherwise there's stackoverflow and kotlinlang slack where community can help with the code and error.
ap...@google.com <ap...@google.com> #27
Branch: androidx-main
commit fc31a066f4f02a0b9e7a22de99a4255602200a06
Author: Levi Albuquerque <levima@google.com>
Date: Tue Mar 01 09:50:06 2022
Nested Scrolling Interop Phase 1: Scrolling compose in cooperating view
In this first implementation of the nested scrolling interop we're adding support
for the case where a Compose scrolling container is placed within a cooperating
view. This means the View can receive scroll deltas from a scrolling child (it already
implements NestedScrollingParent3). This is the case of a CoordinatorLayout.
Test: Added sample and tests to check the behavior.
Relnote: "Enable Nested Scroll interop between View and Compose for
cooperating View classes. This means compose is now able to dispatch scroll deltas to a (cooperating) View parent."
Fixes: 174348612
Change-Id: I5d1ac5fdeced612ac07f0c26ce14284a43369673
A compose/ui/ui/samples/src/main/java/androidx/compose/ui/samples/NestedScrollInteropSamples.kt
M compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/platform/Wrapper.android.kt
M compose/ui/ui/api/current.txt
A compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/platform/NestedScrollInteropAdapter.kt
M compose/ui/ui/build.gradle
M compose/ui/ui-tooling/src/androidAndroidTest/kotlin/androidx/compose/ui/tooling/ComposeViewAdapterTest.kt
M compose/ui/ui/integration-tests/ui-demos/src/main/java/androidx/compose/ui/demos/viewinterop/PointerInputInteropComposeInAndroid.kt
M compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/platform/AndroidComposeView.android.kt
M compose/ui/ui/api/restricted_current.txt
A compose/ui/ui/src/androidAndroidTest/res/layout/test_nested_scroll_coordinator_layout.xml
A compose/ui/ui/integration-tests/ui-demos/src/main/res/layout/compose_in_android_coordinator_layout.xml
M compose/ui/ui/integration-tests/ui-demos/build.gradle
A compose/ui/ui/src/androidAndroidTest/kotlin/androidx/compose/ui/viewinterop/NestedScrollInteropTest.kt
M compose/ui/ui/integration-tests/ui-demos/src/main/AndroidManifest.xml
M compose/ui/ui/api/public_plus_experimental_current.txt
le...@google.com <le...@google.com>
ap...@google.com <ap...@google.com> #28
Branch: androidx-main
commit 697235331591da8efbc20a8f4a9896b2e17b0c1e
Author: Levi Albuquerque <levima@google.com>
Date: Tue Mar 22 16:31:44 2022
Nested Scrolling Interop Phase 2: A scrolling view child inside a compose parent
In this phase I made AndroidViewHolder to implement NestedScrollingParent3.
That way it will act as a nested scroll parent for a containing view.
At the same time, it uses an internal NestedScrollDispatcher to forward
deltas to a Compose Parent, so it also can act as a nested scroll child
for a compose parent.
Test: Added sample and tests to check the behavior.
Relnote: "Enable Nested Scroll interop between Compose and View in the
direction Compose > View. This means that a compose parent will be able to
receive nested scroll deltas from a nested scroll view."
Fixes: 174348612
Change-Id: If7949ccb50ba7897bc740b489fd3f4d615a5369b
M compose/ui/ui/samples/src/main/java/androidx/compose/ui/samples/NestedScrollInteropSamples.kt
M compose/ui/ui/src/androidAndroidTest/kotlin/androidx/compose/ui/viewinterop/NestedScrollInteropConnectionTest.kt
A compose/ui/ui/src/androidAndroidTest/res/layout/android_in_compose_nested_scroll_interop_list_item.xml
A compose/ui/ui/src/androidAndroidTest/res/layout/test_nested_scroll_coordinator_layout_without_toolbar.xml
M compose/ui/ui/api/current.txt
M compose/ui/ui/samples/build.gradle
M compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/viewinterop/AndroidViewHolder.android.kt
M compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/viewinterop/AndroidView.android.kt
M compose/ui/ui/build.gradle
M compose/ui/ui/integration-tests/ui-demos/src/main/java/androidx/compose/ui/demos/viewinterop/PointerInputInteropAndroidInCompose.kt
A compose/ui/ui/integration-tests/ui-demos/src/main/res/layout/android_in_compose_nested_scroll_interop_list_item.xml
M compose/ui/ui/api/restricted_current.txt
A compose/ui/ui/integration-tests/ui-demos/src/main/res/layout/android_in_compose_nested_scroll_interop.xml
A compose/ui/ui/src/androidAndroidTest/res/layout/android_in_compose_nested_scroll_interop.xml
M compose/ui/ui/src/androidMain/kotlin/androidx/compose/ui/platform/NestedScrollInteropConnection.kt
A compose/ui/ui/src/androidAndroidTest/kotlin/androidx/compose/ui/viewinterop/NestedScrollInteropViewHolderTest.kt
M compose/ui/ui/api/public_plus_experimental_current.txt
ub...@gmail.com <ub...@gmail.com> #29
The change from requestDisallowInterceptTouchEvent()
setup from setNestedScrollingEnabled()
on top of the MapView
and a scrollable()
Modifier on a parent Box
. Am I missing something, or does this not work with MapView for some reason? My MapView is inside a horizontal accompanist pager; I tried both vertical and horizontal orientations for scrollable()
, but either one just gets swallowed, and I cannot drag the map in the specified orientation, or drag the pager element.
le...@google.com <le...@google.com> #30
Hi, thanks for your comment. The Modifier.scrollable in the example is just an illustration so one can see the scroll deltas being propagated up the nested scrolling chain across view and compose. If I understand you example correctly, you have a compose scrollable parent (HorizontalPager) + a View (MapView) child. In this case, just setNestedScrollingEnabled() should suffice.
ub...@gmail.com <ub...@gmail.com> #31
Gotcha, thanks for the quick response. Alas, it did not fix my problem. What I want is to have my MapView be scrollable horizontally inside a horizontal accompanist pager. (There is more screen real estate besides the MapView that the user can drag the pager on.) With or without setNestedScrollingEnabled()
, only the pager ever scrolls.
Here's the rough Compose tree:
HorizontalPager {
Column {
AndroidView({
MapView().also { ViewCompat.setNestedScrollingEnabled(it, true) }
})
Text("Drag me to flip the page")
}
}
le...@google.com <le...@google.com> #32
Hey, so from the sample you added above, if you swipe on top of the text "Drag me to flip the page" the pager goes to the next page, but if you do the same on top of the map, you want the map to scroll instead of the pager? I can see how this would be the desired behavior, but ff this is the case we'll need to re-check. MapView is a "special" type of View and I don't think it dispatches NestedScrolling the same way other scrollable containers would (using the nested scrolling system).
ub...@gmail.com <ub...@gmail.com> #33
Yes, that is the desired behavior. Short of Compose support, I am able to make it happen by wrapping the MapView inside this custom view; it's a pattern from androidx ViewPager2:
class TouchWrappingLayout(context: Context) : FrameLayout(context) {
override fun onInterceptTouchEvent(e: MotionEvent): Boolean {
parent.requestDisallowInterceptTouchEvent(true)
return super.onInterceptTouchEvent(e)
}
}
mr...@gmail.com <mr...@gmail.com> #34
On non-compose version a fling event propagates to top appbar, so it collapses smothly
But compose behaviour is different - appbar wont collapse (or expand) when I do a fling gesture
Am I doing something wrong?
n....@gmail.com <n....@gmail.com> #35
le...@google.com <le...@google.com> #36
Hi, we are aware that nestedScroll has some issues with fling movements (see:
wo...@ubique.ch <wo...@ubique.ch> #37
I'm having trouble using Compose nested scrolling inside a BottomSheet. Scrolling upwards (so further down in a list) works fine, meaning it first expands the BottomSheet before scrolling in the Compose LazyColumn. However scrolling downwards (so further up in a list) immediately starts collapsing the BottomSheet instead of first scrolling to the top of the LazyColumn and then collapsing the BottomSheet. Is there a fix or workaround for this issue?
Here's an example:
XML:
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/white">
<LinearLayout
android:id="@+id/bottomSheet"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#e9e9e9"
android:orientation="vertical"
android:padding="5dp"
app:layout_behavior="@string/bottom_sheet_behavior">
<androidx.compose.ui.platform.ComposeView
android:id="@+id/composeContent"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
</androidx.coordinatorlayout.widget.CoordinatorLayout>
Activity:
class ComposeActivity : AppCompatActivity() {
@OptIn(ExperimentalComposeUiApi::class)
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val binding = ActivityComposeBinding.inflate(layoutInflater)
setContentView(binding.root)
binding.composeContent.setContent {
LazyColumn(
Modifier
.nestedScroll(rememberNestedScrollInteropConnection(binding.composeContent))
.fillMaxSize()
) {
items(100) {
Text("Item $it", Modifier.fillMaxWidth(), Color.Black)
}
}
}
}
}
[Deleted User] <[Deleted User]> #38
wo...@ubique.ch <wo...@ubique.ch> #39
Neither the official Compose rememberNestedScrollInteropConnection()
nor the ViewInteropNestedScrollConnection
from #9 fixes the problem I described in #37. I've attached a video showing the issue. When the bottom sheet is fully expanded and the nested composable is not scrolled to the top, I would expect to first scroll the nested composable and not start dragging the bottom sheet down until its collapsed state is reached.
le...@google.com <le...@google.com> #40
Hi, I have tested #37 locally using rememberNestedScrollInteropConnection() and I see the correct behavior. Are you using the latest version of compose? I noticed your rememberNestedScrollInteropConnection still has binding.composeContent, whilst in the latest version we don't need to pass the compose view anymore.
le...@gmail.com <le...@gmail.com> #41
This rememberNestedScrollInteropConnection() is not working for me. Can you please explain what is going wrong here?
My situation is that I'm building a bottom sheet with using BottomSheetDialogFragment. Here is my layout
<androidx.coordinatorlayout.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<androidx.compose.ui.platform.ComposeView
android:id="@+id/composeView"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</androidx.coordinatorlayout.widget.CoordinatorLayout>
Here is how I render my ComposeView, note that the top node of the ComposeView is not LazyColumn:
composeView.setContent {
Column // Set nestedScroll(rememberNestedScrollInteropConnection()) here
- Composable 1 (Top bar)
- Columm(modifier = Modifier.weight(1f))
- LazyColumn // Doesn't work with this LazyColumn here
- Composable 2 (Bottom bar)
}
What I'm doing wrong here? Note that using the workaround from #9 works for me. I use #9 directly to the LazyColumn as it does not require binding with composeView.
wo...@ubique.ch <wo...@ubique.ch> #42
#40: I am using Compose 1.2.0-alpha08, which at the time of writing is the latest version in the Google Maven. When checking the 1.2.0-alpha08 sources jar from rememberNestedScrollInteropConnection
function in NestedScrollInteropConnection.kt
still requires passing a ComposeView as parameter. I can see
I have attached a sample project which shows the behavior I reported in #37 using Compose 1.2.0-alpha08 and using either the official NestedScrollInteropConnection
or the ViewInteropNestedScrollConnection
from #9.
le...@google.com <le...@google.com> #43
Hi #41, could you provide a full code sample so I can better understand and test it? From your sample alone I don't see anything apart the ComposeView inside your xml so I'm not sure why you're using the interop connection here. Thank you!
le...@google.com <le...@google.com> #44
Hi #42, thanks for the sample. Yes, I'm looking into the schedule and it seems that it hasn't been released yet. You can copy and paste it to test it out, but I'm attaching a video I made with the latest version and this seems to be working. Once you're able to test it (either by copying and pasting or waiting for the next release) let me know if the issue is really solved. I'll keep an eye out for this, thanks for reporting!
fl...@polarsteps.com <fl...@polarsteps.com> #45
wo...@ubique.ch <wo...@ubique.ch> #46
Hi #44: I've updated to the new Compose 1.2.0-beta01 where the new parameter-less rememberNestedScrollInteropConnection()
function is available. However, this update made it worse in my sample project, as the bottom sheet now no longer expands/shrinks at all when scrolling in the compose content. Only grabbing the bottom sheet itself changes the expanded state. I've attached a video of the new behavior.
le...@google.com <le...@google.com> #47
Hi #46, this is the version of your sample I have used to generate the video above. I only made minimal changes to update the version and remove unnecessary code. I have just tried it again and it seems to be working.
If the sample you're using is different than this one, could you file a bug in another ticket so we can follow up from there?
Thank you.
wo...@ubique.ch <wo...@ubique.ch> #48
Hi #47: You're right, it is working with the new 1.2.0-beta01. I still had a reference to the rememberViewInteropNestedScrollConnection(binding.composeContent)
from #9 in the code, which interfered with the NestedScrollingChildHelper of the official rememberNestedScrollInteropConnection()
. Thanks a lot for the support and the fix!
kr...@codequest.com <kr...@codequest.com> #49
#47, I modified your BottomSheetCompose2.zip to provide a minimal reproducible example. My main issue is that some places of bottom sheet don't react at all to drag&dismiss gesture (apart from `LazyColumn`). Please see `BottomSheetFragment` class for reference.
ch...@gmail.com <ch...@gmail.com> #50
One of the issues here is that BottomSheetBehavior
calls view.canScrollVertically()
on the nested scrolling view. ComposeView
doesn't implement that, so it's a bit broken atm. I'm surprised this wasn't picked up in testing?
We previously had a workaround of manually creating a 'proxy' nested scrolling view, attaching it via AndroidView
and then instrumenting its canScrollVertically
function based on the LazyListState
. That no longer works in Compose 1.2.0 as rememberNestedScrollInteropConnection()
uses the LocalView
internally rather than allowing us to pass that view through.
qu...@gmail.com <qu...@gmail.com> #51
le...@google.com <le...@google.com> #52
Hi #49, thank you for reporting this. I looked into your sample and I think some clarifications are needed, we're working on adding more documentation around the nested scroll interop in order to avoid confusions in the future, but for now here's the explanation:
- rememberNestedScrollInteropConnection will install a NestedScrollConnection in the element you attached it to, in this case the Box element. The NestedScrollConnection is responsible for transmitting the deltas from the Compose level to the View level. Note that it enables the element to participate in nested scrolling, but it doesn't scroll elements automatically.
- Box is not scrollable automatically, so when you touch the non-scrollable area it, Compose won't propagate deltas in the nested scroll system and the deltas won't reach the NestedScrollConnection provided by rememberNestedScrollInteropConnection, therefore those deltas won't reach the view world.
- When you touch the scrollable portion of compose, the LazyList, the deltas are propagated in the nested scroll system and that's why it works when you scroll it.
- To have the scrolling deltas reach the view world you'd need to either include your text in the Lazy list as a one-off element (using the item{} DSL or to make your outter box scrollable using the .scrollable modifier.
Hopefully the explanation makes sense, let us know what you think. Thank you!
le...@google.com <le...@google.com> #53
Hi #51, the issues with fling is on our roadmap for upcoming releases, stay tuned to these two tickets (
fj...@gmail.com <fj...@gmail.com> #54
I want to scroll pager when i have scrolled to the bottom of lazy column, but its not working.
I tried using rememberNestedScrollInteropConnection, but it did not work.
I Have ViewPager with vertical orientation, Which has fragment with structure like this
<NestedScrollableHost>
<ComposeView>
</NestedScrollHost>
ComposeView has lazy column with vertical orientation.
Seems thats because ComposeView return canScrollVertically as false. I can't use requestDisallowInterceptTouchEvent() to decide to whom give scroll permission. Is there any workaround that i could use to make it work?
Here is the code for NestedScrollableHost:
class NestedScrollableHost : FrameLayout {
constructor(context: Context) : super(context)
constructor(context: Context, attrs: AttributeSet?) : super(context, attrs)
private var touchSlop = 0
private var initialX = 0f
private var initialY = 0f
private val parentViewPager: ViewPager2?
get() {
var v: View? = parent as? View
while (v != null && !(v is ViewPager2 && (v as? ViewPager2)?.orientation == ORIENTATION_VERTICAL)) {
v = v.parent as? View
}
return v as? ViewPager2
}
private val child: View? get() = if (childCount > 0) getChildAt(0) else null
init {
touchSlop = ViewConfiguration.get(context).scaledTouchSlop
}
private fun canChildScroll(orientation: Int, delta: Float): Boolean {
val direction = -delta.sign.toInt()
return when (orientation) {
0 -> child?.canScrollHorizontally(direction) ?: false
1 -> child?.canScrollVertically(direction) ?: false
else -> throw IllegalArgumentException()
}
}
override fun onInterceptTouchEvent(e: MotionEvent): Boolean {
handleInterceptTouchEvent(e)
return super.onInterceptTouchEvent(e)
}
private fun handleInterceptTouchEvent(e: MotionEvent) {
val orientation = parentViewPager?.orientation ?: return
// Early return if child can't scroll in same direction as parent, except if child is also viewpager
if (child !is ViewPager2
&& !canChildScroll(orientation, -1f)
&& !canChildScroll(orientation, 1f)
) {
return
}
if (e.action == MotionEvent.ACTION_DOWN) {
initialX = e.x
initialY = e.y
parent.requestDisallowInterceptTouchEvent(true)
} else if (e.action == MotionEvent.ACTION_MOVE) {
val dx = e.x - initialX
val dy = e.y - initialY
val isVpHorizontal = orientation == ORIENTATION_HORIZONTAL
// assuming ViewPager2 touch-slop is 2x touch-slop of child
val scaledDx = dx.absoluteValue * if (isVpHorizontal) .5f else 1f
val scaledDy = dy.absoluteValue * if (isVpHorizontal) 1f else .5f
if (scaledDx > touchSlop || scaledDy > touchSlop) {
if (isVpHorizontal == (scaledDy > scaledDx)) {
if (child is ViewPager2) {
// In case child and parent are both ViewPagers - calculate on which angle,
// which widget will be swiped
val angle = getAngle(initialX, initialY, e.x, e.y)
// Right
if (inRange(angle, 0f, 55f) || inRange(angle, 305f, 360f)) {
parent.requestDisallowInterceptTouchEvent(true)
// Left
} else if (inRange(angle, 125f, 235f)) {
parent.requestDisallowInterceptTouchEvent(true)
} else {
parent.requestDisallowInterceptTouchEvent(false)
}
} else {
// Gesture is perpendicular, allow all parents to intercept
parent.requestDisallowInterceptTouchEvent(false)
}
} else {
// Gesture is parallel, query child if movement in that direction is possible
if (canChildScroll(orientation, if (isVpHorizontal) dx else dy)) {
// Child can scroll, disallow all parents to intercept
parent.requestDisallowInterceptTouchEvent(true)
} else {
// Child cannot scroll, allow all parents to intercept
parent.requestDisallowInterceptTouchEvent(false)
}
}
}
}
}
private fun getAngle(x1: Float, y1: Float, x2: Float, y2: Float): Double {
val rad = atan2((y1 - y2).toDouble(), (x2 - x1).toDouble()) + Math.PI
return (rad * 180 / Math.PI + 180) % 360
}
private fun inRange(angle: Double, init: Float, end: Float): Boolean {
return angle >= init && angle < end
}
}
[Deleted User] <[Deleted User]> #55
lu...@bertelsmann.de <lu...@bertelsmann.de> #57
The header can be dragged as expected while the list is scrolled fully to the top, however as soon as this is not the case dragging on the header does no longer work as expected, I can only drag the header a few pixels, if at all, and then it instantly dismisses the BottomSheetDialogFragment.
This is what my code looks like:
Box(
Modifier
.nestedScroll(rememberNestedScrollInteropConnection())
) {
Column({
Box(Modifier
.height(50.dp)
.fillMaxWidth()
.verticalScroll(rememberScrollState()),
contentAlignment = Alignment.Center
) {
// Header
}
Column(
Modifier
.fillMaxWidth()
.wrapContentHeight()
.verticalScroll(rememberScrollState()), content = content
)
}
}
Can someone maybe tell me what I am doing wrong, or how to fix this?
li...@gmail.com <li...@gmail.com> #58
Somehow ViewCompat.setNestedScrollingEnabled
doesn't work for me. The code below is oversimplified, but correctly represents the view heierachy, which I have.
HorizontalPager {
AndroidView({
FrameLayout()
.also { ViewCompat.setNestedScrollingEnabled(it, true) }
.also { frame ->
val recycler = RecyclerView()
ViewCompat.setNestedScrollingEnabled(recycler, true)
frame.addView(recycler)
}
}
})
}
The RecyclerView
simply does not scroll.
Description
when nested scrolling in compose is done, we need to consider supporting cases for view interop when compose is either a parent or a child.