OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 // MediaStreamManager is used to open media capture devices (video supported |
| 6 // now). Call flow: |
| 7 // 1. GenerateStream is called when a render process wants to use a capture |
| 8 // device. |
| 9 // 2. MediaStreamManager will ask MediaStreamDeviceSettings for permission to |
| 10 // use devices and for which device to use. |
| 11 // 3. MediaStreamDeviceSettings will request list(s) of available devices, the |
| 12 // requests will be relayed to the corresponding media device manager and the |
| 13 // result will be given to MediaStreamDeviceSettings. |
| 14 // 4. MediaStreamDeviceSettings will, by using user settings, pick devices which |
| 15 // devices to use and let MediaStreamManager know the result. |
| 16 // 5. MediaStreamManager will call the proper media device manager to open the |
| 17 // device and let the MediaStreamRequester know it has been done. |
| 18 |
| 19 #ifndef CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_MANAGER_H_ |
| 20 #define CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_MANAGER_H_ |
| 21 |
| 22 #include <list> |
| 23 #include <string> |
| 24 #include <vector> |
| 25 |
| 26 #include "base/lazy_instance.h" |
| 27 #include "base/memory/ref_counted.h" |
| 28 #include "content/browser/renderer_host/media/media_stream_provider.h" |
| 29 #include "content/browser/renderer_host/media/media_stream_settings_requester.h" |
| 30 #include "content/common/media/media_stream_options.h" |
| 31 |
| 32 namespace media_stream { |
| 33 |
| 34 class MediaStreamDeviceSettings; |
| 35 class MediaStreamRequester; |
| 36 class VideoCaptureManager; |
| 37 |
| 38 // MediaStreamManager is used to generate and close new media devices, not to |
| 39 // start the media flow. |
| 40 // The classes requesting new media streams are answered using |
| 41 // MediaStreamManager::Listener. |
| 42 class MediaStreamManager : public MediaStreamProviderListener, |
| 43 public SettingsRequester { |
| 44 public: |
| 45 typedef MediaStreamManager* (AccessorMethod)(); |
| 46 static MediaStreamManager* Get(); |
| 47 virtual ~MediaStreamManager(); |
| 48 |
| 49 // Used to access VideoCaptuerManager. |
| 50 VideoCaptureManager* GetVideoCaptureManager(); |
| 51 |
| 52 // GenerateStream opens new media devices according to |components|. The |
| 53 // request is identified using |label|, which is pointing to an already |
| 54 // created std::string. |
| 55 void GenerateStream(MediaStreamRequester* requester, int render_process_id, |
| 56 int render_view_id, const StreamOptions& options, |
| 57 const std::string& security_origin, std::string* label); |
| 58 |
| 59 // Cancels all non-finished GenerateStream request, i.e. request for which |
| 60 // StreamGenerated hasn't been called. |
| 61 void CancelRequests(MediaStreamRequester* requester); |
| 62 |
| 63 // Closes generated stream. |
| 64 void StopGeneratedStream(const std::string& label); |
| 65 |
| 66 // Implements MediaStreamProviderListener. |
| 67 virtual void Opened(MediaStreamType stream_type, int capture_session_id); |
| 68 virtual void Closed(MediaStreamType stream_type, int capture_session_id); |
| 69 virtual void DevicesEnumerated(MediaStreamType stream_type, |
| 70 const StreamDeviceInfoArray& devices); |
| 71 virtual void Error(MediaStreamType stream_type, int capture_session_id, |
| 72 MediaStreamProviderError error); |
| 73 |
| 74 // Implements SettingsRequester. |
| 75 virtual void GetDevices(const std::string& label, |
| 76 MediaStreamType stream_type); |
| 77 virtual void DevicesAccepted(const std::string& label, |
| 78 const StreamDeviceInfoArray& devices); |
| 79 virtual void SettingsError(const std::string& label); |
| 80 |
| 81 // Used by unit test to make sure fake devices are used instead of a real |
| 82 // devices, which is needed for server based testing. |
| 83 void UseFakeDevice(); |
| 84 |
| 85 private: |
| 86 // Contains all data needed to keep track of requests. |
| 87 struct DeviceRequest { |
| 88 DeviceRequest(MediaStreamRequester* requester, |
| 89 const StreamOptions& request_options) |
| 90 : requester(requester), |
| 91 options(request_options), |
| 92 state(kNumMediaStreamTypes, kNotRequested) { |
| 93 DCHECK(requester); |
| 94 } |
| 95 |
| 96 enum RequestState { |
| 97 kNotRequested = 0, |
| 98 kRequested, |
| 99 kOpening, |
| 100 kDone, |
| 101 kError |
| 102 }; |
| 103 |
| 104 MediaStreamRequester* requester; |
| 105 std::string label; |
| 106 StreamOptions options; |
| 107 std::vector<RequestState> state; |
| 108 StreamDeviceInfoArray audio_devices; |
| 109 StreamDeviceInfoArray video_devices; |
| 110 }; |
| 111 |
| 112 // Helpers. |
| 113 bool RequestDone(const MediaStreamManager::DeviceRequest& request) const; |
| 114 MediaStreamProvider* GetDeviceManager(MediaStreamType stream_type) const; |
| 115 |
| 116 // Private constructor to enforce singleton. |
| 117 friend struct base::DefaultLazyInstanceTraits<MediaStreamManager>; |
| 118 MediaStreamManager(); |
| 119 |
| 120 VideoCaptureManager* video_capture_manager_; |
| 121 // TODO(mflodman) Add AudioInputManager. |
| 122 |
| 123 // Keeps track of device types currently being enumerated to not enumerate |
| 124 // when not necessary. |
| 125 std::vector<bool> enumeration_in_progress_; |
| 126 |
| 127 // All non-closed request. |
| 128 typedef std::list<DeviceRequest> DeviceRequestList; |
| 129 DeviceRequestList requests_; |
| 130 |
| 131 MediaStreamDeviceSettings* device_settings_; |
| 132 |
| 133 DISALLOW_COPY_AND_ASSIGN(MediaStreamManager); |
| 134 }; |
| 135 |
| 136 } // namespace media_stream |
| 137 |
| 138 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_MANAGER_H_ |
OLD | NEW |