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 |