Chromium Code Reviews| 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 |