Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/router/media_router_dialog_controller_and roid.h" | 5 #include "chrome/browser/media/android/router/media_router_dialog_controller_and roid.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/android/jni_string.h" | 8 #include "base/android/jni_string.h" |
| 9 #include "chrome/browser/media/android/router/media_router_android.h" | |
| 10 #include "chrome/browser/media/router/media_router.h" | |
| 11 #include "chrome/browser/media/router/media_router_factory.h" | |
| 9 #include "chrome/browser/media/router/media_source.h" | 12 #include "chrome/browser/media/router/media_source.h" |
| 13 #include "chrome/browser/sessions/session_tab_helper.h" | |
| 10 #include "content/public/browser/browser_thread.h" | 14 #include "content/public/browser/browser_thread.h" |
| 11 #include "content/public/browser/web_contents.h" | 15 #include "content/public/browser/web_contents.h" |
| 12 #include "content/public/browser/web_contents_delegate.h" | 16 #include "content/public/browser/web_contents_delegate.h" |
| 13 #include "jni/ChromeMediaRouterDialogController_jni.h" | 17 #include "jni/ChromeMediaRouterDialogController_jni.h" |
| 14 | 18 |
| 15 DEFINE_WEB_CONTENTS_USER_DATA_KEY( | 19 DEFINE_WEB_CONTENTS_USER_DATA_KEY( |
| 16 media_router::MediaRouterDialogControllerAndroid); | 20 media_router::MediaRouterDialogControllerAndroid); |
| 17 | 21 |
| 22 using base::android::ConvertJavaStringToUTF8; | |
| 18 using content::WebContents; | 23 using content::WebContents; |
| 19 | 24 |
| 20 namespace media_router { | 25 namespace media_router { |
| 21 | 26 |
| 22 // static | 27 // static |
| 23 MediaRouterDialogControllerAndroid* | 28 MediaRouterDialogControllerAndroid* |
| 24 MediaRouterDialogControllerAndroid::GetOrCreateForWebContents( | 29 MediaRouterDialogControllerAndroid::GetOrCreateForWebContents( |
| 25 WebContents* web_contents) { | 30 WebContents* web_contents) { |
| 26 DCHECK(web_contents); | 31 DCHECK(web_contents); |
| 27 // This call does nothing if the controller already exists. | 32 // This call does nothing if the controller already exists. |
| 28 MediaRouterDialogControllerAndroid::CreateForWebContents(web_contents); | 33 MediaRouterDialogControllerAndroid::CreateForWebContents(web_contents); |
| 29 return MediaRouterDialogControllerAndroid::FromWebContents(web_contents); | 34 return MediaRouterDialogControllerAndroid::FromWebContents(web_contents); |
| 30 } | 35 } |
| 31 | 36 |
| 37 void MediaRouterDialogControllerAndroid::OnSinkSelected( | |
| 38 JNIEnv* env, jobject obj, jstring jsink_id) { | |
| 39 scoped_ptr<CreatePresentationSessionRequest> | |
| 40 request(PassPresentationRequest()); | |
|
imcheng
2015/08/18 17:50:34
Can |request| be null here?
Is there a notion of
whywhat
2015/08/18 19:21:24
Nope, there's no notion of browser-initiated prese
| |
| 41 const std::string& source_id = request->media_source().id(); | |
| 42 const GURL& origin = request->frame_url().GetOrigin(); | |
| 43 | |
| 44 std::vector<MediaRouteResponseCallback> route_response_callbacks; | |
| 45 route_response_callbacks.push_back( | |
| 46 base::Bind(&CreatePresentationSessionRequest::HandleRouteResponse, | |
| 47 base::Passed(&request))); | |
| 48 | |
| 49 MediaRouter* router = static_cast<MediaRouterAndroid*>( | |
| 50 MediaRouterFactory::GetApiForBrowserContext( | |
| 51 initiator()->GetBrowserContext())); | |
| 52 DCHECK(router); | |
| 53 router->CreateRoute(source_id, | |
| 54 ConvertJavaStringToUTF8(env, jsink_id), | |
| 55 origin, | |
| 56 SessionTabHelper::IdForTab(initiator()), | |
| 57 route_response_callbacks); | |
| 58 } | |
| 59 | |
| 60 void MediaRouterDialogControllerAndroid::OnDialogDismissed( | |
| 61 JNIEnv* env, jobject obj) { | |
| 62 scoped_ptr<CreatePresentationSessionRequest> request( | |
| 63 PassPresentationRequest()); | |
| 64 | |
| 65 // If OnDialogDismissed is called after OnSinkSelected, do nothing. | |
| 66 if (!request) | |
| 67 return; | |
| 68 | |
| 69 request->MaybeInvokeErrorCallback(content::PresentationError( | |
| 70 content::PRESENTATION_ERROR_SESSION_REQUEST_CANCELLED, | |
| 71 "The device picker dialog has been dismissed")); | |
| 72 } | |
| 73 | |
| 32 MediaRouterDialogControllerAndroid::MediaRouterDialogControllerAndroid( | 74 MediaRouterDialogControllerAndroid::MediaRouterDialogControllerAndroid( |
| 33 WebContents* web_contents) | 75 WebContents* web_contents) |
| 34 : MediaRouterDialogController(web_contents) { | 76 : MediaRouterDialogController(web_contents) { |
| 35 JNIEnv* env = base::android::AttachCurrentThread(); | 77 JNIEnv* env = base::android::AttachCurrentThread(); |
| 36 java_dialog_controller_.Reset(Java_ChromeMediaRouterDialogController_create( | 78 java_dialog_controller_.Reset(Java_ChromeMediaRouterDialogController_create( |
| 37 env, | 79 env, |
| 38 reinterpret_cast<jlong>(this), | 80 reinterpret_cast<jlong>(this), |
| 39 base::android::GetApplicationContext())); | 81 base::android::GetApplicationContext())); |
| 40 } | 82 } |
| 41 | 83 |
| 42 // static | 84 // static |
| 43 bool MediaRouterDialogControllerAndroid::Register(JNIEnv* env) { | 85 bool MediaRouterDialogControllerAndroid::Register(JNIEnv* env) { |
| 44 bool ret = RegisterNativesImpl(env); | 86 bool ret = RegisterNativesImpl(env); |
| 45 // No native calls to register yet. | 87 DCHECK(g_ChromeMediaRouterDialogController_clazz); |
| 46 // DCHECK(g_ChromeMediaRouterDialogController_clazz); | |
| 47 return ret; | 88 return ret; |
| 48 } | 89 } |
| 49 | 90 |
| 50 MediaRouterDialogControllerAndroid::~MediaRouterDialogControllerAndroid() { | 91 MediaRouterDialogControllerAndroid::~MediaRouterDialogControllerAndroid() { |
| 51 } | 92 } |
| 52 | 93 |
| 53 void MediaRouterDialogControllerAndroid::CreateMediaRouterDialog() { | 94 void MediaRouterDialogControllerAndroid::CreateMediaRouterDialog() { |
| 54 JNIEnv* env = base::android::AttachCurrentThread(); | 95 JNIEnv* env = base::android::AttachCurrentThread(); |
| 55 | 96 |
| 56 scoped_ptr<CreatePresentationSessionRequest> presentation_request( | |
| 57 PassPresentationRequest()); | |
| 58 | |
| 59 ScopedJavaLocalRef<jstring> jsource_urn = | 97 ScopedJavaLocalRef<jstring> jsource_urn = |
| 60 base::android::ConvertUTF8ToJavaString( | 98 base::android::ConvertUTF8ToJavaString(env, GetMediaSourceId()); |
| 61 env, presentation_request->media_source().id()); | |
| 62 | 99 |
| 63 Java_ChromeMediaRouterDialogController_createDialog( | 100 Java_ChromeMediaRouterDialogController_createDialog( |
| 64 env, java_dialog_controller_.obj(), jsource_urn.obj()); | 101 env, java_dialog_controller_.obj(), jsource_urn.obj()); |
| 65 } | 102 } |
| 66 | 103 |
| 67 void MediaRouterDialogControllerAndroid::CloseMediaRouterDialog() { | 104 void MediaRouterDialogControllerAndroid::CloseMediaRouterDialog() { |
| 68 JNIEnv* env = base::android::AttachCurrentThread(); | 105 JNIEnv* env = base::android::AttachCurrentThread(); |
| 69 | 106 |
| 70 Java_ChromeMediaRouterDialogController_closeDialog( | 107 Java_ChromeMediaRouterDialogController_closeDialog( |
| 71 env, java_dialog_controller_.obj()); | 108 env, java_dialog_controller_.obj()); |
| 72 } | 109 } |
| 73 | 110 |
| 74 bool MediaRouterDialogControllerAndroid::IsShowingMediaRouterDialog() const { | 111 bool MediaRouterDialogControllerAndroid::IsShowingMediaRouterDialog() const { |
| 75 JNIEnv* env = base::android::AttachCurrentThread(); | 112 JNIEnv* env = base::android::AttachCurrentThread(); |
| 76 return Java_ChromeMediaRouterDialogController_isShowingDialog( | 113 return Java_ChromeMediaRouterDialogController_isShowingDialog( |
| 77 env, java_dialog_controller_.obj()); | 114 env, java_dialog_controller_.obj()); |
| 78 } | 115 } |
| 79 | 116 |
| 80 } // namespace media_router | 117 } // namespace media_router |
| 81 | 118 |
| OLD | NEW |