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

Side by Side Diff: media/video/capture/mac/video_capture_device_mac.mm

Issue 8177008: Adding VideoCaptureDevice for Mac. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Added PostQuitTask to unittest. Created 9 years, 2 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 (c) 2011 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/video/capture/mac/video_capture_device_mac.h"
6
7 #import <QTKit/QTKit.h>
8
9 #include "base/logging.h"
10 #include "base/time.h"
11 #include "media/video/capture/mac/video_capture_device_mac_qtkit.h"
12
13 namespace media {
14
15 void VideoCaptureDevice::GetDeviceNames(Names* device_names) {
16 // Loop through all available devices and add to |device_names|.
17 device_names->clear();
18 // TODO(mflodman) Return name and id as NSArray* instead of QTCaptureDevice*.
dmac 2011/10/17 17:02:29 NIT: I usually expect a blank line before a commen
mflodman_chromium_OOO 2011/10/17 18:40:38 Done.
19 for (QTCaptureDevice* device in [VideoCaptureDeviceMacQTKit deviceNames]) {
20 Name name;
dmac 2011/10/17 17:02:29 NIT: would be nice if name was a class that just h
mflodman_chromium_OOO 2011/10/17 18:40:38 That is a really good point. I won't do anything a
21 NSString* qt_device_name = [device localizedDisplayName];
22 name.device_name = [qt_device_name UTF8String];
23 NSString* qt_unique_id = [device uniqueID];
24 name.unique_id = [qt_unique_id UTF8String];
25 device_names->push_back(name);
26 }
27 }
28
29 VideoCaptureDevice* VideoCaptureDevice::Create(const Name& device_name) {
30 VideoCaptureDeviceMac* capture_device =
31 new VideoCaptureDeviceMac(device_name);
32 if (!capture_device->Init()) {
33 LOG(ERROR) << "Could not initialize VideoCaptureDevice.";
34 delete capture_device;
35 return NULL;
dmac 2011/10/17 17:02:29 NIT: I would assign capture_device to NULL here an
mflodman_chromium_OOO 2011/10/17 18:40:38 Done.
36 }
37 return capture_device;
38 }
39
40 VideoCaptureDeviceMac::VideoCaptureDeviceMac(const Name& device_name)
41 : device_name_(device_name),
42 observer_(NULL),
43 state_(kNotInitialized),
44 capture_device_(NULL) {
dmac 2011/10/17 17:02:29 capture_device_ should be initiailized to nil not
mflodman_chromium_OOO 2011/10/17 18:40:38 Done.
45 }
46
47 VideoCaptureDeviceMac::~VideoCaptureDeviceMac() {
48 [capture_device_ release];
49 }
50
51 void VideoCaptureDeviceMac::Allocate(int width, int height, int frame_rate,
52 EventHandler* observer) {
53 if (state_ != kIdle) {
54 return;
55 }
56 observer_ = observer;
57 NSString* deviceId =
58 [NSString stringWithUTF8String:device_name_.unique_id.c_str()];
59
60 if (![capture_device_ setCaptureDevice:deviceId]) {
61 SetErrorState("Could not open capture device.");
62 return;
63 }
64 if ([capture_device_ setCaptureHeight:height
dmac 2011/10/17 17:02:29 NIT: normally we would say if (![capture... instea
mflodman_chromium_OOO 2011/10/17 18:40:38 Done.
65 width:width
66 frameRate:frame_rate] == NO) {
67 SetErrorState("Could not configure capture device.");
68 return;
69 }
70
71 state_ = kAllocated;
72 Capability current_settings;
dmac 2011/10/17 17:02:29 NIT: again, if you are playing in the future, it w
mflodman_chromium_OOO 2011/10/17 18:40:38 Will do.
73 current_settings.color = kARGB;
74 current_settings.width = width;
75 current_settings.height = height;
76 current_settings.frame_rate = frame_rate;
77
78 observer_->OnFrameInfo(current_settings);
79 }
80
81 void VideoCaptureDeviceMac::Start() {
82 DCHECK_EQ(state_, kAllocated);
83 if (![capture_device_ startCapture]) {
84 SetErrorState("Could not start capture device.");
85 return;
86 }
87 state_ = kCapturing;
88 }
89
90 void VideoCaptureDeviceMac::Stop() {
91 DCHECK_EQ(state_, kCapturing);
92 [capture_device_ stopCapture];
93 state_ = kAllocated;
94 }
95
96 void VideoCaptureDeviceMac::DeAllocate() {
97 if (state_ != kAllocated && state_ != kCapturing) {
98 return;
99 }
100 if (state_ == kCapturing) {
101 [capture_device_ stopCapture];
102 }
103 [capture_device_ setCaptureDevice:nil];
104 state_ = kIdle;
105 }
106
107 const VideoCaptureDevice::Name& VideoCaptureDeviceMac::device_name() {
108 return device_name_;
dmac 2011/10/17 17:02:29 NIT: worth inlining?
mflodman_chromium_OOO 2011/10/17 18:40:38 After this CL, I'll check if this can be removed c
109 }
110
111 bool VideoCaptureDeviceMac::Init() {
112 DCHECK_EQ(state_, kNotInitialized);
113
114 Names device_names;
115 GetDeviceNames(&device_names);
116 for (Names::iterator it = device_names.begin();
117 it != device_names.end();
118 ++it) {
119 if (device_name_.unique_id == it->unique_id) {
120 capture_device_ =
121 [[VideoCaptureDeviceMacQTKit alloc] initWithFrameReceiver:this];
122 if (!capture_device_) {
123 return false;
124 }
125 state_ = kIdle;
126 return true;
127 }
128 }
129 return false;
130 }
131
132 void VideoCaptureDeviceMac::ReceiveFrame(const uint8* video_frame,
133 int video_frame_length,
134 const Capability& frame_info) {
135 observer_->OnIncomingCapturedFrame(video_frame, video_frame_length,
136 base::Time::Now());
137 }
138
139 void VideoCaptureDeviceMac::SetErrorState(const std::string& reason) {
140 DLOG(ERROR) << reason;
141 state_ = kError;
142 observer_->OnError();
143 }
144
145 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698