/PhotographyKit

A swift library for quickly integrating a built in camera session into your app.

Primary LanguageSwiftMIT LicenseMIT

PhotographyKit

A swift library for quickly integrating a built in camera session into your app.

Installing with cocoapods

pod 'PhotographyKit'

Quick start

First start by creating a PhotographyKitDelegate, this will handle the result of any images being captured

extension CameraViewController: PhotographyKitDelegate {
    
    func didCaptureImage(image: UIImage) {
        imageView.image = image
    }
    
    
    func didStartRecordingVideo() {
        print("Recording started...")
    }
    
    
    func didFinishRecordingVideo(url: URL) {
        print("Finished recording video to \(url.absoluteString)")
    }
    
    
    func didFailRecordingVideo(error: Error) {
        print("Failed recording video to \(url.absoluteString) with error: \(error.localizedDescription)")
    }
    
}

Once you have your delegate setup, you can initialize your PhotographyKit object. The initializer takes 2 arguments:

  • A view that will be used to display your camera preview
  • The delegate which we declare above.
  • Be aware that if your PhotographyKit object allows video then you will need microphone permissions
do {
    camera = try PhotographyKit(view: captureView, delegate: self, allowsVideo: true)
} catch let error {
    showPhotographyKitError(error as? PhotographyKitError)
}

Once this is done you can toggle flash, switch cameras, take photos and record videos

try? camera.takePhoto()
try? camera.startVideoRecording(maxLength: 15)
camera.endVideoRecording
try? camera.switchCamera()
try? camera.toggleFlash(.auto)