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

Unified Diff: chrome/browser/chromeos/accessibility/magnification_manager.cc

Issue 790413002: Focus following for the non-editable controls on web page in magnifier mode. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix a nit. Created 6 years 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/accessibility/magnification_manager.cc
diff --git a/chrome/browser/chromeos/accessibility/magnification_manager.cc b/chrome/browser/chromeos/accessibility/magnification_manager.cc
index e1231b9bab1a1c19d90460fa383b8d10b5acd4d9..347275c739c9df0d72de532d2830abb1bd4b92d0 100644
--- a/chrome/browser/chromeos/accessibility/magnification_manager.cc
+++ b/chrome/browser/chromeos/accessibility/magnification_manager.cc
@@ -27,6 +27,7 @@
#include "content/public/browser/notification_registrar.h"
#include "content/public/browser/notification_service.h"
#include "content/public/browser/notification_source.h"
+#include "content/public/browser/render_view_host.h"
namespace chromeos {
@@ -47,7 +48,8 @@ class MagnificationManagerImpl : public MagnificationManager,
magnifier_scale_pref_handler_(
prefs::kAccessibilityScreenMagnifierScale),
type_(ui::kDefaultMagnifierType),
- enabled_(false) {
+ enabled_(false),
+ monitor_focus_change_in_page_(false) {
registrar_.Add(this,
chrome::NOTIFICATION_LOGIN_OR_LOCK_WEBUI_VISIBLE,
content::NotificationService::AllSources());
@@ -155,6 +157,7 @@ class MagnificationManagerImpl : public MagnificationManager,
if (type_ == ui::MAGNIFIER_FULL) {
ash::Shell::GetInstance()->magnification_controller()->SetEnabled(
enabled_);
+ MonitorFocusInPageChange();
} else {
ash::Shell::GetInstance()->partial_magnification_controller()->SetEnabled(
enabled_);
@@ -213,6 +216,18 @@ class MagnificationManagerImpl : public MagnificationManager,
#endif
}
+ void MonitorFocusInPageChange() {
+ if (enabled_ && !monitor_focus_change_in_page_) {
+ registrar_.Add(this, content::NOTIFICATION_FOCUS_CHANGED_IN_PAGE,
+ content::NotificationService::AllSources());
+ monitor_focus_change_in_page_ = true;
+ } else if (!enabled_ && monitor_focus_change_in_page_) {
+ registrar_.Remove(this, content::NOTIFICATION_FOCUS_CHANGED_IN_PAGE,
+ content::NotificationService::AllSources());
+ monitor_focus_change_in_page_ = false;
+ }
sadrul 2014/12/12 17:13:49 Can you use a RenderViewObserver instead of using
jennyz 2014/12/12 23:14:45 Is there a strong reason you prefer using RenderVi
sadrul 2014/12/15 18:37:16 We should avoid using NotificationService when the
jennyz 2014/12/15 23:24:55 Talked to jam@, he is ok to use the existing notif
+ }
+
// content::NotificationObserver implementation:
virtual void Observe(int type,
const content::NotificationSource& source,
@@ -241,6 +256,15 @@ class MagnificationManagerImpl : public MagnificationManager,
SetProfile(NULL);
break;
}
+ case content::NOTIFICATION_FOCUS_CHANGED_IN_PAGE: {
+ content::FocusedNodeDetails* node_details =
+ content::Details<content::FocusedNodeDetails>(details).ptr();
+ ash::Shell::GetInstance()
+ ->magnification_controller()
+ ->HandleFocusedNodeChanged(node_details->is_editable_node,
+ node_details->node_bounds_in_screen);
+ break;
+ }
}
}
@@ -253,6 +277,7 @@ class MagnificationManagerImpl : public MagnificationManager,
ui::MagnifierType type_;
bool enabled_;
+ bool monitor_focus_change_in_page_;
oshima 2014/12/12 00:48:45 optional: observing_focus_change_in_page_ maybe be
jennyz 2014/12/12 23:14:45 Done.
content::NotificationRegistrar registrar_;
scoped_ptr<PrefChangeRegistrar> pref_change_registrar_;

Powered by Google App Engine
This is Rietveld 408576698