13 KiB
Accessibility improvements in Windows Forms controls
Scope
Major
Version Introduced
4.7.1
Source Analyzer Status
NotPlanned
Change Description
Windows Forms is improving how it works with accessibility technologies to better support Windows Forms customers. These include the following changes:
-
Changes to improve display during High Contrast mode.
-
Changes to improve the property browser experience. Property browser improvements include:
- Better keyboard navigation through the various drop-down selection windows.
- Reduced unnecessary tab stops.
- Better reporting of control types.
- Improved narrator behavior.
-
Changes to implement missing UI accessibility patterns in controls.
-
Quirked
-
Build-time break
Recommended Action
How to opt in or out of these changes
In order for the application to benefit from these changes, it must run on the .NET Framework 4.7.1 or later. The application can benefit from these changes in either of the following ways:
-
It is recompiled to target the .NET Framework 4.7.1. These accessibility changes are enabled by default on Windows Forms applications that target the .NET Framework 4.7.1 or later.
-
It opts out of the legacy accessibility behaviors by adding the following AppContext switch to the
<runtime>
section of the app.config file and setting it tofalse
, as the following example shows.<?xml version="1.0" encoding="utf-8"?> <configuration> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.7"/> </startup> <runtime> <!-- AppContextSwitchOverrides value attribute is in the form of 'key1=true|false;key2=true|false --> <AppContextSwitchOverrides value="Switch.UseLegacyAccessibilityFeatures=false" /> </runtime> </configuration>
Applications that target the .NET Framework 4.7.1 or later and want to preserve the legacy accessibility behavior can opt in to the use of legacy accessibility features by explicitly setting this AppContext switch to true
.
For an overview of UI automation, see the UI Automation Overview.
Added support for UI Automation patterns and properties
Accessibility clients can take advantage of new WinForms accessibility functionality by using common, publicly described invocation patterns. These patterns are not WinForms-specific. For instance, accessibility clients can call the QueryInterface method on the IAccessible interface (MAAS) to obtain an IServiceProvider interface. If this interface is available, clients can use its QueryService method to request an IAccessibleEx interface. For more information, see Using IAccessibleEx from a Client. Starting with the .NET Framework 4.7.1, IServiceProvider and IAccessibleEx (where applicable) are available for WinForms accessibility objects.
The .NET Framework 4.7.1 adds support for the following UI automation patterns and properties:
- The
T:System.Windows.Forms.ToolStripSplitButton
andT:System.Windows.Forms.ComboBox
controls support the Expand/Collapse pattern. - The
T:System.Windows.Forms.ToolStripMenuItem
control has a ControlType property value xref:System.Windows.Automation.ControlType.MenuItem?displayProperty=nameWithType. - The
T:System.Windows.Forms.ToolStripItem
control supports the Name property and Expand/Collapse pattern. - The
T:System.Windows.Forms.ToolStripDropDownItem
control supports AccessibleEvents indicating StateChange and NameChange when drop down is expanded or collapsed. - The
T:System.Windows.Forms.ToolStripDropDownButton
control has a ControlType property value of xref:System.Windows.Automation.ControlType.MenuItem?displayProperty=nameWithType. - The
T:System.Windows.Forms.DataGridViewCheckBoxCell
control supports the Toggle Pattern. - The
T:System.Windows.Forms.NumericUpDown
andT:System.Windows.Forms.DomainUpDown
controls support the Name and have a ControlType of xref:System.Windows.Automation.ControlType.Spinner?displayProperty=nameWithType.
Improvements to the PropertyGrid control
The .NET Framework 4.7.1 adds the following improvements to the PropertyBrowser control:
- The Details button in the error dialog that is displayed when the user enters an incorrect value in the
T:System.Windows.Forms.PropertyGrid
control supports the Expand/Collapse pattern, state and name change notifications, and a ControlType property with a value of xref:System.Windows.Automation.ControlType.MenuItem?displayProperty=nameWithType. - The message pane displayed when the Details button of the error dialog is expanded is now keyboard accessible and allows Narrator to announce the content of the error message.
- The AccessibleRole of rows in
T:System.Windows.Forms.PropertyGrid
control have changed from "Row" to "Cell". The cell maps to UIA ControlType "DataItem", which allows it to support appropriate keyboard shortcuts and Narrator announcements. - The
T:System.Windows.Forms.PropertyGrid
control rows which represent header items when theT:System.Windows.Forms.PropertyGrid
control has aP:System.Windows.Forms.PropertySort
property set toF:System.Windows.Forms.PropertySory.Categorized
have a ControlType property value of xref:System.Windows.Automation.ControlType.Button?displayProperty=nameWithType - The
T:System.Windows.Forms.PropertyGrid
control rows which represent header items when theT:System.Windows.Forms.PropertyGrid
control has aP:System.Windows.Forms.PropertySort
property set toF:System.Windows.Forms.PropertySory.Categorized
support the Expand/Collapse pattern. - Improved keyboard navigation between the grid and the ToolBar above it. Pressing "Shift-Tab" now selects the first ToolBar button, instead of the whole ToolBar
T:System.Windows.Forms.PropertyGrid
controls displayed in High Contrast mode will now draw a focus rectangle around the ToolBar button which corresponds to the currentP:System.Windows.Forms.PropertySort
property value.T:System.Windows.Forms.PropertyGrid
controls displayed in High Contrast mode and with aP:System.Windows.Forms.PropertySort
property set toF:System.Windows.Forms.PropertySory.Categorized
will now display the background of category headers in a highly contrasting color.T:System.Windows.Forms.PropertyGrid
controls better differentiates between ToolBar items with focus and the ToolBar items which indicate the current value of theP:System.Windows.Forms.PropertySort
property. This fix consists of a High Contrast change and a change for non-High Contrast scenarios.T:System.Windows.Forms.PropertyGrid
control ToolBar items which indicates the current value of theP:System.Windows.Forms.PropertySort
property support the Toggle Pattern.- Improved Narrator support for distinguishing the selected alignment in the Alignment Picker.
- When an empty
T:System.Windows.Forms.PropertyGrid
control is displayed on a form, it will now receive focus where previously it would not.
Use of OS-defined colors in High Contrast themes
T:System.Windows.Forms.Button
andT:System.Windows.Forms.CheckBox
controls withP:System.Windows.Forms.Control.FlatStyle
set to xref:System.Windows.Forms.FlatStyle.System?displayProperty=nameWithType, which is the default style, now use OS-defined colors in High Contrast theme when selected. Previously, text and background colors were not contrasting and were hard to read.T:System.Windows.Forms.Button
,T:System.Windows.Forms.CheckBox
,T:System.Windows.Forms.RadioButton
,T:System.Windows.Forms.Label
,T:System.Windows.Forms.LinkLabel
andT:System.Windows.Forms.GroupBox
withP:System.Windows.Forms.Control.Enabled
set to false, used a shaded color to render text in High Contrast themes, resulting in low contrast against the background. Now these controls use "Disabled Text" color defined by the OS. This fix applies to controls withP:System.Windows.Forms.Control.FlatStyle
property set to a value other thanF:System.Windows.Forms.FlatStyle.System
. The latter controls are rendered by the OS.T:System.Windows.Forms.DataGridView
now renders a visible rectangle around the content of the cell which has the current focus. Previously, this was not visible in certain High Contrast themes.T:System.Windows.Forms.ToolStripMenuItem
controls with aP:System.Windows.Forms.ToolStripItem.Enabled
property set to false now use the "Disabled Text" color defined by the OS.T:System.Windows.Forms.ToolStripMenuItem
controls with aP:System.Windows.Forms.ToolStripItem.Checked
property set to true now render the associated check mark in a contrasting system color. Previously the check mark color was not contrasting enough and not visible in High Contrast themes.
NOTE: Windows10 has changed values for some high contrast system colors. Windows Forms Framework is based on the Win32 framework. For the best experience, run on the latest version of Windows and opt in to the latest OS changes by adding an app.manifest file in a test application and uncommenting the following code:
<!-- Windows 10 -->
<supportedOS Id="{8e0f7a12-bfb3-4fe8-b9a5-48fd50a15a9a}" />
Improved keyboard navigation
- When a
T:System.Windows.Forms.ComboBox
control hasP:System.Windows.Forms.ComboBox.DropDownStyle
set toF:System.Windows.Forms.DropDownStyle.DropDownList
and is the first control in the tab order on the form, it now displays a focus rectangle when the parent form is opened using the keyboard. Before this change, keyboard focus was on this control, but a focus indicator was not rendered.
Improved Narrator support
- The
T:System.Windows.Forms.MonthCalendar
control has added support for assistive technologies to access the control, including the ability for Narrator to read the value of the control when previously it could not. - The
T:System.Windows.Forms.CheckedListBox
control now notifies Narrator when theP:System.Windows.Forms.CheckState
property has been changed. Previously, Narrator did not recieve notification and as a result users would not be informed that theP:System.Windows.Forms.CheckState
had been updated. - The
T:System.Windows.Forms.LinkLabel
control has changed the way it notifies Narrator of the text of in the control. Previously, Narrator announced this text twice and read "&" symbols as real text even though they are not visible to a user. The duplicated text was removed from the Narrator announcements, as well as unnecessary "&" symbols. - The
T:System.Windows.Forms.DataGridViewCell
control types now correctly report the read-only status to Narrator and other assistive technologies. - Narrator is now able to read the System Menu of child windows in Multiple-Document Interface applications.
- Narrator is now able to read
T:System.Windows.Forms.ToolStripMenuItem
controls with aP:System.Windows.Forms.ToolStripItem.Enabled
property set to false. Previously, Narrator was unable to focus on disabled menu items to read hte content.
Affected APIs
M:System.Windows.Forms.ToolStripDropDownButton.CreateAccessibilityInstance
P:System.Windows.Forms.DomainUpDown.DomainUpDownAccessibleObject.Name
T:System.Windows.Forms.MonthCalendar.MonthCalendarAccessibleObject
Category
Windows Forms