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

Side by Side Diff: chrome/browser/chromeos/accessibility/chromevox_panel.cc

Issue 1841393002: Hide ChromeVox Panel in full-screen mode. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@shelf_on_login
Patch Set: Created 4 years, 8 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
« no previous file with comments | « chrome/browser/chromeos/accessibility/chromevox_panel.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "ash/root_window_controller.h"
5 #include "ash/shelf/shelf.h" 6 #include "ash/shelf/shelf.h"
6 #include "ash/shelf/shelf_layout_manager.h" 7 #include "ash/shelf/shelf_layout_manager.h"
7 #include "ash/shell.h" 8 #include "ash/shell.h"
8 #include "ash/shell_window_ids.h" 9 #include "ash/shell_window_ids.h"
10 #include "ash/wm/window_state.h"
9 #include "base/macros.h" 11 #include "base/macros.h"
10 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h" 12 #include "chrome/browser/chromeos/accessibility/accessibility_manager.h"
11 #include "chrome/browser/chromeos/accessibility/chromevox_panel.h" 13 #include "chrome/browser/chromeos/accessibility/chromevox_panel.h"
12 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h" 14 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h"
13 #include "chrome/common/extensions/extension_constants.h" 15 #include "chrome/common/extensions/extension_constants.h"
14 #include "content/public/browser/web_contents.h" 16 #include "content/public/browser/web_contents.h"
15 #include "extensions/browser/view_type_utils.h" 17 #include "extensions/browser/view_type_utils.h"
16 #include "ui/chromeos/accessibility_types.h" 18 #include "ui/chromeos/accessibility_types.h"
17 #include "ui/views/controls/webview/webview.h" 19 #include "ui/views/controls/webview/webview.h"
18 #include "ui/views/layout/fill_layout.h" 20 #include "ui/views/layout/fill_layout.h"
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
57 panel_->ExitFullscreen(); 59 panel_->ExitFullscreen();
58 } 60 }
59 61
60 private: 62 private:
61 ChromeVoxPanel* panel_; 63 ChromeVoxPanel* panel_;
62 64
63 DISALLOW_COPY_AND_ASSIGN(ChromeVoxPanelWebContentsObserver); 65 DISALLOW_COPY_AND_ASSIGN(ChromeVoxPanelWebContentsObserver);
64 }; 66 };
65 67
66 ChromeVoxPanel::ChromeVoxPanel(content::BrowserContext* browser_context) 68 ChromeVoxPanel::ChromeVoxPanel(content::BrowserContext* browser_context)
67 : widget_(nullptr), web_view_(nullptr), fullscreen_(false) { 69 : widget_(nullptr), web_view_(nullptr), panel_fullscreen_(false) {
68 std::string url("chrome-extension://"); 70 std::string url("chrome-extension://");
69 url += extension_misc::kChromeVoxExtensionId; 71 url += extension_misc::kChromeVoxExtensionId;
70 url += kChromeVoxPanelRelativeUrl; 72 url += kChromeVoxPanelRelativeUrl;
71 73
72 views::WebView* web_view = new views::WebView(browser_context); 74 views::WebView* web_view = new views::WebView(browser_context);
73 content::WebContents* contents = web_view->GetWebContents(); 75 content::WebContents* contents = web_view->GetWebContents();
74 web_contents_observer_.reset( 76 web_contents_observer_.reset(
75 new ChromeVoxPanelWebContentsObserver(contents, this)); 77 new ChromeVoxPanelWebContentsObserver(contents, this));
76 extensions::SetViewType(contents, extensions::VIEW_TYPE_COMPONENT); 78 extensions::SetViewType(contents, extensions::VIEW_TYPE_COMPONENT);
77 extensions::ChromeExtensionWebContentsObserver::CreateForWebContents( 79 extensions::ChromeExtensionWebContentsObserver::CreateForWebContents(
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
117 if (!shelf) 119 if (!shelf)
118 return; 120 return;
119 121
120 ash::ShelfLayoutManager* shelf_layout_manager = shelf->shelf_layout_manager(); 122 ash::ShelfLayoutManager* shelf_layout_manager = shelf->shelf_layout_manager();
121 if (shelf_layout_manager) 123 if (shelf_layout_manager)
122 shelf_layout_manager->SetChromeVoxPanelHeight(kPanelHeight); 124 shelf_layout_manager->SetChromeVoxPanelHeight(kPanelHeight);
123 } 125 }
124 126
125 void ChromeVoxPanel::EnterFullscreen() { 127 void ChromeVoxPanel::EnterFullscreen() {
126 Focus(); 128 Focus();
127 fullscreen_ = true; 129 panel_fullscreen_ = true;
128 UpdateWidgetBounds(); 130 UpdateWidgetBounds();
129 } 131 }
130 132
131 void ChromeVoxPanel::ExitFullscreen() { 133 void ChromeVoxPanel::ExitFullscreen() {
134 widget_->Deactivate();
132 widget_->widget_delegate()->set_can_activate(false); 135 widget_->widget_delegate()->set_can_activate(false);
133 fullscreen_ = false; 136 panel_fullscreen_ = false;
134 UpdateWidgetBounds(); 137 UpdateWidgetBounds();
135 } 138 }
136 139
137 void ChromeVoxPanel::DisableSpokenFeedback() { 140 void ChromeVoxPanel::DisableSpokenFeedback() {
138 chromeos::AccessibilityManager::Get()->EnableSpokenFeedback( 141 chromeos::AccessibilityManager::Get()->EnableSpokenFeedback(
139 false, ui::A11Y_NOTIFICATION_NONE); 142 false, ui::A11Y_NOTIFICATION_NONE);
140 } 143 }
141 144
142 void ChromeVoxPanel::Focus() { 145 void ChromeVoxPanel::Focus() {
143 widget_->widget_delegate()->set_can_activate(true); 146 widget_->widget_delegate()->set_can_activate(true);
(...skipping 17 matching lines...) Expand all
161 return web_view_; 164 return web_view_;
162 } 165 }
163 166
164 void ChromeVoxPanel::OnDisplayMetricsChanged(const gfx::Display& display, 167 void ChromeVoxPanel::OnDisplayMetricsChanged(const gfx::Display& display,
165 uint32_t changed_metrics) { 168 uint32_t changed_metrics) {
166 UpdateWidgetBounds(); 169 UpdateWidgetBounds();
167 } 170 }
168 171
169 void ChromeVoxPanel::UpdateWidgetBounds() { 172 void ChromeVoxPanel::UpdateWidgetBounds() {
170 gfx::Rect bounds(GetRootWindow()->bounds().size()); 173 gfx::Rect bounds(GetRootWindow()->bounds().size());
171 if (!fullscreen_) 174 if (!panel_fullscreen_)
172 bounds.set_height(kPanelHeight); 175 bounds.set_height(kPanelHeight);
176
177 // If we're in full-screen mode, give the panel a height of 0 unless
178 // it's active.
179 const aura::Window* fullscreen_window =
180 ash::GetRootWindowController(GetRootWindow())
181 ->GetWindowForFullscreenMode();
182 if (fullscreen_window &&
183 ash::wm::GetWindowState(fullscreen_window)->IsFullscreen() &&
xiyuan 2016/03/30 16:08:02 nit: Is checking IsFullscreen() necessary? |fullsc
dmazzoni 2016/03/31 15:25:56 Ah, thanks. I misinterpreted and thought it return
184 !widget_->IsActive()) {
185 bounds.set_height(0);
186 }
187
173 widget_->SetBounds(bounds); 188 widget_->SetBounds(bounds);
174 } 189 }
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/accessibility/chromevox_panel.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698