3
* Copyright 2011, Google Inc.
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
8
* 1. Redistributions of source code must retain the above copyright notice,
9
* this list of conditions and the following disclaimer.
10
* 2. Redistributions in binary form must reproduce the above copyright notice,
11
* this list of conditions and the following disclaimer in the documentation
12
* and/or other materials provided with the distribution.
13
* 3. The name of the author may not be used to endorse or promote products
14
* derived from this software without specific prior written permission.
16
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
17
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
19
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
22
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
23
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
24
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
25
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
#include "talk/app/webrtc/mediastreamtrackproxy.h"
30
#include "talk/session/phone/videocapturer.h"
35
MSG_REGISTER_OBSERVER = 1,
36
MSG_UNREGISTER_OBSERVER,
43
MSG_GET_VIDEORENDERER,
44
MSG_SET_VIDEORENDERER,
47
typedef talk_base::TypedMessageData<std::string*> LabelMessageData;
48
typedef talk_base::TypedMessageData<webrtc::ObserverInterface*>
50
typedef talk_base::TypedMessageData
51
<webrtc::MediaStreamTrackInterface::TrackState> TrackStateMessageData;
52
typedef talk_base::TypedMessageData<bool> EnableMessageData;
55
class AudioDeviceMessageData : public talk_base::MessageData {
57
talk_base::scoped_refptr<webrtc::AudioDeviceModule> audio_device_;
60
class VideoDeviceMessageData : public talk_base::MessageData {
62
cricket::VideoCapturer* video_device_;
65
class VideoRendererMessageData : public talk_base::MessageData {
67
talk_base::scoped_refptr<webrtc::VideoRendererWrapperInterface>
71
} // namespace anonymous
76
MediaStreamTrackProxy<T>::MediaStreamTrackProxy(
77
talk_base::Thread* signaling_thread)
78
: signaling_thread_(signaling_thread) {
82
void MediaStreamTrackProxy<T>::Init(MediaStreamTrackInterface* track) {
87
std::string MediaStreamTrackProxy<T>::kind() const {
88
return track_->kind();
92
std::string MediaStreamTrackProxy<T>::label() const {
93
if (!signaling_thread_->IsCurrent()) {
95
LabelMessageData msg(&label);
96
Send(MSG_LABEL, &msg);
99
return track_->label();
103
MediaStreamTrackInterface::TrackState MediaStreamTrackProxy<T>::state() const {
104
if (!signaling_thread_->IsCurrent()) {
105
TrackStateMessageData msg(MediaStreamTrackInterface::kInitializing);
106
Send(MSG_STATE, &msg);
109
return track_->state();
113
bool MediaStreamTrackProxy<T>::enabled() const {
114
if (!signaling_thread_->IsCurrent()) {
115
EnableMessageData msg(false);
116
Send(MSG_ENABLED, &msg);
119
return track_->enabled();
123
bool MediaStreamTrackProxy<T>::set_enabled(bool enable) {
124
if (!signaling_thread_->IsCurrent()) {
125
EnableMessageData msg(enable);
126
Send(MSG_SET_ENABLED, &msg);
129
return track_->set_enabled(enable);
133
bool MediaStreamTrackProxy<T>::set_state(
134
MediaStreamTrackInterface::TrackState new_state) {
135
if (!signaling_thread_->IsCurrent()) {
136
// State should only be allowed to be changed from the signaling thread.
137
ASSERT(!"Not Allowed!");
140
return track_->set_state(new_state);
144
void MediaStreamTrackProxy<T>::RegisterObserver(ObserverInterface* observer) {
145
if (!signaling_thread_->IsCurrent()) {
146
ObserverMessageData msg(observer);
147
Send(MSG_REGISTER_OBSERVER, &msg);
150
track_->RegisterObserver(observer);
154
void MediaStreamTrackProxy<T>::UnregisterObserver(ObserverInterface* observer) {
155
if (!signaling_thread_->IsCurrent()) {
156
ObserverMessageData msg(observer);
157
Send(MSG_UNREGISTER_OBSERVER, &msg);
160
track_->UnregisterObserver(observer);
164
void MediaStreamTrackProxy<T>::Send(uint32 id,
165
talk_base::MessageData* data) const {
166
signaling_thread_->Send(const_cast<MediaStreamTrackProxy<T>*>(this), id,
171
bool MediaStreamTrackProxy<T>::HandleMessage(talk_base::Message* msg) {
172
talk_base::MessageData* data = msg->pdata;
173
switch (msg->message_id) {
174
case MSG_REGISTER_OBSERVER: {
175
ObserverMessageData* observer = static_cast<ObserverMessageData*>(data);
176
track_->RegisterObserver(observer->data());
180
case MSG_UNREGISTER_OBSERVER: {
181
ObserverMessageData* observer = static_cast<ObserverMessageData*>(data);
182
track_->UnregisterObserver(observer->data());
187
LabelMessageData* label = static_cast<LabelMessageData*>(data);
188
*(label->data()) = track_->label();
191
case MSG_SET_ENABLED: {
192
EnableMessageData* enabled = static_cast<EnableMessageData*>(data);
193
enabled->data() = track_->set_enabled(enabled->data());
198
EnableMessageData* enabled = static_cast<EnableMessageData*>(data);
199
enabled->data() = track_->enabled();
204
TrackStateMessageData* state = static_cast<TrackStateMessageData*>(data);
205
state->data() = track_->state();
214
AudioTrackProxy::AudioTrackProxy(const std::string& label,
215
talk_base::Thread* signaling_thread)
216
: MediaStreamTrackProxy<LocalAudioTrackInterface>(signaling_thread),
217
audio_track_(AudioTrack::CreateRemote(label)) {
221
AudioTrackProxy::AudioTrackProxy(const std::string& label,
222
AudioDeviceModule* audio_device,
223
talk_base::Thread* signaling_thread)
224
: MediaStreamTrackProxy<LocalAudioTrackInterface>(signaling_thread),
225
audio_track_(AudioTrack::CreateLocal(label, audio_device)) {
229
AudioTrackProxy::AudioTrackProxy(LocalAudioTrackInterface* implementation,
230
talk_base::Thread* signaling_thread)
231
: MediaStreamTrackProxy<LocalAudioTrackInterface>(signaling_thread),
232
audio_track_(implementation) {
236
talk_base::scoped_refptr<AudioTrackInterface> AudioTrackProxy::CreateRemote(
237
const std::string& label,
238
talk_base::Thread* signaling_thread) {
239
ASSERT(signaling_thread != NULL);
240
talk_base::RefCountedObject<AudioTrackProxy>* track =
241
new talk_base::RefCountedObject<AudioTrackProxy>(label, signaling_thread);
245
talk_base::scoped_refptr<LocalAudioTrackInterface> AudioTrackProxy::CreateLocal(
246
const std::string& label,
247
AudioDeviceModule* audio_device,
248
talk_base::Thread* signaling_thread) {
249
ASSERT(signaling_thread != NULL);
250
talk_base::RefCountedObject<AudioTrackProxy>* track =
251
new talk_base::RefCountedObject<AudioTrackProxy>(label,
257
talk_base::scoped_refptr<LocalAudioTrackInterface> AudioTrackProxy::CreateLocal(
258
LocalAudioTrackInterface* implementation,
259
talk_base::Thread* signaling_thread) {
260
ASSERT(signaling_thread != NULL);
261
talk_base::RefCountedObject<AudioTrackProxy>* track =
262
new talk_base::RefCountedObject<AudioTrackProxy>(implementation,
267
AudioDeviceModule* AudioTrackProxy::GetAudioDevice() {
268
if (!signaling_thread_->IsCurrent()) {
269
AudioDeviceMessageData msg;
270
Send(MSG_GET_AUDIODEVICE, &msg);
271
return msg.audio_device_;
273
return audio_track_->GetAudioDevice();
276
void AudioTrackProxy::OnMessage(talk_base::Message* msg) {
277
if (!MediaStreamTrackProxy<LocalAudioTrackInterface>::HandleMessage(msg)) {
278
if (msg->message_id == MSG_GET_AUDIODEVICE) {
279
AudioDeviceMessageData* audio_device =
280
static_cast<AudioDeviceMessageData*>(msg->pdata);
281
audio_device->audio_device_ = audio_track_->GetAudioDevice();
283
ASSERT(!"Not Implemented!");
288
VideoTrackProxy::VideoTrackProxy(const std::string& label,
289
talk_base::Thread* signaling_thread)
290
: MediaStreamTrackProxy<LocalVideoTrackInterface>(signaling_thread),
291
video_track_(VideoTrack::CreateRemote(label)) {
295
VideoTrackProxy::VideoTrackProxy(const std::string& label,
296
cricket::VideoCapturer* video_device,
297
talk_base::Thread* signaling_thread)
298
: MediaStreamTrackProxy<LocalVideoTrackInterface>(signaling_thread),
299
video_track_(VideoTrack::CreateLocal(label, video_device)) {
303
VideoTrackProxy::VideoTrackProxy(LocalVideoTrackInterface* implementation,
304
talk_base::Thread* signaling_thread)
305
: MediaStreamTrackProxy<LocalVideoTrackInterface>(signaling_thread),
306
video_track_(implementation) {
310
talk_base::scoped_refptr<VideoTrackInterface> VideoTrackProxy::CreateRemote(
311
const std::string& label,
312
talk_base::Thread* signaling_thread) {
313
ASSERT(signaling_thread != NULL);
314
talk_base::RefCountedObject<VideoTrackProxy>* track =
315
new talk_base::RefCountedObject<VideoTrackProxy>(label, signaling_thread);
319
talk_base::scoped_refptr<LocalVideoTrackInterface> VideoTrackProxy::CreateLocal(
320
const std::string& label,
321
cricket::VideoCapturer* video_device,
322
talk_base::Thread* signaling_thread) {
323
ASSERT(signaling_thread != NULL);
324
talk_base::RefCountedObject<VideoTrackProxy>* track =
325
new talk_base::RefCountedObject<VideoTrackProxy>(label, video_device,
330
talk_base::scoped_refptr<LocalVideoTrackInterface> VideoTrackProxy::CreateLocal(
331
LocalVideoTrackInterface* implementation,
332
talk_base::Thread* signaling_thread) {
333
ASSERT(signaling_thread != NULL);
334
talk_base::RefCountedObject<VideoTrackProxy>* track =
335
new talk_base::RefCountedObject<VideoTrackProxy>(implementation,
340
cricket::VideoCapturer* VideoTrackProxy::GetVideoCapture() {
341
if (!signaling_thread_->IsCurrent()) {
342
VideoDeviceMessageData msg;
343
Send(MSG_GET_VIDEODEVICE, &msg);
344
return msg.video_device_;
346
return video_track_->GetVideoCapture();
349
void VideoTrackProxy::SetRenderer(VideoRendererWrapperInterface* renderer) {
350
if (!signaling_thread_->IsCurrent()) {
351
VideoRendererMessageData msg;
352
msg.video_renderer_ = renderer;
353
Send(MSG_SET_VIDEORENDERER, &msg);
356
return video_track_->SetRenderer(renderer);
359
VideoRendererWrapperInterface* VideoTrackProxy::GetRenderer() {
360
if (!signaling_thread_->IsCurrent()) {
361
VideoRendererMessageData msg;
362
Send(MSG_GET_VIDEORENDERER, &msg);
363
return msg.video_renderer_;
365
return video_track_->GetRenderer();
368
void VideoTrackProxy::OnMessage(talk_base::Message* msg) {
369
if (!MediaStreamTrackProxy<LocalVideoTrackInterface>::HandleMessage(msg)) {
370
switch (msg->message_id) {
371
case MSG_GET_VIDEODEVICE: {
372
VideoDeviceMessageData* video_device =
373
static_cast<VideoDeviceMessageData*>(msg->pdata);
374
video_device->video_device_ = video_track_->GetVideoCapture();
377
case MSG_GET_VIDEORENDERER: {
378
VideoRendererMessageData* video_renderer =
379
static_cast<VideoRendererMessageData*>(msg->pdata);
380
video_renderer->video_renderer_ = video_track_->GetRenderer();
383
case MSG_SET_VIDEORENDERER: {
384
VideoRendererMessageData* video_renderer =
385
static_cast<VideoRendererMessageData*>(msg->pdata);
386
video_track_->SetRenderer(video_renderer->video_renderer_.get());
390
ASSERT(!"Not Implemented!");
396
} // namespace webrtc