OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2011 Google Inc. All rights reserved. | 2 * Copyright (C) 2011 Google Inc. All rights reserved. |
3 * Copyright (C) 2011, 2012 Ericsson AB. All rights reserved. | 3 * Copyright (C) 2011, 2012 Ericsson AB. All rights reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
7 * are met: | 7 * are met: |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
82 { | 82 { |
83 MediaStreamTrackVector audioTracks; | 83 MediaStreamTrackVector audioTracks; |
84 MediaStreamTrackVector videoTracks; | 84 MediaStreamTrackVector videoTracks; |
85 | 85 |
86 for (size_t i = 0; i < tracks.size(); ++i) | 86 for (size_t i = 0; i < tracks.size(); ++i) |
87 processTrack(tracks[i].get(), tracks[i]->kind() == "audio" ? audioTracks : videoTracks); | 87 processTrack(tracks[i].get(), tracks[i]->kind() == "audio" ? audioTracks : videoTracks); |
88 | 88 |
89 return new MediaStream(context, audioTracks, videoTracks); | 89 return new MediaStream(context, audioTracks, videoTracks); |
90 } | 90 } |
91 | 91 |
92 MediaStream* MediaStream::create(ExecutionContext* context, PassRefPtr<MediaStre amDescriptor> streamDescriptor) | 92 MediaStream* MediaStream::create(ExecutionContext* context, MediaStreamDescripto r* streamDescriptor) |
93 { | 93 { |
94 return new MediaStream(context, streamDescriptor); | 94 return new MediaStream(context, streamDescriptor); |
95 } | 95 } |
96 | 96 |
97 MediaStream::MediaStream(ExecutionContext* context, PassRefPtr<MediaStreamDescri ptor> streamDescriptor) | 97 MediaStream::MediaStream(ExecutionContext* context, MediaStreamDescriptor* strea mDescriptor) |
98 : ContextLifecycleObserver(context) | 98 : ContextLifecycleObserver(context) |
99 , m_stopped(false) | 99 , m_stopped(false) |
100 , m_descriptor(streamDescriptor) | 100 , m_descriptor(streamDescriptor) |
101 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired) | 101 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired) |
102 { | 102 { |
103 m_descriptor->setClient(this); | 103 m_descriptor->setClient(this); |
104 | 104 |
105 size_t numberOfAudioTracks = m_descriptor->numberOfAudioComponents(); | 105 size_t numberOfAudioTracks = m_descriptor->numberOfAudioComponents(); |
106 m_audioTracks.reserveCapacity(numberOfAudioTracks); | 106 m_audioTracks.reserveCapacity(numberOfAudioTracks); |
107 for (size_t i = 0; i < numberOfAudioTracks; i++) { | 107 for (size_t i = 0; i < numberOfAudioTracks; i++) { |
(...skipping 28 matching lines...) Expand all Loading... | |
136 (*iter)->registerMediaStream(this); | 136 (*iter)->registerMediaStream(this); |
137 audioComponents.append((*iter)->component()); | 137 audioComponents.append((*iter)->component()); |
138 } | 138 } |
139 for (iter = videoTracks.begin(); iter != videoTracks.end(); ++iter) { | 139 for (iter = videoTracks.begin(); iter != videoTracks.end(); ++iter) { |
140 (*iter)->registerMediaStream(this); | 140 (*iter)->registerMediaStream(this); |
141 videoComponents.append((*iter)->component()); | 141 videoComponents.append((*iter)->component()); |
142 } | 142 } |
143 | 143 |
144 m_descriptor = MediaStreamDescriptor::create(audioComponents, videoComponent s); | 144 m_descriptor = MediaStreamDescriptor::create(audioComponents, videoComponent s); |
145 m_descriptor->setClient(this); | 145 m_descriptor->setClient(this); |
146 MediaStreamCenter::instance().didCreateMediaStream(m_descriptor.get()); | 146 MediaStreamCenter::instance().didCreateMediaStream(m_descriptor); |
147 | 147 |
148 m_audioTracks = audioTracks; | 148 m_audioTracks = audioTracks; |
149 m_videoTracks = videoTracks; | 149 m_videoTracks = videoTracks; |
150 if (emptyOrOnlyEndedTracks()) { | 150 if (emptyOrOnlyEndedTracks()) { |
151 m_descriptor->setActive(false); | 151 m_descriptor->setActive(false); |
152 } | 152 } |
153 } | 153 } |
154 | 154 |
155 MediaStream::~MediaStream() | 155 MediaStream::~MediaStream() |
156 { | 156 { |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
207 break; | 207 break; |
208 } | 208 } |
209 track->registerMediaStream(this); | 209 track->registerMediaStream(this); |
210 m_descriptor->addComponent(track->component()); | 210 m_descriptor->addComponent(track->component()); |
211 | 211 |
212 if (!active() && !track->ended()) { | 212 if (!active() && !track->ended()) { |
213 m_descriptor->setActive(true); | 213 m_descriptor->setActive(true); |
214 scheduleDispatchEvent(Event::create(EventTypeNames::active)); | 214 scheduleDispatchEvent(Event::create(EventTypeNames::active)); |
215 } | 215 } |
216 | 216 |
217 MediaStreamCenter::instance().didAddMediaStreamTrack(m_descriptor.get(), tra ck->component()); | 217 MediaStreamCenter::instance().didAddMediaStreamTrack(m_descriptor.get(), tra ck->component()); |
sof
2015/09/30 06:26:34
redundant get()
peria
2015/09/30 07:50:05
Done.
| |
218 } | 218 } |
219 | 219 |
220 void MediaStream::removeTrack(MediaStreamTrack* track, ExceptionState& exception State) | 220 void MediaStream::removeTrack(MediaStreamTrack* track, ExceptionState& exception State) |
221 { | 221 { |
222 if (!track) { | 222 if (!track) { |
223 exceptionState.throwDOMException(TypeMismatchError, "The MediaStreamTrac k provided is invalid."); | 223 exceptionState.throwDOMException(TypeMismatchError, "The MediaStreamTrac k provided is invalid."); |
224 return; | 224 return; |
225 } | 225 } |
226 | 226 |
227 size_t pos = kNotFound; | 227 size_t pos = kNotFound; |
(...skipping 13 matching lines...) Expand all Loading... | |
241 if (pos == kNotFound) | 241 if (pos == kNotFound) |
242 return; | 242 return; |
243 track->unregisterMediaStream(this); | 243 track->unregisterMediaStream(this); |
244 m_descriptor->removeComponent(track->component()); | 244 m_descriptor->removeComponent(track->component()); |
245 | 245 |
246 if (active() && emptyOrOnlyEndedTracks()) { | 246 if (active() && emptyOrOnlyEndedTracks()) { |
247 m_descriptor->setActive(false); | 247 m_descriptor->setActive(false); |
248 scheduleDispatchEvent(Event::create(EventTypeNames::inactive)); | 248 scheduleDispatchEvent(Event::create(EventTypeNames::inactive)); |
249 } | 249 } |
250 | 250 |
251 MediaStreamCenter::instance().didRemoveMediaStreamTrack(m_descriptor.get(), track->component()); | 251 MediaStreamCenter::instance().didRemoveMediaStreamTrack(m_descriptor.get(), track->component()); |
sof
2015/09/30 06:26:34
redundant get()
peria
2015/09/30 07:50:05
Done.
| |
252 } | 252 } |
253 | 253 |
254 MediaStreamTrack* MediaStream::getTrackById(String id) | 254 MediaStreamTrack* MediaStream::getTrackById(String id) |
255 { | 255 { |
256 for (MediaStreamTrackVector::iterator iter = m_audioTracks.begin(); iter != m_audioTracks.end(); ++iter) { | 256 for (MediaStreamTrackVector::iterator iter = m_audioTracks.begin(); iter != m_audioTracks.end(); ++iter) { |
257 if ((*iter)->id() == id) | 257 if ((*iter)->id() == id) |
258 return iter->get(); | 258 return iter->get(); |
259 } | 259 } |
260 | 260 |
261 for (MediaStreamTrackVector::iterator iter = m_videoTracks.begin(); iter != m_videoTracks.end(); ++iter) { | 261 for (MediaStreamTrackVector::iterator iter = m_videoTracks.begin(); iter != m_videoTracks.end(); ++iter) { |
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
420 | 420 |
421 URLRegistry& MediaStream::registry() const | 421 URLRegistry& MediaStream::registry() const |
422 { | 422 { |
423 return MediaStreamRegistry::registry(); | 423 return MediaStreamRegistry::registry(); |
424 } | 424 } |
425 | 425 |
426 DEFINE_TRACE(MediaStream) | 426 DEFINE_TRACE(MediaStream) |
427 { | 427 { |
428 visitor->trace(m_audioTracks); | 428 visitor->trace(m_audioTracks); |
429 visitor->trace(m_videoTracks); | 429 visitor->trace(m_videoTracks); |
430 visitor->trace(m_descriptor); | |
430 visitor->trace(m_scheduledEvents); | 431 visitor->trace(m_scheduledEvents); |
431 RefCountedGarbageCollectedEventTargetWithInlineData<MediaStream>::trace(visi tor); | 432 RefCountedGarbageCollectedEventTargetWithInlineData<MediaStream>::trace(visi tor); |
432 ContextLifecycleObserver::trace(visitor); | 433 ContextLifecycleObserver::trace(visitor); |
433 } | 434 } |
434 | 435 |
435 } // namespace blink | 436 } // namespace blink |
OLD | NEW |