Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1089)

Unified Diff: media/gpu/content_video_view_overlay.cc

Issue 2692863011: Add ContentVideoViewOverlay to AVDA. (Closed)
Patch Set: fixed avda unittest Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/gpu/content_video_view_overlay.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/gpu/content_video_view_overlay.cc
diff --git a/media/gpu/content_video_view_overlay.cc b/media/gpu/content_video_view_overlay.cc
new file mode 100644
index 0000000000000000000000000000000000000000..2ab158d4301ac4a9b3e4a7bcd731ba57b3bfd198
--- /dev/null
+++ b/media/gpu/content_video_view_overlay.cc
@@ -0,0 +1,71 @@
+// Copyright 2017 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 "media/gpu/content_video_view_overlay.h"
+
+#include "base/bind.h"
+#include "base/logging.h"
+#include "base/threading/thread_task_runner_handle.h"
+#include "gpu/ipc/common/gpu_surface_lookup.h"
+
+namespace media {
+
+ContentVideoViewOverlay::ContentVideoViewOverlay(
+ AVDACodecAllocator* codec_allocator,
+ int surface_id,
+ const AndroidOverlay::Config& config)
+ : codec_allocator_(codec_allocator),
+ surface_id_(surface_id),
+ config_(config),
+ weak_factory_(this) {
+ if (codec_allocator_->AllocateSurface(this, surface_id_)) {
+ // We have the surface -- post a callback to our OnSurfaceAvailable.
+ base::ThreadTaskRunnerHandle::Get()->PostTask(
+ FROM_HERE, base::Bind(&ContentVideoViewOverlay::OnSurfaceAvailable,
+ weak_factory_.GetWeakPtr(), true));
+ }
+}
+
+ContentVideoViewOverlay::~ContentVideoViewOverlay() {
+ // Deallocate the surface. It's okay if we don't own it.
+ codec_allocator_->DeallocateSurface(this, surface_id_);
+}
+
+void ContentVideoViewOverlay::ScheduleLayout(const gfx::Rect& rect) {
+ NOTIMPLEMENTED();
+}
+
+const base::android::JavaRef<jobject>& ContentVideoViewOverlay::GetJavaSurface()
+ const {
+ return surface_.j_surface();
+}
+
+void ContentVideoViewOverlay::OnSurfaceAvailable(bool success) {
+ if (!success) {
+ // Notify that the surface won't be available.
+ config_.failed_cb.Run();
+ // |this| may be deleted.
+ return;
+ }
+
+ // Get the surface and notify our client.
+ surface_ =
+ gpu::GpuSurfaceLookup::GetInstance()->AcquireJavaSurface(surface_id_);
+
+ // If no surface was returned, then fail instead.
+ if (surface_.IsEmpty()) {
+ config_.failed_cb.Run();
+ // |this| may be deleted.
+ return;
+ }
+
+ config_.ready_cb.Run();
+}
+
+void ContentVideoViewOverlay::OnSurfaceDestroyed() {
+ config_.destroyed_cb.Run();
+ // |this| may be deleted, or deletion might be posted elsewhere.
+}
+
+} // namespace media
« no previous file with comments | « media/gpu/content_video_view_overlay.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698