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

Side by Side Diff: media/capture/video/chromeos/video_capture_device_factory_chromeos.cc

Issue 2837273004: media: add video capture device for ARC++ camera HAL v3 (Closed)
Patch Set: address wuchengli's and chfremer's comments Created 3 years, 7 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
OLDNEW
(Empty)
1 // Copyright 2017 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 #include "media/capture/video/chromeos/video_capture_device_factory_chromeos.h"
6
7 #include "base/files/file_util.h"
8 #include "media/capture/video/linux/video_capture_device_factory_linux.h"
9
10 namespace media {
11
12 VideoCaptureDeviceFactoryChromeOS::VideoCaptureDeviceFactoryChromeOS(
13 scoped_refptr<base::SingleThreadTaskRunner> task_runner_for_screen_observer)
14 : task_runner_for_screen_observer_(task_runner_for_screen_observer),
15 module_thread_("CameraModuleThread") {}
16
17 VideoCaptureDeviceFactoryChromeOS::~VideoCaptureDeviceFactoryChromeOS() {}
18
19 bool VideoCaptureDeviceFactoryChromeOS::Init() {
20 if (!module_thread_.Start()) {
21 LOG(ERROR) << "Module thread failed to start";
22 return false;
23 }
24 camera_hal_delegate_ = new CameraHalDelegate(module_thread_.task_runner());
25 return camera_hal_delegate_->StartCameraModuleIpc();
26 }
27
28 std::unique_ptr<VideoCaptureDevice>
29 VideoCaptureDeviceFactoryChromeOS::CreateDevice(
30 const VideoCaptureDeviceDescriptor& device_descriptor) {
31 DCHECK(thread_checker_.CalledOnValidThread());
32 DCHECK(camera_hal_delegate_);
33 return camera_hal_delegate_->CreateDevice(task_runner_for_screen_observer_,
34 device_descriptor);
35 }
36
37 void VideoCaptureDeviceFactoryChromeOS::GetSupportedFormats(
38 const VideoCaptureDeviceDescriptor& device_descriptor,
39 VideoCaptureFormats* supported_formats) {
40 DCHECK(thread_checker_.CalledOnValidThread());
41 DCHECK(camera_hal_delegate_);
42 camera_hal_delegate_->GetSupportedFormats(device_descriptor,
43 supported_formats);
44 }
45
46 void VideoCaptureDeviceFactoryChromeOS::GetDeviceDescriptors(
47 VideoCaptureDeviceDescriptors* device_descriptors) {
48 DCHECK(thread_checker_.CalledOnValidThread());
49 DCHECK(camera_hal_delegate_);
50 camera_hal_delegate_->GetDeviceDescriptors(device_descriptors);
51 }
52
53 #if defined(OS_CHROMEOS)
54 const base::FilePath kArcCamera3Service("/usr/bin/arc_camera3_service");
55
56 // static
57 VideoCaptureDeviceFactory*
58 VideoCaptureDeviceFactory::CreateVideoCaptureDeviceFactory(
59 scoped_refptr<base::SingleThreadTaskRunner>
60 task_runner_for_screen_observer) {
61 if (base::PathExists(kArcCamera3Service)) {
62 auto factory = base::MakeUnique<VideoCaptureDeviceFactoryChromeOS>(
63 task_runner_for_screen_observer);
64 if (!factory->Init()) {
65 return nullptr;
66 }
67 return factory.release();
68 } else {
69 return new VideoCaptureDeviceFactoryLinux(task_runner_for_screen_observer);
70 }
71 }
72 #endif
73
74 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698