Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_DEPENDENCY_FACTORY_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_DEPENDENCY_FACTORY_H_ |
| 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_DEPENDENCY_FACTORY_H_ | 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_DEPENDENCY_FACTORY_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 39 } | 39 } |
| 40 | 40 |
| 41 namespace content { | 41 namespace content { |
| 42 | 42 |
| 43 class IpcNetworkManager; | 43 class IpcNetworkManager; |
| 44 class IpcPacketSocketFactory; | 44 class IpcPacketSocketFactory; |
| 45 class VideoCaptureImplManager; | 45 class VideoCaptureImplManager; |
| 46 class WebRtcAudioDeviceImpl; | 46 class WebRtcAudioDeviceImpl; |
| 47 struct StreamDeviceInfo; | 47 struct StreamDeviceInfo; |
| 48 | 48 |
| 49 #if defined(GOOGLE_TV) | |
| 50 class RTCVideoDecoderFactoryTv; | |
| 51 #endif | |
| 52 | |
| 49 // Object factory for RTC MediaStreams and RTC PeerConnections. | 53 // Object factory for RTC MediaStreams and RTC PeerConnections. |
| 50 class CONTENT_EXPORT MediaStreamDependencyFactory | 54 class CONTENT_EXPORT MediaStreamDependencyFactory |
| 51 : NON_EXPORTED_BASE(public base::NonThreadSafe) { | 55 : NON_EXPORTED_BASE(public base::NonThreadSafe) { |
| 52 public: | 56 public: |
| 53 // MediaSourcesCreatedCallback is used in CreateNativeMediaSources. | 57 // MediaSourcesCreatedCallback is used in CreateNativeMediaSources. |
| 54 typedef base::Callback<void(WebKit::WebMediaStream* description, | 58 typedef base::Callback<void(WebKit::WebMediaStream* description, |
| 55 bool live)> MediaSourcesCreatedCallback; | 59 bool live)> MediaSourcesCreatedCallback; |
| 56 MediaStreamDependencyFactory( | 60 MediaStreamDependencyFactory( |
| 57 VideoCaptureImplManager* vc_manager, | 61 VideoCaptureImplManager* vc_manager, |
| 58 P2PSocketDispatcher* p2p_socket_dispatcher); | 62 P2PSocketDispatcher* p2p_socket_dispatcher); |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 127 int sdp_mline_index, | 131 int sdp_mline_index, |
| 128 const std::string& sdp); | 132 const std::string& sdp); |
| 129 | 133 |
| 130 WebRtcAudioDeviceImpl* GetWebRtcAudioDevice(); | 134 WebRtcAudioDeviceImpl* GetWebRtcAudioDevice(); |
| 131 | 135 |
| 132 // Stop the audio source for local audio tracks. | 136 // Stop the audio source for local audio tracks. |
| 133 // TODO(xians): Remove this function if each audio track takes care of their | 137 // TODO(xians): Remove this function if each audio track takes care of their |
| 134 // own source. | 138 // own source. |
| 135 void StopLocalAudioSource(const WebKit::WebMediaStream& description); | 139 void StopLocalAudioSource(const WebKit::WebMediaStream& description); |
| 136 | 140 |
| 141 #if defined(GOOGLE_TV) | |
| 142 RTCVideoDecoderFactoryTv* decoder_factory_tv() { return decoder_factory_tv_; } | |
| 143 #endif | |
| 144 | |
| 137 protected: | 145 protected: |
| 138 // Asks the PeerConnection factory to create a Local MediaStream object. | 146 // Asks the PeerConnection factory to create a Local MediaStream object. |
| 139 virtual scoped_refptr<webrtc::MediaStreamInterface> | 147 virtual scoped_refptr<webrtc::MediaStreamInterface> |
| 140 CreateLocalMediaStream(const std::string& label); | 148 CreateLocalMediaStream(const std::string& label); |
| 141 | 149 |
| 142 // Asks the PeerConnection factory to create a Local Audio Source. | 150 // Asks the PeerConnection factory to create a Local Audio Source. |
| 143 virtual scoped_refptr<webrtc::AudioSourceInterface> | 151 virtual scoped_refptr<webrtc::AudioSourceInterface> |
| 144 CreateLocalAudioSource( | 152 CreateLocalAudioSource( |
| 145 const webrtc::MediaConstraintsInterface* constraints); | 153 const webrtc::MediaConstraintsInterface* constraints); |
| 146 | 154 |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 194 void DeleteIpcNetworkManager(); | 202 void DeleteIpcNetworkManager(); |
| 195 void CleanupPeerConnectionFactory(); | 203 void CleanupPeerConnectionFactory(); |
| 196 | 204 |
| 197 // We own network_manager_, must be deleted on the worker thread. | 205 // We own network_manager_, must be deleted on the worker thread. |
| 198 // The network manager uses |p2p_socket_dispatcher_|. | 206 // The network manager uses |p2p_socket_dispatcher_|. |
| 199 IpcNetworkManager* network_manager_; | 207 IpcNetworkManager* network_manager_; |
| 200 scoped_ptr<IpcPacketSocketFactory> socket_factory_; | 208 scoped_ptr<IpcPacketSocketFactory> socket_factory_; |
| 201 | 209 |
| 202 scoped_refptr<webrtc::PeerConnectionFactoryInterface> pc_factory_; | 210 scoped_refptr<webrtc::PeerConnectionFactoryInterface> pc_factory_; |
| 203 | 211 |
| 212 #if defined(GOOGLE_TV) | |
| 213 // |pc_factory_| will hold the ownership of this object, and |pc_factory_| | |
| 214 // outlives this object. Thus weak pointer is sufficient. | |
|
ycheo (away)
2013/05/14 13:28:09
weak pointer?
wonsik
2013/05/14 14:18:55
raw pointer is considered weak.
| |
| 215 RTCVideoDecoderFactoryTv* decoder_factory_tv_; | |
| 216 #endif | |
| 217 | |
| 204 scoped_refptr<VideoCaptureImplManager> vc_manager_; | 218 scoped_refptr<VideoCaptureImplManager> vc_manager_; |
| 205 scoped_refptr<P2PSocketDispatcher> p2p_socket_dispatcher_; | 219 scoped_refptr<P2PSocketDispatcher> p2p_socket_dispatcher_; |
| 206 scoped_refptr<WebRtcAudioDeviceImpl> audio_device_; | 220 scoped_refptr<WebRtcAudioDeviceImpl> audio_device_; |
| 207 | 221 |
| 208 // PeerConnection threads. signaling_thread_ is created from the | 222 // PeerConnection threads. signaling_thread_ is created from the |
| 209 // "current" chrome thread. | 223 // "current" chrome thread. |
| 210 talk_base::Thread* signaling_thread_; | 224 talk_base::Thread* signaling_thread_; |
| 211 talk_base::Thread* worker_thread_; | 225 talk_base::Thread* worker_thread_; |
| 212 base::Thread chrome_worker_thread_; | 226 base::Thread chrome_worker_thread_; |
| 213 | 227 |
| 214 DISALLOW_COPY_AND_ASSIGN(MediaStreamDependencyFactory); | 228 DISALLOW_COPY_AND_ASSIGN(MediaStreamDependencyFactory); |
| 215 }; | 229 }; |
| 216 | 230 |
| 217 } // namespace content | 231 } // namespace content |
| 218 | 232 |
| 219 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_DEPENDENCY_FACTORY_H_ | 233 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_DEPENDENCY_FACTORY_H_ |
| OLD | NEW |