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

Side by Side Diff: chrome/browser/android/webapk/webapk_update_manager.cc

Issue 2921623004: Support badge icon in WebAPK update components (Closed)
Patch Set: rebase Created 3 years, 6 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/android/webapk/webapk_update_data_fetcher.cc ('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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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/webapk/webapk_update_manager.h" 5 #include "chrome/browser/android/webapk/webapk_update_manager.h"
6 6
7 #include <jni.h> 7 #include <jni.h>
8 8
9 #include "base/android/jni_array.h" 9 #include "base/android/jni_array.h"
10 #include "base/android/jni_string.h" 10 #include "base/android/jni_string.h"
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
42 42
43 // static JNI method. 43 // static JNI method.
44 static void UpdateAsync( 44 static void UpdateAsync(
45 JNIEnv* env, 45 JNIEnv* env,
46 const JavaParamRef<jclass>& clazz, 46 const JavaParamRef<jclass>& clazz,
47 const JavaParamRef<jstring>& java_id, 47 const JavaParamRef<jstring>& java_id,
48 const JavaParamRef<jstring>& java_start_url, 48 const JavaParamRef<jstring>& java_start_url,
49 const JavaParamRef<jstring>& java_scope, 49 const JavaParamRef<jstring>& java_scope,
50 const JavaParamRef<jstring>& java_name, 50 const JavaParamRef<jstring>& java_name,
51 const JavaParamRef<jstring>& java_short_name, 51 const JavaParamRef<jstring>& java_short_name,
52 const JavaParamRef<jstring>& java_best_primary_icon_url, 52 const JavaParamRef<jstring>& java_primary_icon_url,
53 const JavaParamRef<jobject>& java_best_primary_icon_bitmap, 53 const JavaParamRef<jobject>& java_primary_icon_bitmap,
54 const JavaParamRef<jstring>& java_badge_icon_url,
55 const JavaParamRef<jobject>& java_badge_icon_bitmap,
54 const JavaParamRef<jobjectArray>& java_icon_urls, 56 const JavaParamRef<jobjectArray>& java_icon_urls,
55 const JavaParamRef<jobjectArray>& java_icon_hashes, 57 const JavaParamRef<jobjectArray>& java_icon_hashes,
56 jint java_display_mode, 58 jint java_display_mode,
57 jint java_orientation, 59 jint java_orientation,
58 jlong java_theme_color, 60 jlong java_theme_color,
59 jlong java_background_color, 61 jlong java_background_color,
60 const JavaParamRef<jstring>& java_web_manifest_url, 62 const JavaParamRef<jstring>& java_web_manifest_url,
61 const JavaParamRef<jstring>& java_webapk_package, 63 const JavaParamRef<jstring>& java_webapk_package,
62 jint java_webapk_version, 64 jint java_webapk_version,
63 jboolean java_is_manifest_stale) { 65 jboolean java_is_manifest_stale) {
64 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 66 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
65 67
66 Profile* profile = ProfileManager::GetLastUsedProfile(); 68 Profile* profile = ProfileManager::GetLastUsedProfile();
67 if (profile == nullptr) { 69 if (profile == nullptr) {
68 NOTREACHED() << "Profile not found."; 70 NOTREACHED() << "Profile not found.";
69 return; 71 return;
70 } 72 }
71 73
72 std::string id(ConvertJavaStringToUTF8(env, java_id)); 74 std::string id(ConvertJavaStringToUTF8(env, java_id));
73 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); 75 ShortcutInfo info(GURL(ConvertJavaStringToUTF8(env, java_start_url)));
74 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); 76 info.scope = GURL(ConvertJavaStringToUTF8(env, java_scope));
75 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url));
76 GURL best_primary_icon_url(
77 ConvertJavaStringToUTF8(env, java_best_primary_icon_url));
78 ShortcutInfo info(start_url);
79 info.scope = scope;
80 info.name = ConvertJavaStringToUTF16(env, java_name); 77 info.name = ConvertJavaStringToUTF16(env, java_name);
81 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); 78 info.short_name = ConvertJavaStringToUTF16(env, java_short_name);
82 info.user_title = info.short_name; 79 info.user_title = info.short_name;
83 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); 80 info.display = static_cast<blink::WebDisplayMode>(java_display_mode);
84 info.orientation = 81 info.orientation =
85 static_cast<blink::WebScreenOrientationLockType>(java_orientation); 82 static_cast<blink::WebScreenOrientationLockType>(java_orientation);
86 info.theme_color = (int64_t)java_theme_color; 83 info.theme_color = (int64_t)java_theme_color;
87 info.background_color = (int64_t)java_background_color; 84 info.background_color = (int64_t)java_background_color;
88 info.best_primary_icon_url = best_primary_icon_url; 85 info.best_primary_icon_url =
89 info.manifest_url = web_manifest_url; 86 GURL(ConvertJavaStringToUTF8(env, java_primary_icon_url));
87 info.best_badge_icon_url =
88 GURL(ConvertJavaStringToUTF8(env, java_badge_icon_url));
89 info.manifest_url = GURL(ConvertJavaStringToUTF8(env, java_web_manifest_url));
90 90
91 base::android::AppendJavaStringArrayToStringVector(env, java_icon_urls.obj(), 91 base::android::AppendJavaStringArrayToStringVector(env, java_icon_urls.obj(),
92 &info.icon_urls); 92 &info.icon_urls);
93 93
94 std::vector<std::string> icon_hashes; 94 std::vector<std::string> icon_hashes;
95 base::android::AppendJavaStringArrayToStringVector( 95 base::android::AppendJavaStringArrayToStringVector(
96 env, java_icon_hashes.obj(), &icon_hashes); 96 env, java_icon_hashes.obj(), &icon_hashes);
97 97
98 std::map<std::string, std::string> icon_url_to_murmur2_hash; 98 std::map<std::string, std::string> icon_url_to_murmur2_hash;
99 for (size_t i = 0; i < info.icon_urls.size(); ++i) 99 for (size_t i = 0; i < info.icon_urls.size(); ++i)
100 icon_url_to_murmur2_hash[info.icon_urls[i]] = icon_hashes[i]; 100 icon_url_to_murmur2_hash[info.icon_urls[i]] = icon_hashes[i];
101 101
102 gfx::JavaBitmap java_bitmap_lock(java_best_primary_icon_bitmap); 102 gfx::JavaBitmap java_primary_icon_bitmap_lock(java_primary_icon_bitmap);
103 SkBitmap best_primary_icon_bitmap = 103 SkBitmap primary_icon =
104 gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); 104 gfx::CreateSkBitmapFromJavaBitmap(java_primary_icon_bitmap_lock);
105 best_primary_icon_bitmap.setImmutable(); 105 primary_icon.setImmutable();
106
107 gfx::JavaBitmap java_badge_icon_bitmap_lock(java_badge_icon_bitmap);
108 SkBitmap badge_icon =
109 gfx::CreateSkBitmapFromJavaBitmap(java_badge_icon_bitmap_lock);
110 badge_icon.setImmutable();
106 111
107 std::string webapk_package; 112 std::string webapk_package;
108 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); 113 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package);
109 114
110 WebApkInstallService* install_service = WebApkInstallService::Get(profile); 115 WebApkInstallService* install_service = WebApkInstallService::Get(profile);
111 if (install_service->IsInstallInProgress(info.manifest_url)) { 116 if (install_service->IsInstallInProgress(info.manifest_url)) {
112 base::ThreadTaskRunnerHandle::Get()->PostTask( 117 base::ThreadTaskRunnerHandle::Get()->PostTask(
113 FROM_HERE, 118 FROM_HERE,
114 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id, 119 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id,
115 WebApkInstallResult::FAILURE, false /* relax_updates */, 120 WebApkInstallResult::FAILURE, false /* relax_updates */,
116 "" /* webapk_package */)); 121 "" /* webapk_package */));
117 return; 122 return;
118 } 123 }
119 install_service->UpdateAsync( 124 install_service->UpdateAsync(
120 info, best_primary_icon_bitmap, webapk_package, java_webapk_version, 125 info, primary_icon, badge_icon, webapk_package, java_webapk_version,
121 icon_url_to_murmur2_hash, java_is_manifest_stale, 126 icon_url_to_murmur2_hash, java_is_manifest_stale,
122 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id)); 127 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id));
123 } 128 }
OLDNEW
« no previous file with comments | « chrome/browser/android/webapk/webapk_update_data_fetcher.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698