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

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

Powered by Google App Engine
This is Rietveld 408576698