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 "content/renderer/media_capture_from_element/html_video_element_capture
r_source.h" | 5 #include "content/renderer/media_capture_from_element/html_video_element_capture
r_source.h" |
6 | 6 |
7 #include "base/location.h" | 7 #include "base/location.h" |
8 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
9 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
10 #include "base/threading/thread_task_runner_handle.h" | 10 #include "base/threading/thread_task_runner_handle.h" |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
54 | 54 |
55 HtmlVideoElementCapturerSource::~HtmlVideoElementCapturerSource() { | 55 HtmlVideoElementCapturerSource::~HtmlVideoElementCapturerSource() { |
56 DCHECK(thread_checker_.CalledOnValidThread()); | 56 DCHECK(thread_checker_.CalledOnValidThread()); |
57 } | 57 } |
58 | 58 |
59 void HtmlVideoElementCapturerSource::GetCurrentSupportedFormats( | 59 void HtmlVideoElementCapturerSource::GetCurrentSupportedFormats( |
60 int max_requested_width, | 60 int max_requested_width, |
61 int max_requested_height, | 61 int max_requested_height, |
62 double max_requested_frame_rate, | 62 double max_requested_frame_rate, |
63 const VideoCaptureDeviceFormatsCB& callback) { | 63 const VideoCaptureDeviceFormatsCB& callback) { |
64 DVLOG(3) << __func__ << "{ max_requested_height = " << max_requested_height | 64 DVLOG(2) << __func__ << "{ max_requested_height = " << max_requested_height |
65 << "}) { max_requested_width = " << max_requested_width | 65 << "}) { max_requested_width = " << max_requested_width |
66 << "}) { max_requested_frame_rate = " << max_requested_frame_rate | 66 << "}) { max_requested_frame_rate = " << max_requested_frame_rate |
67 << "})"; | 67 << "})"; |
68 DCHECK(thread_checker_.CalledOnValidThread()); | 68 DCHECK(thread_checker_.CalledOnValidThread()); |
69 | 69 |
70 // WebMediaPlayer has a setRate() but can't be read back. | 70 // WebMediaPlayer has a setRate() but can't be read back. |
71 // TODO(mcasas): Add getRate() to WMPlayer and/or fix the spec to allow users | 71 // TODO(mcasas): Add getRate() to WMPlayer and/or fix the spec to allow users |
72 // to specify it. | 72 // to specify it. |
73 const media::VideoCaptureFormat format( | 73 const media::VideoCaptureFormat format( |
74 web_media_player_->naturalSize(), | 74 web_media_player_->naturalSize(), |
75 MediaStreamVideoSource::kDefaultFrameRate, | 75 MediaStreamVideoSource::kDefaultFrameRate, |
76 media::PIXEL_FORMAT_I420); | 76 media::PIXEL_FORMAT_I420); |
77 media::VideoCaptureFormats formats; | 77 media::VideoCaptureFormats formats; |
78 formats.push_back(format); | 78 formats.push_back(format); |
79 callback.Run(formats); | 79 callback.Run(formats); |
80 } | 80 } |
81 | 81 |
82 void HtmlVideoElementCapturerSource::StartCapture( | 82 void HtmlVideoElementCapturerSource::StartCapture( |
83 const media::VideoCaptureParams& params, | 83 const media::VideoCaptureParams& params, |
84 const VideoCaptureDeliverFrameCB& new_frame_callback, | 84 const VideoCaptureDeliverFrameCB& new_frame_callback, |
85 const RunningCallback& running_callback) { | 85 const RunningCallback& running_callback) { |
86 DVLOG(3) << __func__ << " requested " | 86 DVLOG(2) << __func__ << " requested " |
87 << media::VideoCaptureFormat::ToString(params.requested_format); | 87 << media::VideoCaptureFormat::ToString(params.requested_format); |
88 DCHECK(params.requested_format.IsValid()); | 88 DCHECK(params.requested_format.IsValid()); |
89 DCHECK(thread_checker_.CalledOnValidThread()); | 89 DCHECK(thread_checker_.CalledOnValidThread()); |
90 | 90 |
91 running_callback_ = running_callback; | 91 running_callback_ = running_callback; |
92 if (!web_media_player_ || !web_media_player_->hasVideo()) { | 92 if (!web_media_player_ || !web_media_player_->hasVideo()) { |
93 running_callback_.Run(false); | 93 running_callback_.Run(false); |
94 return; | 94 return; |
95 } | 95 } |
96 const blink::WebSize resolution = web_media_player_->naturalSize(); | 96 const blink::WebSize resolution = web_media_player_->naturalSize(); |
(...skipping 11 matching lines...) Expand all Loading... |
108 std::min(static_cast<float>(media::limits::kMaxFramesPerSecond), | 108 std::min(static_cast<float>(media::limits::kMaxFramesPerSecond), |
109 params.requested_format.frame_rate)); | 109 params.requested_format.frame_rate)); |
110 | 110 |
111 running_callback_.Run(true); | 111 running_callback_.Run(true); |
112 base::ThreadTaskRunnerHandle::Get()->PostTask( | 112 base::ThreadTaskRunnerHandle::Get()->PostTask( |
113 FROM_HERE, base::Bind(&HtmlVideoElementCapturerSource::sendNewFrame, | 113 FROM_HERE, base::Bind(&HtmlVideoElementCapturerSource::sendNewFrame, |
114 weak_factory_.GetWeakPtr())); | 114 weak_factory_.GetWeakPtr())); |
115 } | 115 } |
116 | 116 |
117 void HtmlVideoElementCapturerSource::StopCapture() { | 117 void HtmlVideoElementCapturerSource::StopCapture() { |
118 DVLOG(3) << __func__; | 118 DVLOG(2) << __func__; |
119 DCHECK(thread_checker_.CalledOnValidThread()); | 119 DCHECK(thread_checker_.CalledOnValidThread()); |
120 running_callback_.Reset(); | 120 running_callback_.Reset(); |
121 new_frame_callback_.Reset(); | 121 new_frame_callback_.Reset(); |
122 next_capture_time_ = base::TimeTicks(); | 122 next_capture_time_ = base::TimeTicks(); |
123 } | 123 } |
124 | 124 |
125 void HtmlVideoElementCapturerSource::sendNewFrame() { | 125 void HtmlVideoElementCapturerSource::sendNewFrame() { |
126 DVLOG(3) << __func__; | 126 DVLOG(3) << __func__; |
127 TRACE_EVENT0("video", "HtmlVideoElementCapturerSource::sendNewFrame"); | 127 TRACE_EVENT0("video", "HtmlVideoElementCapturerSource::sendNewFrame"); |
128 DCHECK(thread_checker_.CalledOnValidThread()); | 128 DCHECK(thread_checker_.CalledOnValidThread()); |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
198 next_capture_time_ = current_time; | 198 next_capture_time_ = current_time; |
199 } | 199 } |
200 // Schedule next capture. | 200 // Schedule next capture. |
201 base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( | 201 base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( |
202 FROM_HERE, base::Bind(&HtmlVideoElementCapturerSource::sendNewFrame, | 202 FROM_HERE, base::Bind(&HtmlVideoElementCapturerSource::sendNewFrame, |
203 weak_factory_.GetWeakPtr()), | 203 weak_factory_.GetWeakPtr()), |
204 next_capture_time_ - current_time); | 204 next_capture_time_ - current_time); |
205 } | 205 } |
206 | 206 |
207 } // namespace content | 207 } // namespace content |
OLD | NEW |