OLD | NEW |
---|---|
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 "content/common/android/media_metadata_android.h" | 5 #include "content/common/android/media_metadata_android.h" |
6 | 6 |
7 #include "base/android/jni_array.h" | |
7 #include "base/android/jni_string.h" | 8 #include "base/android/jni_string.h" |
8 #include "content/public/common/media_metadata.h" | 9 #include "content/public/common/media_metadata.h" |
9 #include "jni/MediaMetadata_jni.h" | 10 #include "jni/MediaMetadata_jni.h" |
10 | 11 |
11 namespace content { | 12 namespace content { |
12 | 13 |
14 namespace { | |
15 std::vector<int> GetFlattenedSizeArray(const std::vector<gfx::Size>& sizes) { | |
mlamouri (slow - plz ping)
2016/06/23 12:52:28
style: empty lines around namespace {}
Zhiqiang Zhang (Slow)
2016/06/23 14:19:25
Done.
| |
16 std::vector<int> flattened_array; | |
17 flattened_array.reserve(2 * sizes.size()); | |
18 for (const auto& size : sizes) { | |
19 flattened_array.push_back(size.width()); | |
20 flattened_array.push_back(size.height()); | |
21 } | |
22 return flattened_array; | |
23 } | |
24 } | |
mlamouri (slow - plz ping)
2016/06/23 12:52:29
nit:
} // anonymous namespace
Zhiqiang Zhang (Slow)
2016/06/23 14:19:25
Done.
| |
25 | |
13 // static | 26 // static |
14 base::android::ScopedJavaLocalRef<jobject> | 27 base::android::ScopedJavaLocalRef<jobject> |
15 MediaMetadataAndroid::CreateJavaObject( | 28 MediaMetadataAndroid::CreateJavaObject( |
16 JNIEnv* env, const MediaMetadata& metadata) { | 29 JNIEnv* env, const MediaMetadata& metadata) { |
17 ScopedJavaLocalRef<jstring> j_title( | 30 ScopedJavaLocalRef<jstring> j_title( |
18 base::android::ConvertUTF16ToJavaString(env, metadata.title)); | 31 base::android::ConvertUTF16ToJavaString(env, metadata.title)); |
19 ScopedJavaLocalRef<jstring> j_artist( | 32 ScopedJavaLocalRef<jstring> j_artist( |
20 base::android::ConvertUTF16ToJavaString(env, metadata.artist)); | 33 base::android::ConvertUTF16ToJavaString(env, metadata.artist)); |
21 ScopedJavaLocalRef<jstring> j_album( | 34 ScopedJavaLocalRef<jstring> j_album( |
22 base::android::ConvertUTF16ToJavaString(env, metadata.album)); | 35 base::android::ConvertUTF16ToJavaString(env, metadata.album)); |
23 | 36 |
24 return Java_MediaMetadata_create( | 37 ScopedJavaLocalRef<jobject> j_metadata = Java_MediaMetadata_create( |
25 env, j_title.obj(), j_artist.obj(), j_album.obj()); | 38 env, j_title.obj(), j_artist.obj(), j_album.obj()); |
39 | |
40 for (const auto& artwork : metadata.artwork) { | |
41 std::string src = artwork.src.spec(); | |
42 base::string16 type = artwork.type.is_null() ? | |
43 base::string16() : artwork.type.string(); | |
44 ScopedJavaLocalRef<jstring> j_src( | |
45 base::android::ConvertUTF8ToJavaString(env, src)); | |
46 ScopedJavaLocalRef<jstring> j_type( | |
47 base::android::ConvertUTF16ToJavaString(env, type)); | |
48 ScopedJavaLocalRef<jintArray> j_sizes( | |
49 base::android::ToJavaIntArray( | |
50 env, GetFlattenedSizeArray(artwork.sizes))); | |
51 | |
52 ScopedJavaLocalRef<jobject> j_artwork = Java_MediaMetadata_createArtwork( | |
53 env, j_src.obj(), j_type.obj(), j_sizes.obj()); | |
54 | |
55 Java_MediaMetadata_addArtwork( | |
56 env, j_metadata.obj(), j_artwork.obj()); | |
mlamouri (slow - plz ping)
2016/06/23 12:52:28
It sounds like we could merge addArtwork and creat
Zhiqiang Zhang (Slow)
2016/06/23 14:19:25
Done.
| |
57 } | |
58 | |
59 return j_metadata; | |
26 } | 60 } |
27 | 61 |
28 // static | 62 // static |
29 bool MediaMetadataAndroid::Register(JNIEnv* env) { | 63 bool MediaMetadataAndroid::Register(JNIEnv* env) { |
30 return RegisterNativesImpl(env); | 64 return RegisterNativesImpl(env); |
31 } | 65 } |
32 | 66 |
33 } // namespace content | 67 } // namespace content |
OLD | NEW |