| 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/media/android/remote/remote_media_player_bridge.h" | 5 #include "chrome/browser/media/android/remote/remote_media_player_bridge.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 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" |
| 11 #include "chrome/browser/media/android/remote/record_cast_action.h" | 11 #include "chrome/browser/media/android/remote/record_cast_action.h" |
| 12 #include "chrome/browser/media/android/remote/remote_media_player_manager.h" | 12 #include "chrome/browser/media/android/remote/remote_media_player_manager.h" |
| 13 #include "content/public/browser/android/content_view_core.h" | 13 #include "content/public/browser/android/content_view_core.h" |
| 14 #include "content/public/browser/browser_thread.h" | 14 #include "content/public/browser/browser_thread.h" |
| 15 #include "content/public/browser/web_contents.h" | 15 #include "content/public/browser/web_contents.h" |
| 16 #include "jni/RemoteMediaPlayerBridge_jni.h" | 16 #include "jni/RemoteMediaPlayerBridge_jni.h" |
| 17 #include "media/base/android/media_common_android.h" | 17 #include "media/base/android/media_common_android.h" |
| 18 #include "media/base/android/media_resource_getter.h" | 18 #include "media/base/android/media_resource_getter.h" |
| 19 #include "media/base/timestamp_constants.h" | 19 #include "media/base/timestamp_constants.h" |
| 20 #include "net/base/escape.h" |
| 20 #include "third_party/skia/include/core/SkBitmap.h" | 21 #include "third_party/skia/include/core/SkBitmap.h" |
| 21 #include "ui/gfx/android/java_bitmap.h" | 22 #include "ui/gfx/android/java_bitmap.h" |
| 22 | 23 |
| 23 using base::android::ConvertUTF8ToJavaString; | 24 using base::android::ConvertUTF8ToJavaString; |
| 24 using base::android::ConvertJavaStringToUTF8; | 25 using base::android::ConvertJavaStringToUTF8; |
| 25 using base::android::ScopedJavaLocalRef; | 26 using base::android::ScopedJavaLocalRef; |
| 26 using base::android::AttachCurrentThread; | 27 using base::android::AttachCurrentThread; |
| 27 using content::BrowserThread; | 28 using content::BrowserThread; |
| 28 using media::MediaPlayerAndroid; | 29 using media::MediaPlayerAndroid; |
| 29 | 30 |
| (...skipping 28 matching lines...) Expand all Loading... |
| 58 url_(manager->GetLocalPlayer(player_id)->GetUrl()), | 59 url_(manager->GetLocalPlayer(player_id)->GetUrl()), |
| 59 first_party_for_cookies_( | 60 first_party_for_cookies_( |
| 60 manager->GetLocalPlayer(player_id)->GetFirstPartyForCookies()), | 61 manager->GetLocalPlayer(player_id)->GetFirstPartyForCookies()), |
| 61 user_agent_(user_agent), | 62 user_agent_(user_agent), |
| 62 weak_factory_(this) { | 63 weak_factory_(this) { |
| 63 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 64 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 64 JNIEnv* env = base::android::AttachCurrentThread(); | 65 JNIEnv* env = base::android::AttachCurrentThread(); |
| 65 CHECK(env); | 66 CHECK(env); |
| 66 ScopedJavaLocalRef<jstring> j_url_string; | 67 ScopedJavaLocalRef<jstring> j_url_string; |
| 67 if (url_.is_valid()) { | 68 if (url_.is_valid()) { |
| 69 // Escape the URL to make it safe to use. Don't escape existing escape |
| 70 // sequences though. |
| 71 std::string escaped_url = net::EscapeExternalHandlerValue(url_.spec()); |
| 68 // Create a Java String for the URL. | 72 // Create a Java String for the URL. |
| 69 j_url_string = ConvertUTF8ToJavaString(env, url_.spec()); | 73 j_url_string = ConvertUTF8ToJavaString(env, escaped_url); |
| 70 } | 74 } |
| 71 ScopedJavaLocalRef<jstring> j_frame_url_string; | 75 ScopedJavaLocalRef<jstring> j_frame_url_string; |
| 72 GURL frameUrl = GetLocalPlayer()->frame_url(); | 76 GURL frameUrl = GetLocalPlayer()->frame_url(); |
| 73 if (frameUrl.is_valid()) { | 77 if (frameUrl.is_valid()) { |
| 74 // Create a Java String for the URL. | 78 // Create a Java String for the URL. |
| 75 j_frame_url_string = ConvertUTF8ToJavaString(env, frameUrl.spec()); | 79 j_frame_url_string = ConvertUTF8ToJavaString(env, frameUrl.spec()); |
| 76 } | 80 } |
| 77 java_bridge_.Reset(Java_RemoteMediaPlayerBridge_create( | 81 java_bridge_.Reset(Java_RemoteMediaPlayerBridge_create( |
| 78 env, reinterpret_cast<intptr_t>(this), j_url_string.obj(), | 82 env, reinterpret_cast<intptr_t>(this), j_url_string.obj(), |
| 79 j_frame_url_string.obj(), | 83 j_frame_url_string.obj(), |
| (...skipping 400 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 480 Java_RemoteMediaPlayerBridge_setCookies( | 484 Java_RemoteMediaPlayerBridge_setCookies( |
| 481 env, java_bridge_.obj(), ConvertUTF8ToJavaString(env, cookies).obj()); | 485 env, java_bridge_.obj(), ConvertUTF8ToJavaString(env, cookies).obj()); |
| 482 } | 486 } |
| 483 | 487 |
| 484 MediaPlayerAndroid* RemoteMediaPlayerBridge::GetLocalPlayer() { | 488 MediaPlayerAndroid* RemoteMediaPlayerBridge::GetLocalPlayer() { |
| 485 return static_cast<RemoteMediaPlayerManager*>(manager())->GetLocalPlayer( | 489 return static_cast<RemoteMediaPlayerManager*>(manager())->GetLocalPlayer( |
| 486 player_id()); | 490 player_id()); |
| 487 } | 491 } |
| 488 | 492 |
| 489 } // namespace remote_media | 493 } // namespace remote_media |
| OLD | NEW |