Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/android/shortcut_helper.h" | 5 #include "chrome/browser/android/shortcut_helper.h" |
| 6 | 6 |
| 7 #include <jni.h> | 7 #include <jni.h> |
| 8 | 8 |
| 9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
| 10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 36 : add_shortcut_pending_(false), | 36 : add_shortcut_pending_(false), |
| 37 data_fetcher_(new ShortcutDataFetcher(web_contents, this)) { | 37 data_fetcher_(new ShortcutDataFetcher(web_contents, this)) { |
| 38 java_ref_.Reset(env, obj); | 38 java_ref_.Reset(env, obj); |
| 39 } | 39 } |
| 40 | 40 |
| 41 ShortcutHelper::~ShortcutHelper() { | 41 ShortcutHelper::~ShortcutHelper() { |
| 42 data_fetcher_->set_weak_observer(nullptr); | 42 data_fetcher_->set_weak_observer(nullptr); |
| 43 data_fetcher_ = nullptr; | 43 data_fetcher_ = nullptr; |
| 44 } | 44 } |
| 45 | 45 |
| 46 void ShortcutHelper::OnTitleAvailable(const base::string16& title) { | 46 void ShortcutHelper::OnUserTitleAvailable(const base::string16& user_title) { |
| 47 JNIEnv* env = base::android::AttachCurrentThread(); | 47 JNIEnv* env = base::android::AttachCurrentThread(); |
| 48 ScopedJavaLocalRef<jstring> j_title = | 48 ScopedJavaLocalRef<jstring> j_user_title = |
| 49 base::android::ConvertUTF16ToJavaString(env, title); | 49 base::android::ConvertUTF16ToJavaString(env, user_title); |
| 50 Java_ShortcutHelper_onTitleAvailable(env, | 50 Java_ShortcutHelper_onUserTitleAvailable(env, |
| 51 java_ref_.obj(), | 51 java_ref_.obj(), |
| 52 j_title.obj()); | 52 j_user_title.obj()); |
| 53 } | 53 } |
| 54 | 54 |
| 55 void ShortcutHelper::OnDataAvailable(const ShortcutInfo& info, | 55 void ShortcutHelper::OnDataAvailable(const ShortcutInfo& info, |
| 56 const SkBitmap& icon) { | 56 const SkBitmap& icon) { |
| 57 JNIEnv* env = base::android::AttachCurrentThread(); | 57 JNIEnv* env = base::android::AttachCurrentThread(); |
| 58 ScopedJavaLocalRef<jobject> java_bitmap; | 58 ScopedJavaLocalRef<jobject> java_bitmap; |
| 59 if (icon.getSize()) | 59 if (icon.getSize()) |
| 60 java_bitmap = gfx::ConvertToJavaBitmap(&icon); | 60 java_bitmap = gfx::ConvertToJavaBitmap(&icon); |
| 61 | 61 |
| 62 Java_ShortcutHelper_onIconAvailable(env, | 62 Java_ShortcutHelper_onIconAvailable(env, |
| (...skipping 30 matching lines...) Expand all Loading... | |
| 93 base::android::ScopedJavaLocalRef<jobject> ref = | 93 base::android::ScopedJavaLocalRef<jobject> ref = |
| 94 Java_ShortcutHelper_finalizeLauncherIcon(env, | 94 Java_ShortcutHelper_finalizeLauncherIcon(env, |
| 95 java_url.obj(), | 95 java_url.obj(), |
| 96 java_bitmap.obj(), | 96 java_bitmap.obj(), |
| 97 dominant_red, | 97 dominant_red, |
| 98 dominant_green, | 98 dominant_green, |
| 99 dominant_blue); | 99 dominant_blue); |
| 100 return gfx::CreateSkBitmapFromJavaBitmap(gfx::JavaBitmap(ref.obj())); | 100 return gfx::CreateSkBitmapFromJavaBitmap(gfx::JavaBitmap(ref.obj())); |
| 101 } | 101 } |
| 102 | 102 |
| 103 void ShortcutHelper::AddShortcut(JNIEnv* env, jobject obj, jstring jtitle) { | 103 void ShortcutHelper::AddShortcut(JNIEnv* env, jobject obj, jstring jusertitle) { |
|
mlamouri (slow - plz ping)
2015/07/09 16:34:17
Hmm, "jtitle" was border line wrt coding style, ju
| |
| 104 add_shortcut_pending_ = true; | 104 add_shortcut_pending_ = true; |
| 105 | 105 |
| 106 base::string16 title = base::android::ConvertJavaStringToUTF16(env, jtitle); | 106 base::string16 user_title = |
| 107 if (!title.empty()) | 107 base::android::ConvertJavaStringToUTF16(env, jusertitle); |
| 108 data_fetcher_->shortcut_info().title = title; | 108 if (!user_title.empty()) |
| 109 data_fetcher_->shortcut_info().user_title = user_title; | |
| 109 | 110 |
| 110 if (data_fetcher_->is_ready()) { | 111 if (data_fetcher_->is_ready()) { |
| 111 // If the fetcher isn't ready yet, the shortcut will be added when it is | 112 // If the fetcher isn't ready yet, the shortcut will be added when it is |
| 112 // via OnDataAvailable(); | 113 // via OnDataAvailable(); |
| 113 AddShortcut(data_fetcher_->shortcut_info(), data_fetcher_->shortcut_icon()); | 114 AddShortcut(data_fetcher_->shortcut_info(), data_fetcher_->shortcut_icon()); |
| 114 } | 115 } |
| 115 } | 116 } |
| 116 | 117 |
| 117 void ShortcutHelper::AddShortcut(const ShortcutInfo& info, | 118 void ShortcutHelper::AddShortcut(const ShortcutInfo& info, |
| 118 const SkBitmap& icon) { | 119 const SkBitmap& icon) { |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 138 // static | 139 // static |
| 139 void ShortcutHelper::AddShortcutInBackgroundWithSkBitmap( | 140 void ShortcutHelper::AddShortcutInBackgroundWithSkBitmap( |
| 140 const ShortcutInfo& info, | 141 const ShortcutInfo& info, |
| 141 const SkBitmap& icon_bitmap) { | 142 const SkBitmap& icon_bitmap) { |
| 142 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); | 143 DCHECK_CURRENTLY_ON(content::BrowserThread::IO); |
| 143 | 144 |
| 144 // Send the data to the Java side to create the shortcut. | 145 // Send the data to the Java side to create the shortcut. |
| 145 JNIEnv* env = base::android::AttachCurrentThread(); | 146 JNIEnv* env = base::android::AttachCurrentThread(); |
| 146 ScopedJavaLocalRef<jstring> java_url = | 147 ScopedJavaLocalRef<jstring> java_url = |
| 147 base::android::ConvertUTF8ToJavaString(env, info.url.spec()); | 148 base::android::ConvertUTF8ToJavaString(env, info.url.spec()); |
| 148 ScopedJavaLocalRef<jstring> java_title = | 149 ScopedJavaLocalRef<jstring> java_user_title = |
| 149 base::android::ConvertUTF16ToJavaString(env, info.title); | 150 base::android::ConvertUTF16ToJavaString(env, info.user_title); |
| 151 ScopedJavaLocalRef<jstring> java_name = | |
| 152 base::android::ConvertUTF16ToJavaString(env, info.name); | |
| 153 ScopedJavaLocalRef<jstring> java_short_name = | |
| 154 base::android::ConvertUTF16ToJavaString(env, info.short_name); | |
| 150 ScopedJavaLocalRef<jobject> java_bitmap; | 155 ScopedJavaLocalRef<jobject> java_bitmap; |
| 151 if (icon_bitmap.getSize()) | 156 if (icon_bitmap.getSize()) |
| 152 java_bitmap = gfx::ConvertToJavaBitmap(&icon_bitmap); | 157 java_bitmap = gfx::ConvertToJavaBitmap(&icon_bitmap); |
| 153 | 158 |
| 154 Java_ShortcutHelper_addShortcut( | 159 Java_ShortcutHelper_addShortcut( |
| 155 env, | 160 env, |
| 156 base::android::GetApplicationContext(), | 161 base::android::GetApplicationContext(), |
| 157 java_url.obj(), | 162 java_url.obj(), |
| 158 java_title.obj(), | 163 java_user_title.obj(), |
| 164 java_name.obj(), | |
| 165 java_short_name.obj(), | |
| 159 java_bitmap.obj(), | 166 java_bitmap.obj(), |
| 160 info.display == content::Manifest::DISPLAY_MODE_STANDALONE, | 167 info.display == content::Manifest::DISPLAY_MODE_STANDALONE, |
| 161 info.orientation, | 168 info.orientation, |
| 162 info.source); | 169 info.source); |
| 163 } | 170 } |
| 164 | 171 |
| 165 void ShortcutHelper::RecordAddToHomescreen() { | 172 void ShortcutHelper::RecordAddToHomescreen() { |
| 166 // Record that the shortcut has been added, so no banners will be shown | 173 // Record that the shortcut has been added, so no banners will be shown |
| 167 // for this app. | 174 // for this app. |
| 168 content::WebContents* web_contents = data_fetcher_->web_contents(); | 175 content::WebContents* web_contents = data_fetcher_->web_contents(); |
| 169 if (!web_contents) | 176 if (!web_contents) |
| 170 return; | 177 return; |
| 171 | 178 |
| 172 AppBannerSettingsHelper::RecordBannerEvent( | 179 AppBannerSettingsHelper::RecordBannerEvent( |
| 173 web_contents, web_contents->GetURL(), | 180 web_contents, web_contents->GetURL(), |
| 174 data_fetcher_->shortcut_info().url.spec(), | 181 data_fetcher_->shortcut_info().url.spec(), |
| 175 AppBannerSettingsHelper::APP_BANNER_EVENT_DID_ADD_TO_HOMESCREEN, | 182 AppBannerSettingsHelper::APP_BANNER_EVENT_DID_ADD_TO_HOMESCREEN, |
| 176 base::Time::Now()); | 183 base::Time::Now()); |
| 177 } | 184 } |
| OLD | NEW |