Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 |
| OLD | NEW |