OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "media/cast/transport/transport_video_sender.h" | 5 #include "media/cast/transport/transport_video_sender.h" |
6 | 6 |
7 #include <list> | 7 #include <list> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/message_loop/message_loop.h" | 11 #include "base/message_loop/message_loop.h" |
12 #include "media/base/video_frame.h" | 12 #include "media/base/video_frame.h" |
13 #include "media/cast/transport/pacing/paced_sender.h" | 13 #include "media/cast/transport/pacing/paced_sender.h" |
14 | 14 |
15 namespace media { | 15 namespace media { |
16 namespace cast { | 16 namespace cast { |
17 namespace transport { | 17 namespace transport { |
18 | 18 |
19 TransportVideoSender::TransportVideoSender( | 19 TransportVideoSender::TransportVideoSender( |
20 const CastTransportVideoConfig& config, | 20 const CastTransportVideoConfig& config, |
21 base::TickClock* clock, | 21 base::TickClock* clock, |
| 22 LoggingImpl* logging, |
22 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner, | 23 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner, |
23 PacedSender* const paced_packet_sender) | 24 PacedSender* const paced_packet_sender) |
24 : rtp_max_delay_(base::TimeDelta::FromMilliseconds( | 25 : rtp_max_delay_(base::TimeDelta::FromMilliseconds( |
25 config.base.rtp_config.max_delay_ms)), | 26 config.base.rtp_config.max_delay_ms)), |
26 encryptor_(), | 27 encryptor_(), |
27 rtp_sender_(clock, transport_task_runner, paced_packet_sender) { | 28 rtp_sender_(clock, logging, transport_task_runner, paced_packet_sender) { |
28 rtp_sender_.InitializeVideo(config); | 29 rtp_sender_.InitializeVideo(config); |
29 initialized_ = | 30 initialized_ = |
30 encryptor_.Initialize(config.base.aes_key, config.base.aes_iv_mask); | 31 encryptor_.Initialize(config.base.aes_key, config.base.aes_iv_mask); |
31 } | 32 } |
32 | 33 |
33 TransportVideoSender::~TransportVideoSender() {} | 34 TransportVideoSender::~TransportVideoSender() {} |
34 | 35 |
35 void TransportVideoSender::InsertCodedVideoFrame( | 36 void TransportVideoSender::InsertCodedVideoFrame( |
36 const EncodedVideoFrame* coded_frame, | 37 const EncodedVideoFrame* coded_frame, |
37 const base::TimeTicks& capture_time) { | 38 const base::TimeTicks& capture_time) { |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
72 } | 73 } |
73 | 74 |
74 void TransportVideoSender::SubscribeVideoRtpStatsCallback( | 75 void TransportVideoSender::SubscribeVideoRtpStatsCallback( |
75 const CastTransportRtpStatistics& callback) { | 76 const CastTransportRtpStatistics& callback) { |
76 rtp_sender_.SubscribeRtpStatsCallback(callback); | 77 rtp_sender_.SubscribeRtpStatsCallback(callback); |
77 } | 78 } |
78 | 79 |
79 } // namespace transport | 80 } // namespace transport |
80 } // namespace cast | 81 } // namespace cast |
81 } // namespace media | 82 } // namespace media |
OLD | NEW |