| // Copyright 2019 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Define all the base::Features used by ui/accessibility. |
| #ifndef UI_ACCESSIBILITY_ACCESSIBILITY_FEATURES_H_ |
| #define UI_ACCESSIBILITY_ACCESSIBILITY_FEATURES_H_ |
| |
| #include "base/feature_list.h" |
| #include "base/metrics/field_trial_params.h" |
| #include "build/build_config.h" |
| #include "build/chromeos_buildflags.h" |
| #include "ui/accessibility/ax_base_export.h" |
| |
| // This file declares base::Features related to the ui/accessibility code. |
| // |
| // If your flag is for all platforms, include it in the first section. If |
| // the flag is build-specific, include it in the appropriate section or |
| // add a new section if needed. |
| // |
| // Keep all sections ordered alphabetically. |
| // |
| // Include the base declaration, and a bool "is...Enabled()" getter for |
| // convenience and consistency. The bool method does not need a comment. Place a |
| // comment above the feature flag describing what the flag does when enabled. |
| // For example, a new entry should look like: |
| // |
| // // <<effect of the experiment>> |
| // AX_BASE_EXPORT BASE_DECLARE_FEATURE(kNewFeature); |
| // AX_BASE_EXPORT bool IsNewFeatureEnabled(); |
| // |
| // In the .cc file, a corresponding new entry should look like: |
| // |
| // BASE_FEATURE(kNewFeature, "NewFeature", |
| // base::FEATURE_DISABLED_BY_DEFAULT); bool IsNewFeatureEnabled() { |
| // return base::FeatureList::IsEnabled(::features::kNewFeature); |
| // } |
| // |
| // Your feature name should start with "kAccessibility". There is no need to |
| // include the words "enabled" or "experimental", as these are implied. We |
| // include accessibility to differentiate these features from others in |
| // Chromium. |
| |
| namespace features { |
| |
| // Enable PDF OCR for Select-to-Speak. It will be disabled by default on |
| // platforms other than ChromeOS as STS is available only on ChromeOS. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityPdfOcrForSelectToSpeak); |
| AX_BASE_EXPORT bool IsAccessibilityPdfOcrForSelectToSpeakEnabled(); |
| |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityPruneRedundantInlineText); |
| AX_BASE_EXPORT bool IsAccessibilityPruneRedundantInlineTextEnabled(); |
| |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE( |
| kAccessibilityPruneRedundantInlineConnectivity); |
| AX_BASE_EXPORT bool IsAccessibilityPruneRedundantInlineConnectivityEnabled(); |
| |
| // Use Alternative mechanism for acquiring image descriptions. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kImageDescriptionsAlternateRouting); |
| AX_BASE_EXPORT bool IsImageDescriptionsAlternateRoutingEnabled(); |
| |
| // Disable the accessibility engine after a certain |
| // number of user input events spanning a minimum amount of time with no |
| // accessibility API usage in that time. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAutoDisableAccessibility); |
| AX_BASE_EXPORT bool IsAutoDisableAccessibilityEnabled(); |
| |
| // Recognize "aria-virtualcontent" as a valid aria property. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kEnableAccessibilityAriaVirtualContent); |
| AX_BASE_EXPORT bool IsAccessibilityAriaVirtualContentEnabled(); |
| |
| // Use language detection to determine the language |
| // of text content in page and exposed to the browser process AXTree. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kEnableAccessibilityLanguageDetection); |
| AX_BASE_EXPORT bool IsAccessibilityLanguageDetectionEnabled(); |
| |
| // Restrict AXModes to web content related modes only when an IA2 |
| // query is performed on a web content node. |
| // TODO(crbug.com/40266474): Remove flag once the change has been confirmed |
| // safe. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kEnableAccessibilityRestrictiveIA2AXModes); |
| AX_BASE_EXPORT bool IsAccessibilityRestrictiveIA2AXModesEnabled(); |
| |
| // Serialize accessibility information from the Views tree and |
| // deserialize it into an AXTree in the browser process. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kEnableAccessibilityTreeForViews); |
| AX_BASE_EXPORT bool IsAccessibilityTreeForViewsEnabled(); |
| |
| // Support aria element reflection. For example: |
| // element.ariaActiveDescendantElement = child; |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kEnableAriaElementReflection); |
| AX_BASE_EXPORT bool IsAriaElementReflectionEnabled(); |
| |
| // Turn on browser vocalization of 'descriptions' tracks. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kTextBasedAudioDescription); |
| AX_BASE_EXPORT bool IsTextBasedAudioDescriptionEnabled(); |
| |
| // Expose document markers on inline text boxes in addition to |
| // static nodes. (Note: This will make it possible for AXPosition in the browser |
| // process to handle document markers, which will be platform agnositc) |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kUseAXPositionForDocumentMarkers); |
| AX_BASE_EXPORT bool IsUseAXPositionForDocumentMarkersEnabled(); |
| |
| // Performs a move over a copy of snapshot tree data in AXTreeCombiner. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kUseMoveNotCopyInAXTreeCombiner); |
| AX_BASE_EXPORT bool IsUseMoveNotCopyInAXTreeCombinerEnabled(); |
| |
| // Performs a move over a copy of merge tree update. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kUseMoveNotCopyInMergeTreeUpdate); |
| AX_BASE_EXPORT bool IsUseMoveNotCopyInMergeTreeUpdateEnabled(); |
| |
| #if BUILDFLAG(IS_WIN) |
| // Use Chrome-specific accessibility COM API. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kIChromeAccessible); |
| AX_BASE_EXPORT bool IsIChromeAccessibleEnabled(); |
| |
| // Selectively enable accessibility depending on the |
| // UIA APIs that are called. (Note: This will make it possible for |
| // non-screenreader services to enable less of the accessibility system) |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kSelectiveUIAEnablement); |
| AX_BASE_EXPORT bool IsSelectiveUIAEnablementEnabled(); |
| |
| // Use the browser's UIA provider when requested by |
| // an accessibility client. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kUiaProvider); |
| #endif // BUILDFLAG(IS_WIN) |
| |
| #if BUILDFLAG(IS_CHROMEOS_ASH) |
| // TODO(accessibility): Should this be moved to ash_features.cc? |
| AX_BASE_EXPORT bool IsDictationOfflineAvailable(); |
| |
| // Adds option to enable Accessibility accelerator. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityAccelerator); |
| AX_BASE_EXPORT bool IsAccessibilityAcceleratorEnabled(); |
| |
| // Adds option to limit the movement on the screen. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityReducedAnimations); |
| AX_BASE_EXPORT bool IsAccessibilityReducedAnimationsEnabled(); |
| |
| // Integrate with FaceGaze. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityFaceGaze); |
| AX_BASE_EXPORT bool IsAccessibilityFaceGazeEnabled(); |
| |
| // Adds reduced animations toggle to kiosk quick settings. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityReducedAnimationsInKiosk); |
| AX_BASE_EXPORT bool IsAccessibilityReducedAnimationsInKioskEnabled(); |
| |
| // Allow context checking with the accessibility Dictation |
| // feature. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE( |
| kExperimentalAccessibilityDictationContextChecking); |
| AX_BASE_EXPORT bool |
| IsExperimentalAccessibilityDictationContextCheckingEnabled(); |
| |
| // Download Google TTS High Quality voices. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE( |
| kExperimentalAccessibilityGoogleTtsHighQualityVoices); |
| AX_BASE_EXPORT bool |
| IsExperimentalAccessibilityGoogleTtsHighQualityVoicesEnabled(); |
| |
| // Whether the screen magnifier can follow the ChromeVox focus. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityMagnifierFollowsChromeVox); |
| AX_BASE_EXPORT bool IsAccessibilityMagnifierFollowsChromeVoxEnabled(); |
| |
| // Whether the screen magnifier can follow the Select to Speak focus. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityMagnifierFollowsSts); |
| AX_BASE_EXPORT bool IsAccessibilityMagnifierFollowsStsEnabled(); |
| |
| // Control mouse with keyboard. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityMouseKeys); |
| AX_BASE_EXPORT bool IsAccessibilityMouseKeysEnabled(); |
| |
| // Control blink rate of text cursor. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityCaretBlinkIntervalSetting); |
| AX_BASE_EXPORT bool IsAccessibilityCaretBlinkIntervalSettingEnabled(); |
| |
| // Control whether the overscroll setting is available. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityOverscrollSettingFeature); |
| AX_BASE_EXPORT bool IsAccessibilityOverscrollSettingFeatureEnabled(); |
| |
| // Controls whether the Select to Speak keyboard shortcut is enabled. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilitySelectToSpeakShortcut); |
| AX_BASE_EXPORT bool IsAccessibilitySelectToSpeakShortcutEnabled(); |
| |
| // Controls whether the shake cursor to locate feature is available. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityShakeToLocate); |
| AX_BASE_EXPORT bool IsAccessibilityShakeToLocateEnabled(); |
| |
| // Controls whether the turn on magnifier at accelerator dialog feature is |
| // available. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityMagnifyAcceleratorDialog); |
| AX_BASE_EXPORT bool IsAccessibilityMagnifyAcceleratorDialogEnabled(); |
| |
| // Controls whether the Select to Speak keyboard shortcut is enabled. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityDisableTrackpad); |
| AX_BASE_EXPORT bool IsAccessibilityDisableTrackpadEnabled(); |
| |
| // Controls whether the flash screen for notifications feature is available. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityFlashScreenFeature); |
| AX_BASE_EXPORT bool IsAccessibilityFlashScreenFeatureEnabled(); |
| |
| #endif // BUILDFLAG(IS_CHROMEOS_ASH) |
| |
| #if BUILDFLAG(IS_ANDROID) |
| // Disable max node and timeout limits on the |
| // AXTreeSnapshotter's Snapshot method, and track related histograms. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilitySnapshotStressTests); |
| AX_BASE_EXPORT bool IsAccessibilitySnapshotStressTestsEnabled(); |
| // Controls the maximum amount of nodes in a given snapshot. We set an |
| // arbitrarily high value as the default to simulate there being no max nodes |
| // limit. |
| AX_BASE_EXPORT const base::FeatureParam<int> |
| kAccessibilitySnapshotStressTestsMaxNodes{ |
| &kAccessibilitySnapshotStressTests, |
| "AccessibilitySnapshotStressTestsMaxNodes", 100000}; |
| #endif // BUILDFLAG(IS_ANDROID) |
| |
| #if !BUILDFLAG(IS_ANDROID) |
| // Use the experimental Accessibility Service. |
| // TODO(katydek): Provide a more descriptive name here. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityService); |
| AX_BASE_EXPORT bool IsAccessibilityServiceEnabled(); |
| |
| // Open Read Anything side panel when the browser is opened, and |
| // call distill after the navigation's load-complete event. (Note: The browser |
| // is only being opened to render one webpage, for the sake of generating |
| // training data for Screen2x data collection. The browser is intended to be |
| // closed by the user who launches Chrome once the first distill call finishes |
| // executing.) |
| // |
| // Note: This feature should be used along with 'ScreenAIDebugModeEnabled=true' |
| // and --no-sandbox. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kDataCollectionModeForScreen2x); |
| AX_BASE_EXPORT bool IsDataCollectionModeForScreen2xEnabled(); |
| |
| // Identify and annotate the main node of the AXTree where one was not already |
| // provided. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kMainNodeAnnotations); |
| AX_BASE_EXPORT bool IsMainNodeAnnotationsEnabled(); |
| |
| // Use OCR to make inaccessible (i.e. untagged) PDFs |
| // accessibility. (Note: Due to the size of the OCR component, this feature |
| // targets only desktop versions of Chrome for now.) |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kPdfOcr); |
| AX_BASE_EXPORT bool IsPdfOcrEnabled(); |
| |
| // Show the Read Aloud feature in Read Anything. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAnythingReadAloud); |
| AX_BASE_EXPORT bool IsReadAnythingReadAloudEnabled(); |
| |
| // Use automatic voice switching in the Read Aloud feature in Read Anything. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAloudAutoVoiceSwitching); |
| AX_BASE_EXPORT bool IsReadAloudAutoVoiceSwitchingEnabled(); |
| |
| // Use automatic voice switching in the Read Aloud feature in Read Anything. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAloudLanguagePackDownloading); |
| AX_BASE_EXPORT bool IsReadAloudLanguagePackDownloadingEnabled(); |
| |
| // Enable automatic word highlighting in Read Anything Read Aloud. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE( |
| kReadAnythingReadAloudAutomaticWordHighlighting); |
| AX_BASE_EXPORT bool IsReadAnythingReadAloudAutomaticWordHighlightingEnabled(); |
| |
| // Enable phrase highlighting in Read Anything Read Aloud. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAnythingReadAloudPhraseHighlighting); |
| AX_BASE_EXPORT bool IsReadAnythingReadAloudPhraseHighlightingEnabled(); |
| |
| // Use screen2x integration for Read Anything to distill web pages |
| // using an ML model. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAnythingWithScreen2x); |
| AX_BASE_EXPORT bool IsReadAnythingWithScreen2xEnabled(); |
| |
| // Enable rules based algorithm for distilling content. Should be enabled by |
| // default. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAnythingWithAlgorithm); |
| AX_BASE_EXPORT bool IsReadAnythingWithAlgorithmEnabled(); |
| |
| // Enable images to be distilled via algorithm. Should be disabled by |
| // default. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAnythingImagesViaAlgorithm); |
| AX_BASE_EXPORT bool IsReadAnythingImagesViaAlgorithmEnabled(); |
| |
| // Enable Reading Mode to work on Google Docs. Should be disabled by default. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kReadAnythingDocsIntegration); |
| AX_BASE_EXPORT bool IsReadAnythingDocsIntegrationEnabled(); |
| |
| // Write some ScreenAI library debug data in /tmp. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kScreenAIDebugMode); |
| AX_BASE_EXPORT bool IsScreenAIDebugModeEnabled(); |
| |
| // ScreenAI library's Main Content Extraction service is enabled. |
| AX_BASE_EXPORT bool IsScreenAIMainContentExtractionEnabled(); |
| |
| // ScreenAI library's OCR service is enabled. |
| AX_BASE_EXPORT bool IsScreenAIOCREnabled(); |
| |
| // Enables to use the Screen AI component available for testing. |
| // If enabled, ScreenAI library will be loaded from //third_party/screen-ai. |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kScreenAITestMode); |
| AX_BASE_EXPORT bool IsScreenAITestModeEnabled(); |
| |
| #endif // !BUILDFLAG(IS_ANDROID) |
| |
| #if BUILDFLAG(IS_MAC) |
| // Set NSAccessibilityRemoteUIElement's RemoteUIApp to YES to fix |
| // some accessibility bugs in PWA Mac. (Note: When enabling |
| // NSAccessibilityRemoteUIElement's RemoteUIApp previously, chromium would hang. |
| // See: https://crbug.com/1491329). |
| AX_BASE_EXPORT BASE_DECLARE_FEATURE(kAccessibilityRemoteUIApp); |
| AX_BASE_EXPORT bool IsAccessibilityRemoteUIAppEnabled(); |
| #endif // BUILDFLAG(IS_MAC) |
| |
| } // namespace features |
| |
| #endif // UI_ACCESSIBILITY_ACCESSIBILITY_FEATURES_H_ |