blob: 4bbd92f284b74584f3e6c37ddc0b30f21179fe7f [file] [log] [blame]
[email protected]48871fc2013-01-23 07:36:511// Copyright 2013 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
[email protected]cc3cfaa2013-03-18 09:05:525#include "cc/layers/video_frame_provider_client_impl.h"
[email protected]48871fc2013-01-23 07:36:516
primianoc06e2382015-01-28 04:21:497#include "base/trace_event/trace_event.h"
[email protected]681ccff2013-03-18 06:13:528#include "cc/base/math_util.h"
[email protected]cc3cfaa2013-03-18 09:05:529#include "cc/layers/video_layer_impl.h"
[email protected]b7cfc632013-04-10 04:44:4910#include "media/base/video_frame.h"
[email protected]48871fc2013-01-23 07:36:5111
12namespace cc {
13
14// static
15scoped_refptr<VideoFrameProviderClientImpl>
16 VideoFrameProviderClientImpl::Create(
17 VideoFrameProvider* provider) {
18 return make_scoped_refptr(
19 new VideoFrameProviderClientImpl(provider));
20}
21
22VideoFrameProviderClientImpl::~VideoFrameProviderClientImpl() {}
23
24VideoFrameProviderClientImpl::VideoFrameProviderClientImpl(
25 VideoFrameProvider* provider)
kulkarni.a4015690f12014-10-10 13:50:0626 : active_video_layer_(nullptr), provider_(provider) {
[email protected]48871fc2013-01-23 07:36:5127 // This only happens during a commit on the compositor thread while the main
28 // thread is blocked. That makes this a thread-safe call to set the video
29 // frame provider client that does not require a lock. The same is true of
30 // the call to Stop().
31 provider_->SetVideoFrameProviderClient(this);
32
33 // This matrix is the default transformation for stream textures, and flips
34 // on the Y axis.
35 stream_texture_matrix_ = gfx::Transform(
36 1.0, 0.0, 0.0, 0.0,
37 0.0, -1.0, 0.0, 1.0,
38 0.0, 0.0, 1.0, 0.0,
39 0.0, 0.0, 0.0, 1.0);
40}
41
dongseong.hwangee88f0aa2015-02-10 19:39:5942void VideoFrameProviderClientImpl::SetActiveVideoLayer(
43 VideoLayerImpl* video_layer) {
44 DCHECK(thread_checker_.CalledOnValidThread());
45 DCHECK(video_layer);
46 active_video_layer_ = video_layer;
47}
48
[email protected]48871fc2013-01-23 07:36:5149void VideoFrameProviderClientImpl::Stop() {
dongseong.hwangee88f0aa2015-02-10 19:39:5950 // It's called when the main thread is blocked, so lock isn't needed.
[email protected]48871fc2013-01-23 07:36:5151 if (!provider_)
52 return;
dongseong.hwangee88f0aa2015-02-10 19:39:5953 DCHECK(thread_checker_.CalledOnValidThread());
kulkarni.a4015690f12014-10-10 13:50:0654 provider_->SetVideoFrameProviderClient(nullptr);
55 provider_ = nullptr;
[email protected]48871fc2013-01-23 07:36:5156}
57
dongseong.hwangee88f0aa2015-02-10 19:39:5958bool VideoFrameProviderClientImpl::Stopped() {
59 DCHECK(thread_checker_.CalledOnValidThread());
60 // |provider_| is changed while the main thread is blocked, and not changed
61 // thereafter, so lock isn't needed.
62 return !provider_;
63}
64
[email protected]af2cd322013-03-22 16:56:1865scoped_refptr<media::VideoFrame>
66VideoFrameProviderClientImpl::AcquireLockAndCurrentFrame() {
dongseong.hwangee88f0aa2015-02-10 19:39:5967 DCHECK(thread_checker_.CalledOnValidThread());
[email protected]48871fc2013-01-23 07:36:5168 provider_lock_.Acquire(); // Balanced by call to ReleaseLock().
69 if (!provider_)
kulkarni.a4015690f12014-10-10 13:50:0670 return nullptr;
[email protected]48871fc2013-01-23 07:36:5171
72 return provider_->GetCurrentFrame();
73}
74
[email protected]af2cd322013-03-22 16:56:1875void VideoFrameProviderClientImpl::PutCurrentFrame(
76 const scoped_refptr<media::VideoFrame>& frame) {
dongseong.hwangee88f0aa2015-02-10 19:39:5977 DCHECK(thread_checker_.CalledOnValidThread());
[email protected]48871fc2013-01-23 07:36:5178 provider_lock_.AssertAcquired();
79 provider_->PutCurrentFrame(frame);
80}
81
82void VideoFrameProviderClientImpl::ReleaseLock() {
dongseong.hwangee88f0aa2015-02-10 19:39:5983 DCHECK(thread_checker_.CalledOnValidThread());
[email protected]48871fc2013-01-23 07:36:5184 provider_lock_.AssertAcquired();
85 provider_lock_.Release();
86}
87
88void VideoFrameProviderClientImpl::StopUsingProvider() {
89 // Block the provider from shutting down until this client is done
90 // using the frame.
91 base::AutoLock locker(provider_lock_);
kulkarni.a4015690f12014-10-10 13:50:0692 provider_ = nullptr;
[email protected]48871fc2013-01-23 07:36:5193}
94
95void VideoFrameProviderClientImpl::DidReceiveFrame() {
[email protected]9469d782014-04-18 01:23:5696 TRACE_EVENT1("cc",
97 "VideoFrameProviderClientImpl::DidReceiveFrame",
98 "active_video_layer",
99 !!active_video_layer_);
dongseong.hwangee88f0aa2015-02-10 19:39:59100 DCHECK(thread_checker_.CalledOnValidThread());
[email protected]48871fc2013-01-23 07:36:51101 if (active_video_layer_)
[email protected]4af49d542013-03-15 22:18:47102 active_video_layer_->SetNeedsRedraw();
[email protected]48871fc2013-01-23 07:36:51103}
104
105void VideoFrameProviderClientImpl::DidUpdateMatrix(const float* matrix) {
dongseong.hwangee88f0aa2015-02-10 19:39:59106 DCHECK(thread_checker_.CalledOnValidThread());
[email protected]48871fc2013-01-23 07:36:51107 stream_texture_matrix_ = gfx::Transform(
108 matrix[0], matrix[4], matrix[8], matrix[12],
109 matrix[1], matrix[5], matrix[9], matrix[13],
110 matrix[2], matrix[6], matrix[10], matrix[14],
111 matrix[3], matrix[7], matrix[11], matrix[15]);
112 if (active_video_layer_)
[email protected]4af49d542013-03-15 22:18:47113 active_video_layer_->SetNeedsRedraw();
[email protected]48871fc2013-01-23 07:36:51114}
115
116} // namespace cc