Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

UIA Formatted Text Navigation #3567

Open
carlos-zamora opened this issue Nov 13, 2019 · 8 comments
Open

UIA Formatted Text Navigation #3567

carlos-zamora opened this issue Nov 13, 2019 · 8 comments
Assignees
Labels
A11yMAS Accessibility tracking Area-Accessibility Issues related to accessibility Disability-All Accessibility tracking InclusionBacklog Accessibility tracking InclusionBacklog-Windows TerminalWin32 Accessibility tracking Issue-Feature Complex enough to require an in depth planning process and actual budgeted, scheduled work. Product-Conhost For issues in the Console codebase Product-Terminal The new Windows Terminal.
Milestone

Comments

@carlos-zamora
Copy link
Member

Description of the new feature/enhancement

Text Ranges can be explored via a number of ways:

  • Character
  • Format
  • Word
  • Line
  • Paragraph
  • Page
  • Document

We don't necessarily have to support all of them (refer to #3161 for us adding word navigation). But it would be interesting if we supported "format".

I envision us being able to jump between runs of formatted text. Today, the main formatting I can think of is colored text composed of foreground and background color. Maybe we could just see if any have changed and, if that's the case, that would be a breakpoint for formatted text navigation.

Proposed technical implementation details (optional)

Coincidentally, I just did a little bit of work in the AttrRowIterator. If that's actually taking a look at the text attributes, this would be an integral part of this design.

@carlos-zamora carlos-zamora added the Issue-Feature Complex enough to require an in depth planning process and actual budgeted, scheduled work. label Nov 13, 2019
@ghost ghost added Needs-Triage It's a new issue that the core contributor team needs to triage at the next triage meeting Needs-Tag-Fix Doesn't match tag requirements labels Nov 13, 2019
@carlos-zamora carlos-zamora added Area-Accessibility Issues related to accessibility Product-Conhost For issues in the Console codebase Product-Terminal The new Windows Terminal. and removed Needs-Tag-Fix Doesn't match tag requirements labels Nov 13, 2019
@carlos-zamora
Copy link
Member Author

More info from link:

TextUnit_Format is used to position the boundary of a text range based on the formatting attributes of the text. For example, if a text range is currently positioned on a single character of a word, specifying TextUnit_Format in a call to IUIAutomationTextRange::ExpandToEnclosingUnit expands the text range to include all text that shares all the same attributes as the single character. The resulting text range might or might not include the entire word. Also, using the format text unit will not expand a text range across the boundary of an embedded object such as an image or hyperlink.

Unlike the other text units, which include the text units that are smaller than themselves, TextUnit_Format can be smaller or larger than the other units. For example, if an entire document shares the same text attributes and contains no embedded objects, expanding a text range by TextUnit_Format would create a new range that encompasses the entire document, while expanding the text range by TextUnit_Word would create a smaller range.

@DHowett-MSFT DHowett-MSFT removed the Needs-Triage It's a new issue that the core contributor team needs to triage at the next triage meeting label Nov 14, 2019
@DHowett-MSFT DHowett-MSFT added this to the Terminal Backlog milestone Nov 14, 2019
@codeofdusk
Copy link
Contributor

Are there plans to close this in time for 21H1?

@DHowett-MSFT
Copy link
Contributor

This one isn't on our radar for 21H1; we need to figure out how this works in a world where text-mode applications can print complicated UIs and things that aren't basic formatted text. There's a spec floating around in the Terminal Working Group as to how to best handle sub-channel accessibility information (like alt text for textual screen elements), but I can't find it right now -- that might have to be part of a comprehensive solution here.

@codeofdusk
Copy link
Contributor

As an aside, does the console even expose colours to UIA? I'm not quite sure that it does.

@DHowett-MSFT
Copy link
Contributor

It doesn't currently.

@codeofdusk
Copy link
Contributor

Oh, I just found #2161. Thanks.

@codeofdusk
Copy link
Contributor

Are there any plans to add this? It seems much more straightforward after #10336.

@hwf1324
Copy link

hwf1324 commented Jan 2, 2025

Sorry, I'm not sure it's appropriate to discuss the following Issue here?

After making it possible for NVDA's mouse tracking to report the contents of the terminal via the means provided by @codeofdusk in nvaccess/nvda#17407 (comment), I found that when the text unit is a paragraph, the entire text in the terminal will be reported.

The result returned by ExpandToEnclosingUnit(UIA.TextUnit_Paragraph) seems to be wrong, or there is no support for this text unit making the result returned a larger text unit?

I'm sorry I don't have enough knowledge to investigate any further.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A11yMAS Accessibility tracking Area-Accessibility Issues related to accessibility Disability-All Accessibility tracking InclusionBacklog Accessibility tracking InclusionBacklog-Windows TerminalWin32 Accessibility tracking Issue-Feature Complex enough to require an in depth planning process and actual budgeted, scheduled work. Product-Conhost For issues in the Console codebase Product-Terminal The new Windows Terminal.
Projects
None yet
Development

No branches or pull requests

5 participants