photo credit: fveronesi1 Little Swift at nest – Kakum NP – Ghana 14_S4E2783 via photopin (license)
FlexibleAVCapture provides a kind of AV capture view controller with flexible camera frame. It includes default capture settings, preview layer, buttons, tap-gesture focusing, pinch-gesture zooming, and so on.
Screen Capture
Example
You can try 2 examples. One is included in the pods and the another is on App Store.
These 2 are almost same, but the one on App Store is more practical and better reference.
Pods Example
To run the example project, clone the repo, and run pod install
from the Example directory first.
Flex Camera on App Store
You can download “Flex Camera” app from App Store.
See the fllowing post for its summary.
[iOS App] Flex Camera – Take videos with unique shape!
Installation
FlexibleAVCapture is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod 'FlexibleAVCapture'
Usage
Your view controller should satisfy the following conditions:
- Adopt
FlexibleAVCaptureDelegate
protocol and implementdidCapture(withFileURL fileURL: URL)
function. - Create an
FlexibleAVCaptureViewController
object and set itsdelegate
.
import UIKit
import FlexibleAVCapture
class ViewController: UIViewController, FlexibleAVCaptureDelegate {
let flexibleAVCaptureVC: FlexibleAVCaptureViewController = FlexibleAVCaptureViewController()
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
self.flexibleAVCaptureVC.delegate = self
self.present(flexibleAVCaptureVC, animated: true, completion: nil)
}
func didCapture(withFileURL fileURL: URL) {
print(fileURL)
}
}
API
API Informations in this section are for version 2.1.0.
Visit CocoaPods for the latest version.
FlexibleAVCaptureViewController
An object that manages capture settings and a session. It also displays a preview layer and handles user interactions.
Topics | API |
---|---|
Initializing | init() -> FlexibleAVCaptureViewController Initializes a FlexibleAVCaptureViewController object with back camera. |
init(cameraPosition: AVCaptureDevice.Position) -> FlexibleAVCaptureViewController Initializes a FlexibleAVCaptureViewController object to use back camera or front camera. |
|
Managing Interactions | var delegate: FlexibleAVCaptureDelegate? The object that acts as the delegate of the flexible AV capture view. |
Managing Capture Settings | var allowsResizing: Bool A Boolean value that indicates whether users can resize camera frame. Allowing this feature hides a resizing slider and resizing buttons. The default value of this property is true. |
var allowsReversingCamera: Bool A Boolean value that indicates whether users can make the camera position reversed. Allowing this feature hides a camera-reversing button. The default value of this property is true. |
|
var allowsSoundEffect: Bool A Boolean value that indicates whether sound effect rings at the beginning and the ending of video recording. The default value of this property is true. |
|
var cameraPosition: AVCaptureDevice.Position The camera position being used to capture video. Back camera will be used by default. (This is a get-only property.) |
|
var maximumRecordDuration: CMTime The longest duration allowed for the recording. The default value of this property is invalid, which indicates no limit. |
|
var minimumFrameRatio: CGFloat The ratio of the vertical(or horizontal) edge length in the full frame when the wideset(or tallest) frame is applied. The default value of this property is 0.34. |
|
var videoQuality: AVCaptureSession.Preset A constant value indicating the quality level or bit rate of the output. The default value of this property is medium. (This is a get-only property.) |
|
func canSetVideoQuality(_ videoQuality: AVCaptureSession.Preset) -> Bool Returns a Boolean value that indicates whether the receiver can use the given preset. |
|
func forceResize(withResizingParameter resizingParameter: Float) -> Void Recieve a Float value between 0.0 and 1.0 and resize the camera frame using the value. |
|
func reverseCameraPosition() -> Void Change the camera position to the oppsite of the current position. |
|
func setVideoQuality(_ videoQuality: AVCaptureSession.Preset) -> Void Change the video capturing quality. |
|
Replasing Default UI | func replaceFullFramingButton(with button: UIButton) -> Void Replace the existing full-framing button. |
func replaceResizingSlider(with slider: UISlider) -> Void Replace the existing resizing slider. The slider’s range will be forced to be 0.0 to 1.0. |
|
func replaceRecordButton(with button: UIButton) -> Void Replace the existing record button. |
|
func replaceReverseButton(with button: UIButton) -> Void Replace the existing camera-position-reversing button. |
|
func replaceSquareFramingButton(with button: UIButton) -> Void Replace the existing square-framing button. |
|
func replaceTallFramingButton(with button: UIButton) -> Void Replace the existing tall-framing button. |
|
func replaceWideFramingButton(with button: UIButton) -> Void Replace the existing wide-framing button. |
FlexibleAVCaptureDelegate
Defines an interface for delegates of FlexibleAVCaptureViewController to respond to events that occur in the process of recording a single file.
The delegate of an FlexibleAVCaptureViewController object must adopt the FlexibleAVCaptureDelegate protocol.
Topics | API |
---|---|
Delegate Methods | didCapture(withFileURL fileURL: URL) -> Void Informs the delegate when all pending data has been written to an output file. Required. |
Source Code on GitHub
You can see the whole source code of FlexibleAVCapture on GitHub.
https://github.com/hahnah/FlexibleAVCapture
0件のコメント