OLD | NEW |
---|---|
(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 } | |
OLD | NEW |