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

Side by Side Diff: chrome/browser/android/omnibox/answers_image_bridge.cc

Issue 312203005: [AiS] Java bridge for AnswersImageService (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@img-service
Patch Set: Created 6 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
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/android/omnibox/answers_image_bridge.h"
6
7 #include <jni.h>
8
9 #include "base/android/jni_android.h"
10 #include "base/android/jni_string.h"
11 #include "base/android/scoped_java_ref.h"
12 #include "base/bind.h"
13 #include "chrome/browser/autocomplete/answers_image_service.h"
14 #include "chrome/browser/autocomplete/answers_image_service_factory.h"
15 #include "chrome/browser/profiles/profile.h"
16 #include "chrome/browser/profiles/profile_android.h"
17 #include "jni/AnswersImage_jni.h"
18 #include "third_party/skia/include/core/SkBitmap.h"
19 #include "ui/gfx/android/java_bitmap.h"
20 #include "url/gurl.h"
21
22 using base::android::ScopedJavaLocalRef;
23 using base::android::ConvertUTF8ToJavaString;
24
25 namespace {
26
27 class AnswersImageObserverAndroid : public AnswersImageObserver {
28 public:
29 explicit AnswersImageObserverAndroid(jobject java_answers_image_observer)
30 : java_answers_image_observer_(java_answers_image_observer) {}
31
32 virtual ~AnswersImageObserverAndroid() {}
33
34 // AnswersImageObserver:
35 virtual void OnImageChanged(const SkBitmap& answers_image) OVERRIDE {
36 JNIEnv* env = base::android::AttachCurrentThread();
37 ScopedJavaLocalRef<jobject> java_bitmap =
38 gfx::ConvertToJavaBitmap(&answers_image);
39 Java_AnswersImageObserver_onAnswersImageChanged(
40 env, java_answers_image_observer_, java_bitmap.obj());
41 }
42
43 virtual void OnRequestFinished(int request_id) OVERRIDE { delete this; }
44
45 private:
46 jobject java_answers_image_observer_;
Ted C 2014/06/06 01:49:23 Instead of a raw jobject, can you store this as a
groby-ooo-7-16 2014/06/13 23:52:21 I _am_ morbidly interested. Thanks for the pointer
47 };
48
49 } // namespace
50
51 static void CancelAnswersImageRequest(JNIEnv* env,
52 jclass,
53 jobject java_profile,
54 jint java_request_id) {
55 Profile* profile = ProfileAndroid::FromProfileAndroid(java_profile);
56 if (profile) {
57 AnswersImageService* answers_image_service =
58 AnswersImageServiceFactory::GetForBrowserContext(profile);
59 answers_image_service->CancelRequest(java_request_id);
60 }
61 }
62
63 static jobject RequestAnswersImage(JNIEnv* env,
64 jclass,
65 jobject java_profile,
66 jstring java_url,
67 jobject java_callback) {
68 Profile* profile = ProfileAndroid::FromProfileAndroid(java_profile);
69 if (profile) {
Ted C 2014/06/06 01:49:24 I would just dcheck profile here. People shouldn'
groby-ooo-7-16 2014/06/13 23:52:21 Done.
70 AnswersImageService* answers_image_service =
71 AnswersImageServiceFactory::GetForBrowserContext(profile);
72 std::string url;
73 base::android::ConvertJavaStringToUTF8(env, java_url, &url);
74 int request_id = answers_image_service->RequestImage(
75 GURL(url), new AnswersImageObserverAndroid(java_callback));
76 return Java_AnswersImage_createAnswersImageRequest(
77 env, java_callback, request_id).Release();
Ted C 2014/06/06 01:49:23 indented too much
groby-ooo-7-16 2014/06/13 23:52:21 That's what 'git cl format' believes to be correct
Ted C 2014/06/17 20:38:15 Nothing about this indenting looks sane to me. If
groby-ooo-7-16 2014/06/17 23:46:20 It _is_ somewhat sane in that the style guide does
78 }
79 return NULL;
80 }
81
82 // static
83 bool RegisterAnswersImageBridge(JNIEnv* env) {
84 return RegisterNativesImpl(env);
85 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698