Chromium Code Reviews| Index: content/browser/media/android/browser_surface_view_manager.cc |
| diff --git a/content/browser/media/android/browser_surface_view_manager.cc b/content/browser/media/android/browser_surface_view_manager.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..e6457ad610dcd8685f5856572a03899b4d2b1ffc |
| --- /dev/null |
| +++ b/content/browser/media/android/browser_surface_view_manager.cc |
| @@ -0,0 +1,58 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "content/browser/media/android/browser_surface_view_manager.h" |
| + |
| +#include "content/browser/android/child_process_launcher_android.h" |
| +#include "content/browser/android/content_view_core_impl.h" |
| +#include "content/browser/gpu/gpu_surface_tracker.h" |
| +#include "content/browser/web_contents/web_contents_impl.h" |
| +#include "content/common/media/surface_view_manager_messages_android.h" |
| +#include "content/public/browser/render_frame_host.h" |
| + |
| +namespace content { |
| + |
| +BrowserSurfaceViewManager::BrowserSurfaceViewManager( |
| + RenderFrameHost* render_frame_host) |
| + : render_frame_host_(render_frame_host) {} |
| + |
| +void BrowserSurfaceViewManager::SetVideoSurface( |
| + gfx::ScopedJavaSurface surface) { |
| + if (surface.IsEmpty()) { |
| + GpuSurfaceTracker::Get()->RemoveSurface(surface_view_id_); |
| + UnregisterViewSurface(surface_view_id_); |
| + } else { |
| + // We mainly use the surface tracker to allocate a surface id for us. The |
| + // lookup will go through the Android specific path and get the java |
| + // surface directly, so there's no need to add a valid native widget here. |
| + surface_view_id_ = GpuSurfaceTracker::Get()->AddSurfaceForNativeWidget( |
| + gfx::kNullAcceleratedWidget); |
| + RegisterViewSurface(surface_view_id_, surface.j_surface().obj()); |
| + Send(new RendererSurfaceViewManagerMsg_FullscreenSurfaceCreated( |
| + render_frame_host_->GetRoutingID(), surface_view_id_)); |
| + } |
| +} |
| + |
| +void BrowserSurfaceViewManager::DidExitFullscreen(bool release_media_player) { |
| + content_video_view_.reset(); |
| +} |
| + |
| +void BrowserSurfaceViewManager::OnCreateFullscreenSurface() { |
| + DCHECK(!ContentVideoView::GetInstance()); |
| + ContentViewCore* cvc = ContentViewCore::FromWebContents( |
| + WebContents::FromRenderFrameHost(render_frame_host_)); |
| + content_video_view_.reset(new ContentVideoView(this, cvc)); |
| + base::android::ScopedJavaLocalRef<jobject> j_content_video_view = |
| + content_video_view_->GetJavaObject(base::android::AttachCurrentThread()); |
| + if (!j_content_video_view.is_null()) { |
| + // XXX: plumb through the size change event. |
|
DaleCurtis
2016/02/02 01:01:32
Do you have a vision for what this looks like? Ano
watk
2016/02/02 20:38:14
Yeah, that's what I was thinking, but haven't figu
watk
2016/02/05 03:42:30
This turned out to be pretty simple. I just pass t
|
| + content_video_view_->OnVideoSizeChanged(1280, 720); |
| + } |
| +} |
| + |
| +bool BrowserSurfaceViewManager::Send(IPC::Message* msg) { |
| + return render_frame_host_->Send(msg); |
| +} |
| + |
| +} // namespace content |