RFR: 8341670: [Text, TextFlow] Public API for Text Layout Info [v25]
Michael Strauß
mstrauss at openjdk.org
Fri Apr 11 08:31:38 UTC 2025
On Mon, 7 Apr 2025 19:37:27 GMT, Andy Goryachev <angorya at openjdk.org> wrote:
>> Please refer to
>>
>> https://github.com/andy-goryachev-oracle/Test/blob/main/doc/Text/LayoutInfo.md
>>
>> The RichTextArea control ([JDK-8301121](https://bugs.openjdk.org/browse/JDK-8301121)), or any custom control that needs non-trivial navigation within complex or wrapped text needs a public API to get information about text layout.
>>
>> This change fixes the missing functionality by adding a new public method to the `Text` and `TextFlow` classes.:
>>
>>
>> /**
>> * Obtains the snapshot of the current text layout information.
>> * @return the layout information
>> * @since 25
>> */
>> public final LayoutInfo getLayoutInfo()
>>
>>
>> The `LayoutInfo` provides a view into the text layout within `Text`/`TextFlow` nodes such as:
>>
>> - caret information
>> - text lines: offsets and bounds
>> - overall layout bounds
>> - text selection geometry
>> - strike-through geometry
>> - underline geometry
>>
>>
>> This PR also adds the missing `strikeThroughShape()` method to complement the existing `underlineShape()` and `rangeShape()` for consistency sake:
>>
>>
>> /**
>> * Returns the shape for the strike-through in local coordinates.
>> *
>> * @param start the beginning character index for the range
>> * @param end the end character index (non-inclusive) for the range
>> * @return an array of {@code PathElement} which can be used to create a {@code Shape}
>> * @since 25
>> */
>> public final PathElement[] strikeThroughShape(int start, int end)
>>
>>
>>
>>
>> ## WARNING
>>
>> Presently, information obtained via certain Text/TextField methods is incorrect with non-zero padding and borders, see [JDK-8341438](https://bugs.openjdk.org/browse/JDK-8341438).
>>
>> This PR provides correct answers in the new API, leaving the behavior of the existing methods unchanged (there is a compatibility risk associated with trying to fix [JDK-8341438](https://bugs.openjdk.org/browse/JDK-8341438) ).
>>
>>
>>
>> ## Testing
>>
>> The new APIs can be visually tested using the Monkey Tester on this branch:
>> https://github.com/andy-goryachev-oracle/MonkeyTest/tree/text.layout.api
>>
>> in the Text and TextFlow pages:
>> 
>>
>> Two very basic headful tests have been added.
>>
>>
>> ## See Also
>>
>> https://github.com/FXMisc/RichTextFX/pull/1246
>
> Andy Goryachev has updated the pull request incrementally with one additional commit since the last revision:
>
> sealed
Looks good. I've left one minor comment.
modules/javafx.graphics/src/main/java/javafx/scene/text/TextLineInfo.java line 36:
> 34: * @param bounds the bounds of the text line, in local coordinates:
> 35: * <ul>
> 36: * <li>
We usually indent with 4 spaces.
-------------
Marked as reviewed by mstrauss (Reviewer).
PR Review: https://git.openjdk.org/jfx/pull/1596#pullrequestreview-2759559341
PR Review Comment: https://git.openjdk.org/jfx/pull/1596#discussion_r2039065579
More information about the openjfx-dev
mailing list