1 // Copyright 2013 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.
5 #ifndef MEDIA_VIDEO_CAPTURE_MAC_PLATFORM_VIDEO_CAPTURING_MAC_H_
6 #define MEDIA_VIDEO_CAPTURE_MAC_PLATFORM_VIDEO_CAPTURING_MAC_H_
8 #import <Foundation/Foundation.h>
11 class VideoCaptureDeviceMac
;
14 // Protocol representing platform-dependent video capture on Mac, implemented
15 // by both QTKit and AVFoundation APIs.
16 @protocol PlatformVideoCapturingMac
<NSObject
>
18 // This method initializes the instance by calling NSObject |init| and registers
19 // internally a frame receiver at the same time. The frame receiver is supposed
20 // to be initialised before and outlive the VideoCapturingDeviceMac
22 - (id
)initWithFrameReceiver
:(media::VideoCaptureDeviceMac
*)frameReceiver
;
24 // Set the frame receiver. This method executes the registration in mutual
26 // TODO(mcasas): This method and stopCapture() are always called in sequence and
27 // this one is only used to clear the frameReceiver, investigate if both can be
29 - (void)setFrameReceiver
:(media::VideoCaptureDeviceMac
*)frameReceiver
;
31 // Sets which capture device to use by name passed as deviceId argument. The
32 // device names are usually obtained via VideoCaptureDevice::GetDeviceNames()
33 // method. This method will also configure all device properties except those in
34 // setCaptureHeight:widht:frameRate. If |deviceId| is nil, all potential
35 // configuration is torn down. Returns YES on sucess, NO otherwise.
36 - (BOOL
)setCaptureDevice
:(NSString
*)deviceId
;
38 // Configures the capture properties.
39 - (BOOL
)setCaptureHeight
:(int)height width
:(int)width frameRate
:(int)frameRate
;
41 // Start video capturing, register observers. Returns YES on sucess, NO
45 // Stops video capturing, unregisters observers.
50 #endif // MEDIA_VIDEO_CAPTURE_MAC_PLATFORM_VIDEO_CAPTURING_MAC_H_