Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "extensions/renderer/api/display_source/wifi_display/wifi_display_video _encoder.h" | 5 #include "extensions/renderer/api/display_source/wifi_display/wifi_display_video _encoder.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 | 8 |
| 9 namespace extensions { | 9 namespace extensions { |
| 10 | 10 |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 | 21 |
| 22 WiFiDisplayVideoEncoder::~WiFiDisplayVideoEncoder() = default; | 22 WiFiDisplayVideoEncoder::~WiFiDisplayVideoEncoder() = default; |
| 23 | 23 |
| 24 // static | 24 // static |
| 25 void WiFiDisplayVideoEncoder::Create( | 25 void WiFiDisplayVideoEncoder::Create( |
| 26 const InitParameters& params, | 26 const InitParameters& params, |
| 27 const VideoEncoderCallback& encoder_callback) { | 27 const VideoEncoderCallback& encoder_callback) { |
| 28 CreateVEA(params, encoder_callback); | 28 CreateVEA(params, encoder_callback); |
| 29 } | 29 } |
| 30 | 30 |
| 31 WiFiDisplayElementaryStreamInfo | |
| 32 WiFiDisplayVideoEncoder::CreateElementaryStreamInfo() const { | |
| 33 DCHECK(client_thread_checker_.CalledOnValidThread()); | |
| 34 return WiFiDisplayElementaryStreamInfo( | |
| 35 WiFiDisplayElementaryStreamInfo::VIDEO_H264, | |
| 36 CreateElementaryStreamDescriptors()); | |
| 37 } | |
| 38 | |
| 39 std::vector<WiFiDisplayElementaryStreamDescriptor> | |
| 40 WiFiDisplayVideoEncoder::CreateElementaryStreamDescriptors() const { | |
|
Mikhail
2016/04/29 06:36:57
why this method is needed(isn't CreateElementarySt
e_hakkinen
2016/04/29 07:16:13
The idea is that it can be overridden by WiFiDispl
Mikhail
2016/04/29 07:37:41
CreateElementaryStreamInfo's body is tiny, IMO enc
e_hakkinen
2016/04/29 08:27:07
With the current design, WiFiDisplayVideoEncoder d
| |
| 41 std::vector<WiFiDisplayElementaryStreamDescriptor> descriptors; | |
| 42 descriptors.push_back( | |
| 43 WiFiDisplayElementaryStreamDescriptor::AVCTimingAndHRD::Create()); | |
| 44 return descriptors; | |
| 45 } | |
| 46 | |
| 31 void WiFiDisplayVideoEncoder::InsertRawVideoFrame( | 47 void WiFiDisplayVideoEncoder::InsertRawVideoFrame( |
| 32 const scoped_refptr<media::VideoFrame>& video_frame, | 48 const scoped_refptr<media::VideoFrame>& video_frame, |
| 33 base::TimeTicks reference_time) { | 49 base::TimeTicks reference_time) { |
| 34 DCHECK(client_thread_checker_.CalledOnValidThread()); | 50 DCHECK(client_thread_checker_.CalledOnValidThread()); |
| 35 DCHECK(!encoded_callback_.is_null()); | 51 DCHECK(!encoded_callback_.is_null()); |
| 36 media_task_runner_->PostTask( | 52 media_task_runner_->PostTask( |
| 37 FROM_HERE, base::Bind(&WiFiDisplayVideoEncoder::InsertFrameOnMediaThread, | 53 FROM_HERE, base::Bind(&WiFiDisplayVideoEncoder::InsertFrameOnMediaThread, |
| 38 this, video_frame, reference_time, send_idr_)); | 54 this, video_frame, reference_time, send_idr_)); |
| 39 send_idr_ = false; | 55 send_idr_ = false; |
| 40 } | 56 } |
| 41 | 57 |
| 42 void WiFiDisplayVideoEncoder::RequestIDRPicture() { | 58 void WiFiDisplayVideoEncoder::RequestIDRPicture() { |
| 43 DCHECK(client_thread_checker_.CalledOnValidThread()); | 59 DCHECK(client_thread_checker_.CalledOnValidThread()); |
| 44 send_idr_ = true; | 60 send_idr_ = true; |
| 45 } | 61 } |
| 46 | 62 |
| 47 } // namespace extensions | 63 } // namespace extensions |
| OLD | NEW |