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

Unified Diff: chrome/browser/accessibility/font_size_prefs_android.cc

Issue 415343002: Upstream accessibility font size preferences. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: early return for removeObserver Created 6 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/accessibility/font_size_prefs_android.cc
diff --git a/chrome/browser/accessibility/font_size_prefs_android.cc b/chrome/browser/accessibility/font_size_prefs_android.cc
new file mode 100644
index 0000000000000000000000000000000000000000..cebf9fbcc1cd9d6ef0bc52406db1a0d106870860
--- /dev/null
+++ b/chrome/browser/accessibility/font_size_prefs_android.cc
@@ -0,0 +1,134 @@
+// Copyright (c) 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/accessibility/font_size_prefs_android.h"
+
+#include "base/observer_list.h"
+#include "base/prefs/pref_change_registrar.h"
+#include "base/prefs/pref_service.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/profiles/profile_android.h"
+#include "chrome/common/pref_names.h"
+#include "jni/FontSizePrefs_jni.h"
+
+FontSizePrefsAndroid::FontSizePrefsAndroid(JNIEnv* env,
+ jobject obj,
+ Profile* profile)
+ : pref_service_(profile->GetPrefs()) {
+ java_ref_.Reset(env, obj);
+ pref_change_registrar_.reset(new PrefChangeRegistrar);
+ pref_change_registrar_->Init(pref_service_);
+ pref_change_registrar_->Add(
+ prefs::kWebKitFontScaleFactor,
+ base::Bind(&FontSizePrefsAndroid::OnFontScaleFactorPrefsChanged,
+ base::Unretained(this)));
+ pref_change_registrar_->Add(
+ prefs::kWebKitForceEnableZoom,
+ base::Bind(&FontSizePrefsAndroid::OnForceEnableZoomPrefsChanged,
+ base::Unretained(this)));
+}
+
+FontSizePrefsAndroid::~FontSizePrefsAndroid() {}
+
+void FontSizePrefsAndroid::Destroy(JNIEnv* env, jobject obj) {
+ delete this;
+}
+
+void FontSizePrefsAndroid::SetFontScaleFactor(JNIEnv* env,
+ jobject obj,
+ jfloat font_size) {
+ pref_service_->SetDouble(prefs::kWebKitFontScaleFactor,
+ static_cast<double>(font_size));
+}
+
+float FontSizePrefsAndroid::GetFontScaleFactor(JNIEnv* env, jobject obj) {
+ return pref_service_->GetDouble(prefs::kWebKitFontScaleFactor);
+}
+
+void FontSizePrefsAndroid::SetForceEnableZoom(JNIEnv* env,
+ jobject obj,
+ jboolean enabled) {
+ pref_service_->SetBoolean(prefs::kWebKitForceEnableZoom, enabled);
+}
+
+bool FontSizePrefsAndroid::GetForceEnableZoom(JNIEnv* env, jobject obj) {
+ return pref_service_->GetBoolean(prefs::kWebKitForceEnableZoom);
+}
+
+bool FontSizePrefsAndroid::Register(JNIEnv* env) {
nyquist 2014/08/06 23:39:26 could you have this after add/remove observer?
sunangel 2014/08/07 18:50:53 Done.
+ return RegisterNativesImpl(env);
+}
+
+jlong Init(JNIEnv* env, jobject obj, jobject j_profile) {
+ FontSizePrefsAndroid* font_size_prefs_android = new FontSizePrefsAndroid(
+ env, obj, ProfileAndroid::FromProfileAndroid(j_profile));
+ return reinterpret_cast<intptr_t>(font_size_prefs_android);
+}
+
+void FontSizePrefsAndroid::AddObserver(JNIEnv* env,
+ jobject obj,
+ jlong observerPtr) {
+ FontSizePrefsObserverAndroid* font_size_prefs_observer_android =
+ reinterpret_cast<FontSizePrefsObserverAndroid*>(observerPtr);
+ observers_.AddObserver(font_size_prefs_observer_android);
+}
+
+void FontSizePrefsAndroid::RemoveObserver(JNIEnv* env,
+ jobject obj,
+ jlong observerPtr) {
nyquist 2014/08/06 23:39:26 nit: hackercase in C++, not camelCase throughout t
sunangel 2014/08/07 18:50:53 Done.
+ FontSizePrefsObserverAndroid* font_size_prefs_observer_android =
+ reinterpret_cast<FontSizePrefsObserverAndroid*>(observerPtr);
+ observers_.RemoveObserver(font_size_prefs_observer_android);
+}
+
+void FontSizePrefsAndroid::OnFontScaleFactorPrefsChanged() {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ FOR_EACH_OBSERVER(
+ Observer,
+ observers_,
+ OnChangeFontSize(GetFontScaleFactor(env, java_ref_.obj())));
+}
+
+void FontSizePrefsAndroid::OnForceEnableZoomPrefsChanged() {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ FOR_EACH_OBSERVER(
+ Observer,
+ observers_,
+ OnChangeForceEnableZoom(GetForceEnableZoom(env, java_ref_.obj())));
+}
+
+FontSizePrefsObserverAndroid::FontSizePrefsObserverAndroid(JNIEnv* env,
+ jobject obj) {
+ java_ref_.Reset(env, obj);
+}
+
+FontSizePrefsObserverAndroid::~FontSizePrefsObserverAndroid() {
+}
+
+bool FontSizePrefsObserverAndroid::Register(JNIEnv* env) {
+ return RegisterNativesImpl(env);
+}
+
+void FontSizePrefsObserverAndroid::DestroyObserverAndroid(JNIEnv* env,
+ jobject obj) {
+ delete this;
+}
+
+jlong InitObserverAndroid(JNIEnv* env, jobject obj) {
+ FontSizePrefsObserverAndroid* observer_wrapper =
+ new FontSizePrefsObserverAndroid(env, obj);
+ return reinterpret_cast<intptr_t>(observer_wrapper);
+}
+
+void FontSizePrefsObserverAndroid::OnChangeFontSize(float font_size) {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ Java_FontSizePrefsObserverWrapper_onChangeFontSize(
+ env, java_ref_.obj(), font_size);
+}
+
+void FontSizePrefsObserverAndroid::OnChangeForceEnableZoom(bool enabled) {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ Java_FontSizePrefsObserverWrapper_onChangeForceEnableZoom(
+ env, java_ref_.obj(), enabled);
+}

Powered by Google App Engine
This is Rietveld 408576698