| /* |
| * Copyright 2012 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef PC_DTMFSENDER_H_ |
| #define PC_DTMFSENDER_H_ |
| |
| #include <string> |
| |
| #include "api/dtmfsenderinterface.h" |
| #include "api/proxy.h" |
| #include "rtc_base/asyncinvoker.h" |
| #include "rtc_base/constructormagic.h" |
| #include "rtc_base/refcount.h" |
| #include "rtc_base/thread.h" |
| |
| // DtmfSender is the native implementation of the RTCDTMFSender defined by |
| // the WebRTC W3C Editor's Draft. |
| // https://w3c.github.io/webrtc-pc/#rtcdtmfsender |
| |
| namespace webrtc { |
| |
| // This interface is called by DtmfSender to talk to the actual audio channel |
| // to send DTMF. |
| class DtmfProviderInterface { |
| public: |
| // Returns true if the audio sender is capable of sending DTMF. Otherwise |
| // returns false. |
| virtual bool CanInsertDtmf() = 0; |
| // Sends DTMF |code|. |
| // The |duration| indicates the length of the DTMF tone in ms. |
| // Returns true on success and false on failure. |
| virtual bool InsertDtmf(int code, int duration) = 0; |
| // Returns a |sigslot::signal0<>| signal. The signal should fire before |
| // the provider is destroyed. |
| virtual sigslot::signal0<>* GetOnDestroyedSignal() = 0; |
| |
| protected: |
| virtual ~DtmfProviderInterface() {} |
| }; |
| |
| class DtmfSender : public DtmfSenderInterface, public sigslot::has_slots<> { |
| public: |
| static rtc::scoped_refptr<DtmfSender> Create(rtc::Thread* signaling_thread, |
| DtmfProviderInterface* provider); |
| |
| // Implements DtmfSenderInterface. |
| void RegisterObserver(DtmfSenderObserverInterface* observer) override; |
| void UnregisterObserver() override; |
| bool CanInsertDtmf() override; |
| bool InsertDtmf(const std::string& tones, |
| int duration, |
| int inter_tone_gap) override; |
| std::string tones() const override; |
| int duration() const override; |
| int inter_tone_gap() const override; |
| |
| protected: |
| DtmfSender(rtc::Thread* signaling_thread, DtmfProviderInterface* provider); |
| virtual ~DtmfSender(); |
| |
| private: |
| DtmfSender(); |
| |
| void QueueInsertDtmf(const rtc::Location& posted_from, uint32_t delay_ms); |
| |
| // The DTMF sending task. |
| void DoInsertDtmf(); |
| |
| void OnProviderDestroyed(); |
| |
| void StopSending(); |
| |
| DtmfSenderObserverInterface* observer_; |
| rtc::Thread* signaling_thread_; |
| DtmfProviderInterface* provider_; |
| std::string tones_; |
| int duration_; |
| int inter_tone_gap_; |
| // Invoker for running delayed tasks which feed the DTMF provider one tone at |
| // a time. |
| rtc::AsyncInvoker dtmf_driver_; |
| |
| RTC_DISALLOW_COPY_AND_ASSIGN(DtmfSender); |
| }; |
| |
| // Define proxy for DtmfSenderInterface. |
| BEGIN_SIGNALING_PROXY_MAP(DtmfSender) |
| PROXY_SIGNALING_THREAD_DESTRUCTOR() |
| PROXY_METHOD1(void, RegisterObserver, DtmfSenderObserverInterface*) |
| PROXY_METHOD0(void, UnregisterObserver) |
| PROXY_METHOD0(bool, CanInsertDtmf) |
| PROXY_METHOD3(bool, InsertDtmf, const std::string&, int, int) |
| PROXY_CONSTMETHOD0(std::string, tones) |
| PROXY_CONSTMETHOD0(int, duration) |
| PROXY_CONSTMETHOD0(int, inter_tone_gap) |
| END_PROXY_MAP() |
| |
| // Get DTMF code from the DTMF event character. |
| bool GetDtmfCode(char tone, int* code); |
| |
| } // namespace webrtc |
| |
| #endif // PC_DTMFSENDER_H_ |