Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(187)

Side by Side Diff: content/renderer/media/media_stream_impl.h

Issue 131763002: Adds MediaStreamSource, MediaStreamAudioSource and MediaStreamVideoCaptureDeviceSource (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased. Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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_IMPL_H_ 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_
6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
(...skipping 12 matching lines...) Expand all
23 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h" 23 #include "third_party/WebKit/public/platform/WebMediaStreamSource.h"
24 #include "third_party/WebKit/public/platform/WebVector.h" 24 #include "third_party/WebKit/public/platform/WebVector.h"
25 #include "third_party/WebKit/public/web/WebUserMediaClient.h" 25 #include "third_party/WebKit/public/web/WebUserMediaClient.h"
26 #include "third_party/WebKit/public/web/WebUserMediaRequest.h" 26 #include "third_party/WebKit/public/web/WebUserMediaRequest.h"
27 #include "third_party/libjingle/source/talk/app/webrtc/mediastreaminterface.h" 27 #include "third_party/libjingle/source/talk/app/webrtc/mediastreaminterface.h"
28 28
29 namespace content { 29 namespace content {
30 class MediaStreamAudioRenderer; 30 class MediaStreamAudioRenderer;
31 class MediaStreamDependencyFactory; 31 class MediaStreamDependencyFactory;
32 class MediaStreamDispatcher; 32 class MediaStreamDispatcher;
33 class MediaStreamSourceExtraData; 33 class MediaStreamSource;
34 class WebRtcAudioRenderer; 34 class WebRtcAudioRenderer;
35 class WebRtcLocalAudioRenderer; 35 class WebRtcLocalAudioRenderer;
36 36
37 // MediaStreamImpl is a delegate for the Media Stream API messages used by 37 // MediaStreamImpl is a delegate for the Media Stream API messages used by
38 // WebKit. It ties together WebKit, native PeerConnection in libjingle and 38 // WebKit. It ties together WebKit, native PeerConnection in libjingle and
39 // MediaStreamManager (via MediaStreamDispatcher and MediaStreamDispatcherHost) 39 // MediaStreamManager (via MediaStreamDispatcher and MediaStreamDispatcherHost)
40 // in the browser process. It must be created, called and destroyed on the 40 // in the browser process. It must be created, called and destroyed on the
41 // render thread. 41 // render thread.
42 // MediaStreamImpl have weak pointers to a MediaStreamDispatcher. 42 // MediaStreamImpl have weak pointers to a MediaStreamDispatcher.
43 class CONTENT_EXPORT MediaStreamImpl 43 class CONTENT_EXPORT MediaStreamImpl
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 89
90 // RenderViewObserver OVERRIDE 90 // RenderViewObserver OVERRIDE
91 virtual void FrameDetached(blink::WebFrame* frame) OVERRIDE; 91 virtual void FrameDetached(blink::WebFrame* frame) OVERRIDE;
92 virtual void FrameWillClose(blink::WebFrame* frame) OVERRIDE; 92 virtual void FrameWillClose(blink::WebFrame* frame) OVERRIDE;
93 93
94 protected: 94 protected:
95 void OnLocalSourceStop(const blink::WebMediaStreamSource& source); 95 void OnLocalSourceStop(const blink::WebMediaStreamSource& source);
96 96
97 void OnLocalMediaStreamStop(const std::string& label); 97 void OnLocalMediaStreamStop(const std::string& label);
98 98
99 // Callback function triggered when all native (libjingle) versions of the
100 // underlying media sources have been created and started.
101 // |web_stream| is a raw pointer to the web_stream in
102 // UserMediaRequests::web_stream for which the underlying sources have been
103 // created.
104 void OnCreateNativeSourcesComplete(
105 blink::WebMediaStream* web_stream,
106 bool request_succeeded);
107
108 // This function is virtual for test purposes. A test can override this to 99 // This function is virtual for test purposes. A test can override this to
109 // test requesting local media streams. The function notifies WebKit that the 100 // test requesting local media streams. The function notifies WebKit that the
110 // |request| have completed and generated the MediaStream |stream|. 101 // |request| have completed and generated the MediaStream |stream|.
111 virtual void CompleteGetUserMediaRequest( 102 virtual void CompleteGetUserMediaRequest(
112 const blink::WebMediaStream& stream, 103 const blink::WebMediaStream& stream,
113 blink::WebUserMediaRequest* request_info, 104 blink::WebUserMediaRequest* request_info,
114 bool request_succeeded); 105 bool request_succeeded);
115 106
116 // Returns the WebKit representation of a MediaStream given an URL. 107 // Returns the WebKit representation of a MediaStream given an URL.
117 // This is virtual for test purposes. 108 // This is virtual for test purposes.
118 virtual blink::WebMediaStream GetMediaStream(const GURL& url); 109 virtual blink::WebMediaStream GetMediaStream(const GURL& url);
119 110
120 private: 111 private:
121 // Structure for storing information about a WebKit request to create a 112 // Class for storing information about a WebKit request to create a
122 // MediaStream. 113 // MediaStream.
123 struct UserMediaRequestInfo { 114 class UserMediaRequestInfo
115 : public base::SupportsWeakPtr<UserMediaRequestInfo> {
116 public:
117 typedef base::Callback<void(UserMediaRequestInfo* request_info,
118 bool request_succeeded)> ResourcesReady;
119
124 UserMediaRequestInfo(int request_id, 120 UserMediaRequestInfo(int request_id,
125 blink::WebFrame* frame, 121 blink::WebFrame* frame,
126 const blink::WebUserMediaRequest& request, 122 const blink::WebUserMediaRequest& request,
127 bool enable_automatic_output_device_selection); 123 bool enable_automatic_output_device_selection);
128 ~UserMediaRequestInfo(); 124 ~UserMediaRequestInfo();
129 int request_id; 125 int request_id;
130 // True if MediaStreamDispatcher has generated the stream, see 126 // True if MediaStreamDispatcher has generated the stream, see
131 // OnStreamGenerated. 127 // OnStreamGenerated.
132 bool generated; 128 bool generated;
133 const bool enable_automatic_output_device_selection; 129 const bool enable_automatic_output_device_selection;
134 blink::WebFrame* frame; // WebFrame that requested the MediaStream. 130 blink::WebFrame* frame; // WebFrame that requested the MediaStream.
135 blink::WebMediaStream web_stream; 131 blink::WebMediaStream web_stream;
136 blink::WebUserMediaRequest request; 132 blink::WebUserMediaRequest request;
137 std::vector<blink::WebMediaStreamSource> sources; 133
134 void StartTrack(const blink::WebMediaStreamTrack& track,
135 const blink::WebMediaConstraints& constraints);
136
137 // Triggers |callback| when all sources used in this request has either
138 // successfully started, or a source has failed to start.
139 void CallbackonTracksStarted(const ResourcesReady& callback);
140
141 bool IsSourceUsed(const blink::WebMediaStreamSource& source) const;
142 void RemoveSource(const blink::WebMediaStreamSource& source);
143
144 bool IsAllSourcesRemoved() { return sources_.empty();}
145
146 private:
147 void OnTrackStarted(MediaStreamSource* source, bool success);
148 void CheckAllTracksStarted();
149
150 ResourcesReady ready_callback_;
151 bool request_failed_;
152 // Sources used in this request.
153 std::vector<blink::WebMediaStreamSource> sources_;
154 std::vector<MediaStreamSource*> sources_waiting_for_callback_;
138 }; 155 };
139 typedef ScopedVector<UserMediaRequestInfo> UserMediaRequests; 156 typedef ScopedVector<UserMediaRequestInfo> UserMediaRequests;
140 157
141 struct LocalStreamSource { 158 struct LocalStreamSource {
142 LocalStreamSource(blink::WebFrame* frame, 159 LocalStreamSource(blink::WebFrame* frame,
143 const blink::WebMediaStreamSource& source) 160 const blink::WebMediaStreamSource& source)
144 : frame(frame), source(source) { 161 : frame(frame), source(source) {
145 } 162 }
146 // |frame| is the WebFrame that requested |source|. NULL in unit tests. 163 // |frame| is the WebFrame that requested |source|. NULL in unit tests.
147 // TODO(perkj): Change so that |frame| is not NULL in unit tests. 164 // TODO(perkj): Change so that |frame| is not NULL in unit tests.
148 blink::WebFrame* frame; 165 blink::WebFrame* frame;
149 blink::WebMediaStreamSource source; 166 blink::WebMediaStreamSource source;
150 }; 167 };
151 typedef std::vector<LocalStreamSource> LocalStreamSources; 168 typedef std::vector<LocalStreamSource> LocalStreamSources;
152 169
153 // Creates a WebKit representation of stream sources based on 170 // Creates a WebKit representation of stream sources based on
154 // |devices| from the MediaStreamDispatcher. 171 // |devices| from the MediaStreamDispatcher.
155 void CreateWebKitSourceVector( 172 void InitializeSourceObject(
156 const std::string& label, 173 const StreamDeviceInfo& device,
174 blink::WebMediaStreamSource::Type type,
175 const blink::WebMediaConstraints& constraints,
176 blink::WebFrame* frame,
177 blink::WebMediaStreamSource* webkit_source);
178
179 void CreateVideoTracks(
157 const StreamDeviceInfoArray& devices, 180 const StreamDeviceInfoArray& devices,
158 blink::WebMediaStreamSource::Type type, 181 const blink::WebMediaConstraints& constraints,
159 blink::WebFrame* frame, 182 blink::WebVector<blink::WebMediaStreamTrack>* webkit_tracks,
160 blink::WebVector<blink::WebMediaStreamSource>& webkit_sources); 183 UserMediaRequestInfo* request);
184
185 void CreateAudioTracks(
186 const StreamDeviceInfoArray& devices,
187 const blink::WebMediaConstraints& constraints,
188 blink::WebVector<blink::WebMediaStreamTrack>* webkit_tracks,
189 UserMediaRequestInfo* request);
190
191 // Callback function triggered when all native versions of the
192 // underlying media sources and tracks have been created and started.
193 void OnCreateNativeTracksComplete(
194 UserMediaRequestInfo* request,
195 bool request_succeeded);
161 196
162 UserMediaRequestInfo* FindUserMediaRequestInfo(int request_id); 197 UserMediaRequestInfo* FindUserMediaRequestInfo(int request_id);
163 UserMediaRequestInfo* FindUserMediaRequestInfo( 198 UserMediaRequestInfo* FindUserMediaRequestInfo(
164 blink::WebMediaStream* web_stream);
165 UserMediaRequestInfo* FindUserMediaRequestInfo(
166 const blink::WebUserMediaRequest& request); 199 const blink::WebUserMediaRequest& request);
167 UserMediaRequestInfo* FindUserMediaRequestInfo(const std::string& label); 200 UserMediaRequestInfo* FindUserMediaRequestInfo(const std::string& label);
168 void DeleteUserMediaRequestInfo(UserMediaRequestInfo* request); 201 void DeleteUserMediaRequestInfo(UserMediaRequestInfo* request);
169 202
170 // Returns the source that use a device with |device.session_id| 203 // Returns the source that use a device with |device.session_id|
171 // and |device.device.id|. NULL if such source doesn't exist. 204 // and |device.device.id|. NULL if such source doesn't exist.
172 const blink::WebMediaStreamSource* FindLocalSource( 205 const blink::WebMediaStreamSource* FindLocalSource(
173 const StreamDeviceInfo& device) const; 206 const StreamDeviceInfo& device) const;
174 207
175 // Returns true if |source| exists in |user_media_requests_| 208 // Returns true if |source| exists in |user_media_requests_|
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
207 UserMediaRequests user_media_requests_; 240 UserMediaRequests user_media_requests_;
208 241
209 LocalStreamSources local_sources_; 242 LocalStreamSources local_sources_;
210 243
211 DISALLOW_COPY_AND_ASSIGN(MediaStreamImpl); 244 DISALLOW_COPY_AND_ASSIGN(MediaStreamImpl);
212 }; 245 };
213 246
214 } // namespace content 247 } // namespace content
215 248
216 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ 249 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698