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

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 chfremer's comments Created 3 years, 6 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 camera_hal_delegate_->Reset();
19 module_thread_.Stop();
20 }
21
22 bool VideoCaptureDeviceFactoryChromeOS::Init() {
23 if (!module_thread_.Start()) {
24 LOG(ERROR) << "Module thread failed to start";
25 return false;
26 }
27 camera_hal_delegate_ = new CameraHalDelegate(module_thread_.task_runner());
28 return camera_hal_delegate_->StartCameraModuleIpc();
29 }
30
31 std::unique_ptr<VideoCaptureDevice>
32 VideoCaptureDeviceFactoryChromeOS::CreateDevice(
33 const VideoCaptureDeviceDescriptor& device_descriptor) {
34 DCHECK(thread_checker_.CalledOnValidThread());
35 DCHECK(camera_hal_delegate_);
36 return camera_hal_delegate_->CreateDevice(task_runner_for_screen_observer_,
37 device_descriptor);
38 }
39
40 void VideoCaptureDeviceFactoryChromeOS::GetSupportedFormats(
41 const VideoCaptureDeviceDescriptor& device_descriptor,
42 VideoCaptureFormats* supported_formats) {
43 DCHECK(thread_checker_.CalledOnValidThread());
44 DCHECK(camera_hal_delegate_);
45 camera_hal_delegate_->GetSupportedFormats(device_descriptor,
46 supported_formats);
47 }
48
49 void VideoCaptureDeviceFactoryChromeOS::GetDeviceDescriptors(
50 VideoCaptureDeviceDescriptors* device_descriptors) {
51 DCHECK(thread_checker_.CalledOnValidThread());
52 DCHECK(camera_hal_delegate_);
53 camera_hal_delegate_->GetDeviceDescriptors(device_descriptors);
54 }
55
56 #if defined(OS_CHROMEOS)
57 const base::FilePath kArcCamera3Service("/usr/bin/arc_camera3_service");
58
59 // static
60 VideoCaptureDeviceFactory*
61 VideoCaptureDeviceFactory::CreateVideoCaptureDeviceFactory(
62 scoped_refptr<base::SingleThreadTaskRunner>
63 task_runner_for_screen_observer) {
64 if (base::PathExists(kArcCamera3Service)) {
65 auto factory = base::MakeUnique<VideoCaptureDeviceFactoryChromeOS>(
66 task_runner_for_screen_observer);
67 if (!factory->Init()) {
68 return nullptr;
69 }
70 return factory.release();
71 } else {
72 return new VideoCaptureDeviceFactoryLinux(task_runner_for_screen_observer);
73 }
74 }
75 #endif
76
77 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698