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

Side by Side Diff: media/capture/video/linux/video_capture_device_chromeos.cc

Issue 2837273004: media: add video capture device for ARC++ camera HAL v3 (Closed)
Patch Set: RELAND: media: add video capture device for ARC++ camera HAL v3 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
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #include "media/capture/video/linux/video_capture_device_chromeos.h" 5 #include "media/capture/video/linux/video_capture_device_chromeos.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "base/memory/ref_counted.h" 11 #include "base/memory/ref_counted.h"
12 #include "base/single_thread_task_runner.h" 12 #include "base/single_thread_task_runner.h"
13 #include "base/threading/thread_task_runner_handle.h" 13 #include "base/threading/thread_task_runner_handle.h"
14 #include "ui/display/display.h" 14 #include "ui/display/display.h"
15 #include "ui/display/display_observer.h" 15 #include "ui/display/display_observer.h"
16 #include "ui/display/screen.h" 16 #include "ui/display/screen.h"
17 17
18 namespace media { 18 namespace media {
19 19
20 static CameraConfigChromeOS* GetCameraConfig() { 20 static CameraConfigChromeOS* GetCameraConfig() {
21 static CameraConfigChromeOS* config = new CameraConfigChromeOS(); 21 static CameraConfigChromeOS* config = new CameraConfigChromeOS();
22 return config; 22 return config;
23 } 23 }
24 24
25 // This is a delegate class used to transfer Display change events from the UI
26 // thread to the media thread.
27 class VideoCaptureDeviceChromeOS::ScreenObserverDelegate
28 : public display::DisplayObserver,
29 public base::RefCountedThreadSafe<ScreenObserverDelegate> {
30 public:
31 ScreenObserverDelegate(
32 VideoCaptureDeviceChromeOS* capture_device,
33 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner)
34 : capture_device_(capture_device),
35 ui_task_runner_(ui_task_runner),
36 capture_task_runner_(base::ThreadTaskRunnerHandle::Get()) {
37 ui_task_runner_->PostTask(
38 FROM_HERE,
39 base::Bind(&ScreenObserverDelegate::AddObserverOnUIThread, this));
40 }
41
42 void RemoveObserver() {
43 DCHECK(capture_task_runner_->BelongsToCurrentThread());
44 capture_device_ = NULL;
45 ui_task_runner_->PostTask(
46 FROM_HERE,
47 base::Bind(&ScreenObserverDelegate::RemoveObserverOnUIThread, this));
48 }
49
50 private:
51 friend class base::RefCountedThreadSafe<ScreenObserverDelegate>;
52
53 ~ScreenObserverDelegate() override { DCHECK(!capture_device_); }
54
55 void OnDisplayAdded(const display::Display& /*new_display*/) override {}
56 void OnDisplayRemoved(const display::Display& /*old_display*/) override {}
57 void OnDisplayMetricsChanged(const display::Display& display,
58 uint32_t metrics) override {
59 DCHECK(ui_task_runner_->BelongsToCurrentThread());
60 if (!(metrics & DISPLAY_METRIC_ROTATION))
61 return;
62 SendDisplayRotation(display);
63 }
64
65 void AddObserverOnUIThread() {
66 DCHECK(ui_task_runner_->BelongsToCurrentThread());
67 display::Screen* screen = display::Screen::GetScreen();
68 if (screen) {
69 screen->AddObserver(this);
70 SendDisplayRotation(screen->GetPrimaryDisplay());
71 }
72 }
73
74 void RemoveObserverOnUIThread() {
75 DCHECK(ui_task_runner_->BelongsToCurrentThread());
76 display::Screen* screen = display::Screen::GetScreen();
77 if (screen)
78 screen->RemoveObserver(this);
79 }
80
81 // Post the screen rotation change from the UI thread to capture thread
82 void SendDisplayRotation(const display::Display& display) {
83 DCHECK(ui_task_runner_->BelongsToCurrentThread());
84 capture_task_runner_->PostTask(
85 FROM_HERE,
86 base::Bind(&ScreenObserverDelegate::SendDisplayRotationOnCaptureThread,
87 this, display));
88 }
89
90 void SendDisplayRotationOnCaptureThread(const display::Display& display) {
91 DCHECK(capture_task_runner_->BelongsToCurrentThread());
92 if (capture_device_)
93 capture_device_->SetDisplayRotation(display);
94 }
95
96 VideoCaptureDeviceChromeOS* capture_device_;
97 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner_;
98 scoped_refptr<base::SingleThreadTaskRunner> capture_task_runner_;
99 DISALLOW_IMPLICIT_CONSTRUCTORS(ScreenObserverDelegate);
100 };
101
102 VideoCaptureDeviceChromeOS::VideoCaptureDeviceChromeOS( 25 VideoCaptureDeviceChromeOS::VideoCaptureDeviceChromeOS(
103 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner, 26 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner,
104 const VideoCaptureDeviceDescriptor& device_descriptor) 27 const VideoCaptureDeviceDescriptor& device_descriptor)
105 : VideoCaptureDeviceLinux(device_descriptor), 28 : VideoCaptureDeviceLinux(device_descriptor),
106 screen_observer_delegate_( 29 screen_observer_delegate_(
107 new ScreenObserverDelegate(this, ui_task_runner)), 30 new ScreenObserverDelegate(this, ui_task_runner)),
108 lens_facing_( 31 lens_facing_(
109 GetCameraConfig()->GetCameraFacing(device_descriptor.device_id, 32 GetCameraConfig()->GetCameraFacing(device_descriptor.device_id,
110 device_descriptor.model_id)), 33 device_descriptor.model_id)),
111 camera_orientation_( 34 camera_orientation_(
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
163 VideoCaptureDeviceLinux::SetRotation(rotation); 86 VideoCaptureDeviceLinux::SetRotation(rotation);
164 } 87 }
165 88
166 void VideoCaptureDeviceChromeOS::SetDisplayRotation( 89 void VideoCaptureDeviceChromeOS::SetDisplayRotation(
167 const display::Display& display) { 90 const display::Display& display) {
168 if (display.IsInternal()) 91 if (display.IsInternal())
169 SetRotation(display.rotation() * 90); 92 SetRotation(display.rotation() * 90);
170 } 93 }
171 94
172 } // namespace media 95 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698