OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "chrome/renderer/media/cast_rtp_stream.h" | 5 #include "chrome/renderer/media/cast_rtp_stream.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/memory/weak_ptr.h" | 9 #include "base/memory/weak_ptr.h" |
10 #include "chrome/renderer/media/cast_session.h" | 10 #include "chrome/renderer/media/cast_session.h" |
11 #include "chrome/renderer/media/cast_udp_transport.h" | 11 #include "chrome/renderer/media/cast_udp_transport.h" |
12 #include "content/public/renderer/media_stream_audio_sink.h" | 12 #include "content/public/renderer/media_stream_audio_sink.h" |
13 #include "content/public/renderer/media_stream_video_sink.h" | 13 #include "content/public/renderer/media_stream_video_sink.h" |
14 #include "media/base/audio_bus.h" | 14 #include "media/base/audio_bus.h" |
15 #include "media/cast/cast_config.h" | 15 #include "media/cast/cast_config.h" |
16 #include "media/cast/cast_defines.h" | 16 #include "media/cast/cast_defines.h" |
17 #include "media/cast/cast_sender.h" | 17 #include "media/cast/cast_sender.h" |
| 18 #include "media/cast/transport/cast_transport_config.h" |
18 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" | 19 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" |
19 | 20 |
20 using media::cast::AudioSenderConfig; | 21 using media::cast::AudioSenderConfig; |
21 using media::cast::VideoSenderConfig; | 22 using media::cast::VideoSenderConfig; |
22 | 23 |
23 namespace { | 24 namespace { |
24 const char kCodecNameOpus[] = "OPUS"; | 25 const char kCodecNameOpus[] = "OPUS"; |
25 const char kCodecNameVp8[] = "VP8"; | 26 const char kCodecNameVp8[] = "VP8"; |
26 | 27 |
27 CastRtpPayloadParams DefaultOpusPayload() { | 28 CastRtpPayloadParams DefaultOpusPayload() { |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
72 const CastRtpPayloadParams& payload_params = params.payloads[0]; | 73 const CastRtpPayloadParams& payload_params = params.payloads[0]; |
73 config->sender_ssrc = payload_params.ssrc; | 74 config->sender_ssrc = payload_params.ssrc; |
74 config->incoming_feedback_ssrc = payload_params.feedback_ssrc; | 75 config->incoming_feedback_ssrc = payload_params.feedback_ssrc; |
75 config->rtp_payload_type = payload_params.payload_type; | 76 config->rtp_payload_type = payload_params.payload_type; |
76 config->use_external_encoder = false; | 77 config->use_external_encoder = false; |
77 config->frequency = payload_params.clock_rate; | 78 config->frequency = payload_params.clock_rate; |
78 config->channels = payload_params.channels; | 79 config->channels = payload_params.channels; |
79 config->bitrate = payload_params.max_bitrate; | 80 config->bitrate = payload_params.max_bitrate; |
80 config->aes_key = payload_params.aes_key; | 81 config->aes_key = payload_params.aes_key; |
81 config->aes_iv_mask = payload_params.aes_iv_mask; | 82 config->aes_iv_mask = payload_params.aes_iv_mask; |
82 config->codec = media::cast::kPcm16; | 83 config->codec = media::cast::transport::kPcm16; |
83 if (payload_params.codec_name == kCodecNameOpus) | 84 if (payload_params.codec_name == kCodecNameOpus) |
84 config->codec = media::cast::kOpus; | 85 config->codec = media::cast::transport::kOpus; |
85 else | 86 else |
86 return false; | 87 return false; |
87 return true; | 88 return true; |
88 } | 89 } |
89 | 90 |
90 bool ToVideoSenderConfig(const CastRtpParams& params, | 91 bool ToVideoSenderConfig(const CastRtpParams& params, |
91 VideoSenderConfig* config) { | 92 VideoSenderConfig* config) { |
92 if (params.payloads.empty()) | 93 if (params.payloads.empty()) |
93 return false; | 94 return false; |
94 const CastRtpPayloadParams& payload_params = params.payloads[0]; | 95 const CastRtpPayloadParams& payload_params = params.payloads[0]; |
95 config->sender_ssrc = payload_params.ssrc; | 96 config->sender_ssrc = payload_params.ssrc; |
96 config->incoming_feedback_ssrc = payload_params.feedback_ssrc; | 97 config->incoming_feedback_ssrc = payload_params.feedback_ssrc; |
97 config->rtp_payload_type = payload_params.payload_type; | 98 config->rtp_payload_type = payload_params.payload_type; |
98 config->use_external_encoder = false; | 99 config->use_external_encoder = false; |
99 config->width = payload_params.width; | 100 config->width = payload_params.width; |
100 config->height = payload_params.height; | 101 config->height = payload_params.height; |
101 config->min_bitrate = config->start_bitrate = payload_params.min_bitrate; | 102 config->min_bitrate = config->start_bitrate = payload_params.min_bitrate; |
102 config->max_bitrate = payload_params.max_bitrate; | 103 config->max_bitrate = payload_params.max_bitrate; |
103 config->aes_key = payload_params.aes_key; | 104 config->aes_key = payload_params.aes_key; |
104 config->aes_iv_mask = payload_params.aes_iv_mask; | 105 config->aes_iv_mask = payload_params.aes_iv_mask; |
105 if (payload_params.codec_name == kCodecNameVp8) | 106 if (payload_params.codec_name == kCodecNameVp8) |
106 config->codec = media::cast::kVp8; | 107 config->codec = media::cast::transport::kVp8; |
107 else | 108 else |
108 return false; | 109 return false; |
109 return true; | 110 return true; |
110 } | 111 } |
111 | 112 |
112 void DeleteAudioBus(scoped_ptr<media::AudioBus> audio_bus) { | 113 void DeleteAudioBus(scoped_ptr<media::AudioBus> audio_bus) { |
113 // Do nothing as |audio_bus| will be deleted. | 114 // Do nothing as |audio_bus| will be deleted. |
114 } | 115 } |
115 | 116 |
116 } // namespace | 117 } // namespace |
(...skipping 172 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
289 } | 290 } |
290 | 291 |
291 void CastRtpStream::Stop() { | 292 void CastRtpStream::Stop() { |
292 audio_sink_.reset(); | 293 audio_sink_.reset(); |
293 video_sink_.reset(); | 294 video_sink_.reset(); |
294 } | 295 } |
295 | 296 |
296 bool CastRtpStream::IsAudio() const { | 297 bool CastRtpStream::IsAudio() const { |
297 return track_.source().type() == blink::WebMediaStreamSource::TypeAudio; | 298 return track_.source().type() == blink::WebMediaStreamSource::TypeAudio; |
298 } | 299 } |
OLD | NEW |