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 // VideoCaptureManager is used to open/close, start/stop, enumerate available | 5 // VideoCaptureManager is used to open/close, start/stop, enumerate available |
6 // video capture devices, and manage VideoCaptureController's. | 6 // video capture devices, and manage VideoCaptureController's. |
7 // All functions are expected to be called from Browser::IO thread. Some helper | 7 // All functions are expected to be called from Browser::IO thread. Some helper |
8 // functions (*OnDeviceThread) will dispatch operations to the device thread. | 8 // functions (*OnDeviceThread) will dispatch operations to the device thread. |
9 // VideoCaptureManager will open OS dependent instances of VideoCaptureDevice. | 9 // VideoCaptureManager will open OS dependent instances of VideoCaptureDevice. |
10 // A device can only be opened once. | 10 // A device can only be opened once. |
(...skipping 234 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
245 | 245 |
246 // Returns true if the current operation needs to be preempted by a call to | 246 // Returns true if the current operation needs to be preempted by a call to |
247 // InitializeCaptureDeviceApiOnUIThread. | 247 // InitializeCaptureDeviceApiOnUIThread. |
248 // Called on the IO thread. | 248 // Called on the IO thread. |
249 bool NeedToInitializeCaptureDeviceApi(MediaStreamType stream_type); | 249 bool NeedToInitializeCaptureDeviceApi(MediaStreamType stream_type); |
250 | 250 |
251 // Called on the IO thread to do async initialization of the capture api. | 251 // Called on the IO thread to do async initialization of the capture api. |
252 // Once initialization is done, and_then will be run on the IO thread. | 252 // Once initialization is done, and_then will be run on the IO thread. |
253 void InitializeCaptureDeviceApiOnUIThread(const base::Closure& and_then); | 253 void InitializeCaptureDeviceApiOnUIThread(const base::Closure& and_then); |
254 | 254 |
255 // Due to initialization issues with AVFoundation and QTKit on Mac, we need | 255 // Due to initialization issues with AVFoundation on Mac, we need |
256 // to make sure we initialize the APIs on the UI thread before we can reliably | 256 // to make sure we initialize the APIs on the UI thread before we can reliably |
257 // use them. This variable is only checked and set on the IO thread. | 257 // use them. This variable is only checked and set on the IO thread. |
258 bool capture_device_api_initialized_ = false; | 258 bool capture_device_api_initialized_ = false; |
259 #endif | 259 #endif |
260 | 260 |
261 // The message loop of media stream device thread, where VCD's live. | 261 // The message loop of media stream device thread, where VCD's live. |
262 scoped_refptr<base::SingleThreadTaskRunner> device_task_runner_; | 262 scoped_refptr<base::SingleThreadTaskRunner> device_task_runner_; |
263 | 263 |
264 // Only accessed on Browser::IO thread. | 264 // Only accessed on Browser::IO thread. |
265 MediaStreamProviderListener* listener_; | 265 MediaStreamProviderListener* listener_; |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
354 // Map used by DesktopCapture. | 354 // Map used by DesktopCapture. |
355 std::map<media::VideoCaptureSessionId, gfx::NativeViewId> | 355 std::map<media::VideoCaptureSessionId, gfx::NativeViewId> |
356 notification_window_ids_; | 356 notification_window_ids_; |
357 | 357 |
358 DISALLOW_COPY_AND_ASSIGN(VideoCaptureManager); | 358 DISALLOW_COPY_AND_ASSIGN(VideoCaptureManager); |
359 }; | 359 }; |
360 | 360 |
361 } // namespace content | 361 } // namespace content |
362 | 362 |
363 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_VIDEO_CAPTURE_MANAGER_H_ | 363 #endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_VIDEO_CAPTURE_MANAGER_H_ |
OLD | NEW |