Chromium Code Reviews| OLD | NEW | 
|---|---|
| 1 /* | 1 /* | 
| 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. | 
| 3 * | 3 * | 
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license | 
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source | 
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found | 
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may | 
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. | 
| 9 */ | 9 */ | 
| 10 | 10 | 
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 50 // header-extension-for-audio-level-indication. | 50 // header-extension-for-audio-level-indication. | 
| 51 // Valid range is [0,100]. Actual value is negative. | 51 // Valid range is [0,100]. Actual value is negative. | 
| 52 int32_t SetAudioLevel(uint8_t level_dbov); | 52 int32_t SetAudioLevel(uint8_t level_dbov); | 
| 53 | 53 | 
| 54 // Send a DTMF tone using RFC 2833 (4733) | 54 // Send a DTMF tone using RFC 2833 (4733) | 
| 55 int32_t SendTelephoneEvent(uint8_t key, uint16_t time_ms, uint8_t level); | 55 int32_t SendTelephoneEvent(uint8_t key, uint16_t time_ms, uint8_t level); | 
| 56 | 56 | 
| 57 protected: | 57 protected: | 
| 58 bool SendTelephoneEventPacket( | 58 bool SendTelephoneEventPacket( | 
| 59 bool ended, | 59 bool ended, | 
| 60 int8_t dtmf_payload_type, | |
| 61 uint32_t dtmf_timestamp, | 60 uint32_t dtmf_timestamp, | 
| 62 uint16_t duration, | 61 uint16_t duration, | 
| 63 bool marker_bit); // set on first packet in talk burst | 62 bool marker_bit); // set on first packet in talk burst | 
| 64 | 63 | 
| 65 bool MarkerBit(FrameType frame_type, int8_t payload_type); | 64 bool MarkerBit(FrameType frame_type, int8_t payload_type); | 
| 66 | 65 | 
| 67 private: | 66 private: | 
| 68 Clock* const clock_; | 67 Clock* const clock_; | 
| 69 RTPSender* const rtp_sender_; | 68 RTPSender* const rtp_sender_; | 
| 70 | 69 | 
| 71 rtc::CriticalSection send_audio_critsect_; | 70 rtc::CriticalSection send_audio_critsect_; | 
| 72 | 71 | 
| 73 uint16_t packet_size_samples_ GUARDED_BY(send_audio_critsect_); | 72 uint16_t packet_size_samples_ GUARDED_BY(send_audio_critsect_) = 160; | 
| 74 | 73 | 
| 75 // DTMF. | 74 // DTMF. | 
| 76 bool dtmf_event_is_on_; | 75 bool dtmf_event_is_on_ = false; | 
| 77 bool dtmf_event_first_packet_sent_; | 76 bool dtmf_event_first_packet_sent_ = false; | 
| 78 int8_t dtmf_payload_type_ GUARDED_BY(send_audio_critsect_); | 77 int8_t dtmf_payload_type_ GUARDED_BY(send_audio_critsect_) = -1; | 
| 79 uint32_t dtmf_timestamp_; | 78 uint32_t dtmf_timestamp_ = 0; | 
| 80 uint8_t dtmf_key_; | 79 uint32_t dtmf_length_samples_ = 0; | 
| 81 uint32_t dtmf_length_samples_; | 80 int64_t dtmf_time_last_sent_ = 0; | 
| 82 uint8_t dtmf_level_; | 81 uint32_t dtmf_timestamp_last_sent_ = 0; | 
| 83 int64_t dtmf_time_last_sent_; | 82 DtmfQueue::Event dtmf_current_event_; | 
| 84 uint32_t dtmf_timestamp_last_sent_; | 83 DtmfQueue dtmf_queue_; | 
| 85 DTMFqueue dtmf_queue_; | |
| 86 | 84 | 
| 87 // VAD detection, used for marker bit. | 85 // VAD detection, used for marker bit. | 
| 88 bool inband_vad_active_ GUARDED_BY(send_audio_critsect_); | 86 bool inband_vad_active_ GUARDED_BY(send_audio_critsect_) = false; | 
| 89 int8_t cngnb_payload_type_ GUARDED_BY(send_audio_critsect_); | 87 int8_t cngnb_payload_type_ GUARDED_BY(send_audio_critsect_) = -1; | 
| 90 int8_t cngwb_payload_type_ GUARDED_BY(send_audio_critsect_); | 88 int8_t cngwb_payload_type_ GUARDED_BY(send_audio_critsect_) = -1; | 
| 91 int8_t cngswb_payload_type_ GUARDED_BY(send_audio_critsect_); | 89 int8_t cngswb_payload_type_ GUARDED_BY(send_audio_critsect_) = -1; | 
| 92 int8_t cngfb_payload_type_ GUARDED_BY(send_audio_critsect_); | 90 int8_t cngfb_payload_type_ GUARDED_BY(send_audio_critsect_) = -1; | 
| 93 int8_t last_payload_type_ GUARDED_BY(send_audio_critsect_); | 91 int8_t last_payload_type_ GUARDED_BY(send_audio_critsect_) = -1; | 
| 94 | 92 | 
| 95 // Audio level indication. | 93 // Audio level indication. | 
| 96 // (https://datatracker.ietf.org/doc/draft-lennox-avt-rtp-audio-level-exthdr/) | 94 // (https://datatracker.ietf.org/doc/draft-lennox-avt-rtp-audio-level-exthdr/) | 
| 97 uint8_t audio_level_dbov_ GUARDED_BY(send_audio_critsect_); | 95 uint8_t audio_level_dbov_ GUARDED_BY(send_audio_critsect_) = 0; | 
| 
 
stefan-webrtc
2016/11/08 15:05:39
We've tended to prefer initializer lists as splitt
 
the sun
2016/11/11 12:07:24
Ah yes, that's why I set clock_ and rtp_sender_ to
 
 | |
| 98 OneTimeEvent first_packet_sent_; | 96 OneTimeEvent first_packet_sent_; | 
| 99 | 97 | 
| 100 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(RTPSenderAudio); | 98 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(RTPSenderAudio); | 
| 101 }; | 99 }; | 
| 102 | 100 | 
| 103 } // namespace webrtc | 101 } // namespace webrtc | 
| 104 | 102 | 
| 105 #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_SENDER_AUDIO_H_ | 103 #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_RTP_SENDER_AUDIO_H_ | 
| OLD | NEW |