Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(47)

Side by Side Diff: chrome/browser/chromeos/arc/accessibility/arc_accessibility_helper_bridge.cc

Issue 2640123004: Initial support for native accessibility in ARC (Closed)
Patch Set: |window| can be nullptr Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/chromeos/arc/accessibility/arc_accessibility_helper_bri dge.h" 5 #include "chrome/browser/chromeos/arc/accessibility/arc_accessibility_helper_bri dge.h"
6 6
7 #include "base/command_line.h"
7 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h" 8 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h"
9 #include "chrome/browser/chromeos/arc/accessibility/ax_tree_source_arc.h"
10 #include "chromeos/chromeos_switches.h"
8 #include "components/arc/arc_bridge_service.h" 11 #include "components/arc/arc_bridge_service.h"
12 #include "components/exo/shell_surface.h"
13 #include "components/exo/surface.h"
9 #include "components/exo/wm_helper.h" 14 #include "components/exo/wm_helper.h"
10 #include "ui/aura/window.h" 15 #include "ui/aura/window.h"
11 #include "ui/gfx/geometry/rect.h" 16 #include "ui/gfx/geometry/rect.h"
17 #include "ui/views/view.h"
18 #include "ui/views/widget/widget.h"
19
20 namespace {
21
22 exo::Surface* GetArcSurface(const aura::Window* window) {
23 if (!window)
24 return nullptr;
25
26 exo::Surface* arc_surface = exo::Surface::AsSurface(window);
27 if (!arc_surface)
28 arc_surface = exo::ShellSurface::GetMainSurface(window);
29 return arc_surface;
30 }
31
32 } // namespace
12 33
13 namespace arc { 34 namespace arc {
14 35
15 ArcAccessibilityHelperBridge::ArcAccessibilityHelperBridge( 36 ArcAccessibilityHelperBridge::ArcAccessibilityHelperBridge(
16 ArcBridgeService* bridge_service) 37 ArcBridgeService* bridge_service)
17 : ArcService(bridge_service), binding_(this) { 38 : ArcService(bridge_service), binding_(this) {
18 arc_bridge_service()->accessibility_helper()->AddObserver(this); 39 arc_bridge_service()->accessibility_helper()->AddObserver(this);
19 } 40 }
20 41
21 ArcAccessibilityHelperBridge::~ArcAccessibilityHelperBridge() { 42 ArcAccessibilityHelperBridge::~ArcAccessibilityHelperBridge() {
22 arc_bridge_service()->accessibility_helper()->RemoveObserver(this); 43 arc_bridge_service()->accessibility_helper()->RemoveObserver(this);
23 } 44 }
24 45
25 void ArcAccessibilityHelperBridge::OnInstanceReady() { 46 void ArcAccessibilityHelperBridge::OnInstanceReady() {
26 auto* instance = ARC_GET_INSTANCE_FOR_METHOD( 47 auto* instance = ARC_GET_INSTANCE_FOR_METHOD(
27 arc_bridge_service()->accessibility_helper(), Init); 48 arc_bridge_service()->accessibility_helper(), Init);
28 DCHECK(instance); 49 DCHECK(instance);
29 instance->Init(binding_.CreateInterfacePtrAndBind()); 50 instance->Init(binding_.CreateInterfacePtrAndBind());
51
52 chromeos::AccessibilityManager* accessibility_manager =
53 chromeos::AccessibilityManager::Get();
54 if (base::CommandLine::ForCurrentProcess()->HasSwitch(
55 chromeos::switches::kEnableChromeVoxArcSupport)) {
56 instance->SetFilter(arc::mojom::AccessibilityFilterType::ALL);
57 if (!tree_) {
58 tree_.reset(new AXTreeSourceArc());
59 exo::WMHelper::GetInstance()->AddActivationObserver(this);
60 }
61 } else if (accessibility_manager &&
62 accessibility_manager->IsFocusHighlightEnabled()) {
63 instance->SetFilter(arc::mojom::AccessibilityFilterType::FOCUS);
64 }
30 } 65 }
31 66
32 void ArcAccessibilityHelperBridge::OnAccessibilityEvent( 67 void ArcAccessibilityHelperBridge::OnAccessibilityEvent(
33 mojom::AccessibilityEventType event_type, 68 mojom::AccessibilityEventDataPtr event_data) {
34 mojom::AccessibilityNodeInfoDataPtr event_source) { 69 if (tree_) {
35 if (event_type != mojom::AccessibilityEventType::VIEW_FOCUSED || 70 tree_->NotifyAccessibilityEvent(event_data.get());
36 event_source.is_null()) { 71 } else {
dmazzoni 2017/02/09 01:18:09 nit: maybe just return inside the first if block,
72 chromeos::AccessibilityManager* accessibility_manager =
73 chromeos::AccessibilityManager::Get();
74 if (!accessibility_manager)
75 return;
76
77 exo::WMHelper* wmHelper = exo::WMHelper::GetInstance();
78 aura::Window* focused_window = wmHelper->GetFocusedWindow();
79 if (!focused_window)
80 return;
81
82 aura::Window* toplevel_window = focused_window->GetToplevelWindow();
83
84 CHECK_EQ(1, event_data.get()->nodeData.size());
85 gfx::Rect bounds_in_screen = gfx::ScaleToEnclosingRect(
86 event_data.get()->nodeData[0]->boundsInScreen,
87 1.0f / toplevel_window->layer()->device_scale_factor());
88
89 accessibility_manager->OnViewFocusedInArc(bounds_in_screen);
90 }
91 }
92
93 void ArcAccessibilityHelperBridge::OnWindowActivated(
94 aura::Window* gained_active,
95 aura::Window* lost_active) {
96 if (gained_active == lost_active)
37 return; 97 return;
98
99 exo::Surface* active_surface = GetArcSurface(gained_active);
100 exo::Surface* inactive_surface = GetArcSurface(lost_active);
101 if (inactive_surface) {
102 views::Widget* widget = views::Widget::GetWidgetForNativeView(lost_active);
103 if (widget && widget->GetContentsView()) {
104 widget->GetContentsView()->RemoveChildView(tree_.get());
105 widget->GetContentsView()->NotifyAccessibilityEvent(
106 ui::AX_EVENT_CHILDREN_CHANGED, false);
107 }
38 } 108 }
39 109
40 chromeos::AccessibilityManager* accessibility_manager = 110 if (!active_surface)
41 chromeos::AccessibilityManager::Get();
42
43 if (!accessibility_manager ||
44 !accessibility_manager->IsFocusHighlightEnabled()) {
45 return;
46 }
47
48 exo::WMHelper* wmHelper = exo::WMHelper::GetInstance();
49
50 aura::Window* focused_window = wmHelper->GetFocusedWindow();
51 if (!focused_window)
52 return; 111 return;
53 112
54 aura::Window* toplevel_window = focused_window->GetToplevelWindow(); 113 tree_.reset(new AXTreeSourceArc());
55 114
56 gfx::Rect bounds_in_screen = gfx::ScaleToEnclosingRect( 115 views::Widget* widget = views::Widget::GetWidgetForNativeView(gained_active);
57 event_source.get()->boundsInScreen, 116 if (widget && widget->GetContentsView()) {
58 1.0f / toplevel_window->layer()->device_scale_factor()); 117 widget->GetContentsView()->AddChildView(tree_.get());
59 118 widget->GetContentsView()->NotifyAccessibilityEvent(
60 accessibility_manager->OnViewFocusedInArc(bounds_in_screen); 119 ui::AX_EVENT_CHILDREN_CHANGED, false);
120 tree_->RequestFocus();
121 }
61 } 122 }
62 123
63 } // namespace arc 124 } // namespace arc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698