Upvote:1
Aprove answer
//
// ViewController.swift
// CustomCamera
//
// Created by chunibyo on 2021/3/8.
//
import UIKit
import AVFoundation
import Vision
import VideoToolbox
class ViewController: UIViewController, AVCaptureVideoDataOutputSampleBufferDelegate {
@IBOutlet weak var captureButton: UIButton!
let sessionQueue = DispatchQueue(label: "Session Queue")
var status = false
var zoomStatus = 1
private var MyCaptureDevice: AVCaptureDevice?
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
captureButton.layer.cornerRadius = captureButton.frame.width / 2
captureButton.layer.masksToBounds = true
captureButton.layer.zPosition = 10
guard let captureDevice = AVCaptureDevice.default(for: AVMediaType.video) else {return}
guard let input = try? AVCaptureDeviceInput(device: captureDevice) else {return}
let captureSession = AVCaptureSession();
// captureSession.sessionPreset = .photo
captureSession.addInput(input)
// 1
for vFormat in captureDevice.formats {
// 2
let ranges = vFormat.videoSupportedFrameRateRanges as [AVFrameRateRange]
let frameRates = ranges[0]
// 3
if frameRates.maxFrameRate == 240 {
// 4
try? captureDevice.lockForConfiguration()
captureDevice.activeFormat = vFormat as AVCaptureDevice.Format
captureDevice.activeVideoMinFrameDuration = CMTimeMake(value: 1, timescale: Int32(240))
captureDevice.activeVideoMaxFrameDuration = CMTimeMake(value: 1, timescale: Int32(240))
captureDevice.videoZoomFactor = captureDevice.minAvailableVideoZoomFactor
captureDevice.unlockForConfiguration()
}
}
captureSession.startRunning();
let previewLayer = AVCaptureVideoPreviewLayer(session: captureSession)
view.layer.addSublayer(previewLayer)
previewLayer.frame = view.frame
let dataOutput = AVCaptureVideoDataOutput()
dataOutput.setSampleBufferDelegate(self, queue: DispatchQueue(label: "videoQueue"))
dataOutput.alwaysDiscardsLateVideoFrames = true;
captureSession.addOutput(dataOutput)
print(captureDevice.minAvailableVideoZoomFactor)
print(captureDevice.maxAvailableVideoZoomFactor)
MyCaptureDevice = captureDevice
}
func captureOutput(_ output: AVCaptureOutput, didOutput sampleBuffer: CMSampleBuffer, from connection: AVCaptureConnection) {
print(CMTimeGetSeconds(CMSampleBufferGetPresentationTimeStamp(sampleBuffer)))
// if !status { return }
// guard let pixelBuffer: CVPixelBuffer = CMSampleBufferGetImageBuffer(sampleBuffer) else { return }
// guard let uiImage = UIImage(pixelBuffer: pixelBuffer) else { return }
// UIImageWriteToSavedPhotosAlbum(uiImage, nil, nil, nil)
//
// guard let captureDevice = self.MyCaptureDevice else { return }
// if self.zoomStatus == 1 && captureDevice.videoZoomFactor >= CGFloat(Int32(captureDevice.maxAvailableVideoZoomFactor * 0.6)) { self.zoomStatus = -1
// }
// else if self.zoomStatus == -1 && captureDevice.videoZoomFactor <= (captureDevice.minAvailableVideoZoomFactor + 1.0) {
// self.zoomStatus = 1
// }
// UIImageWriteToSavedPhotosAlbum(uiImage, nil, nil, nil)
// try? captureDevice.lockForConfiguration()
// captureDevice.videoZoomFactor += (0.1 * CGFloat(self.zoomStatus))
// captureDevice.unlockForConfiguration()
}
@IBAction func captureControl(_ sender: UIButton) {
DispatchQueue.main.async {
if self.status {
self.captureButton.backgroundColor = .white
print("stop")
self.status = !self.status
}
else {
self.captureButton.backgroundColor = .red
print("recording...")
self.status = !self.status
}
}
}
}
extension UIImage {
public convenience init?(pixelBuffer: CVPixelBuffer) {
var cgImage: CGImage?
VTCreateCGImageFromCVPixelBuffer(pixelBuffer, options: nil, imageOut: &cgImage)
guard let _cgImage = cgImage else { return nil }
self.init(cgImage: _cgImage)
}
}
Credit Goes to: stackoverflow.com
Related question with same questions but different answers
- HOW CAN I CALL CAPTUREOUTPUT AT 240FPS? IN IOS
- ASYNC CALL BLOCKING MAIN THREAD WHEN USING DISPATCHGROUP IN IOS
- WEBRTC AUDIO CALL VOICE NOT HEARING IN IOS NOT WORKING WITH MOBILE DATA BUT WORKS WITH WIFI CONNECTION IN IOS
- WHEN REFERRING TO AN OLDER VERSION OF MACOS, DO WE STILL CALL IT OS X? IN IOS
- HOW TO CALL FUNCTION FROM ONE TARGET TO ANOTHER TARGET IOS SWIFT XCODE IN IOS
- RETURN TO THE SAME QUEUE AS NETWORK CALL WAS PERFORMED IN IOS
- HOW TO CALL FUNCTION WHEN COLLECTION VIEW IS RELOADED? IN IOS
- HOW CREATE AN NOTIFICATION SWIFT LIKE WHATSAPP CALL FCM? IN IOS
- HOW TO PASS DATA FROM AN API CALL TO THE VIEWCONTROLLER? IN IOS
- HOW TO CALL A BUTTON IN THE CONSTRUCTOR IN MAINPAGE WHEN APP STARTING USING XAMARIN IOS C# IN IOS
- HOW TO CALL AN AWS WEBSERVICE (API GATEWAY) ON IOS USING SOTO? IN IOS
- PICTURE SIZE DIFFERENCE PROBLEM ON ANDROID AND IOS IN IOS
- BEST PRACTICES / SOLUTION ARCHITECTURE ON INITIAL ICONS DELIVERY TO MOBILE APP IN REACT NATIVE IN IOS
- AUDIO NOT AVAILABLE THROUGH HEADPHONES DURING WEBRTC VIDEO CALLING IN IOS
- FAILED TO INSTALL COCOAPODS DEPENDENCIES FOR IOS PROJECT REACT-NATIVE IN IOS
- HOW TO GO BACK TO THE FIRST VIEWCONTROLLER? IN IOS
- EXPAND UITABLEVIEWCELL ADDING UICOLLECTIONVIEW AS A SUBVIEW IN IOS
- GRADIENT BACKGROUND COLOR OF UICOLLECTION VIEW CELL CHANGES BY ITSELF WHILE SCROLLING IN IOS
- APP CRASH USING HOT RESTART XAMARIN FORMS ON IOS AND THE ARCGIS RUNTIME IN IOS
- DATA NOT DISPLAYING CORRECTLY IN COLLECTIONVIEW CELL? IN IOS
- THE VARIABLE CHANGES INSIDE OF MY LOOP, BUT STAYS THE SAME IN MAIN CODE IN REACT NATIVE IN IOS
- ESTABLISHING TO-MANY RELATIONSHIPS BETWEEN NSMANAGEDOBJECTS CREATED IN A NSBATCHINSERTREQUEST IN IOS
- IN FIREBASE, WITH FLUTTERFIRE, HOW TO INITIALIZE A SECONDARY APP ON IOS? INITIALIZEAPP WITH OPTIONS GIVE GOOGLE_APP_ID ERROR IN IOS
- HOW TO ADD ITEMS INTO AN ARRAY THAT ARE IN THE STRUCT BUT NOT IN THE DB TABLE USING GRDB IN IOS
- UINAVIGATIONCONTROLLER IN WATCHKIT IN IOS
- QUESTION ABOUT DELEGATE NOT BEING APPLIED WHEN UITEXTFIELDDELEGATE FILE IS SEPARATED FROM VIEWCONTROLLER IN SWIFT IN IOS
- DEPTH OF FIELD EFFECT – BOKEHPASS DOESNT WORK CORRECTLY ON IOS (IPHONE 7) IN IOS
- USING APPCENTER.MS TRYING TO BUILD FOR IOS, INVALID P12 CERTIFICATE IN IOS
- UNABLE TO LOAD CONFIG.JS IN IOS
- HOW TO ASSIGN AD CONTENT TO STACKLAYOUT USING XAMARIN.IOS IN IOS
- HOW TO MAKE SOME BUTTONS OF TABLEVIEW CELLS CLICKABLE AND SOME UNCLICKABLE | IOS IN IOS
- ADD PADDING/INSETS TO UIIMAGE AS BACKGROUND OF UITEXTFIELD IN IOS
- ARE BROWSERSTACK DEVICES ROOTED OR JAIL BROKEN? IN IOS
- UIBUTTON IMAGE WITH PDF HAS FULL WIDTH IMAGE VIEW IN IOS
- NOT ABLE TO ADD UISEARCHBAR IN HEADERVIEW(TABLEVIEW'S HEADER VIEW)? IN IOS
- WHY CAN I NOT CAST THIS CELL TO A CLASS THAT INHERITS FROM CELL IN SWIFT? IN IOS
- ADD BORDER OF VARYING WIDTH TO DIFFERENT SIDES IN IOS
- SEGMENTATION FAULT: 11, XCODE -12 IN IOS
- CLOSE UIPICKERVIEW THAT IS AN UITEXTFIELD INPUTVIEW ON SELECTION IN IOS
- TRIGGER NATIVE UI FROM CAPACITOR PLUGIN.SWIFT IN IOS
- HOW DO I SET MY ENVIRONMENT OBJECT TO USER INPUT IN SWIFTUI? IN IOS
- UICOLLECTIONVIEW NOT DISPLAYING CORRECT NUMBER OF ITEMS IN IOS
- 2 CELLS IN UICOLLECTIONVIEW ROW IN IOS
- XCODE - HOW TO RENAME CORE DATA XCDATAMODELD MODEL INTERNALS? IN IOS
- AUDIOKIT AKPLAYER STOP WITH AT AVAUDIOTIME METHOD IN IOS
- (OBJECTIVE-C) DIFFERENCE BETWEEN ACCESSING THE NAVIGATION STACK THROUGH THE WINDOW.ROOTVIEW AND KEYWINDOW IN IOS
- PODFILE DEPENDING ON ALAMOFIRE AND OTHER POD THAT DEPENDS ON ALAMOFIRE TOO BUT DIFFERENT VERSION IN IOS
- SWIFTUI, @PUBLISHED WITH FOREACH NOT UPDATING MY VIEW IN IOS
- NEED HELP IN INTEGRATING "IBEACON + BLE PERIPHERAL SCANNING IOS BACKGROUND MODE" FEATURE IN IOS
- HOW TO RETIEVE DATA FOR 2 DIFFERENT SECTION IN UICOLLECTIONVIEW USING MVC IN IOS
- HOW CAN I USE CORDOVA-PLUGIN-BACKGROUND MODE IN IOS
- SWIFT - COMBINE - SYNCHRONOUS API EXECUTION INSIDE .TRYCATCH IN IOS
- HOW CAN YOU GET STREAMED UPDATES FROM A BLUTOOTH LE DEVICE USING FLUTTER [FLUTTER BLUE]? IN IOS
- BEST WAY TO STORE 1000'S OF MAPKIT ANNOTATIONS + SHOW ANNOTATIONS IN TABLEVIEW IN IOS
- BOTTOM BAR DOESN'T SHOW UP IN TABLEVIEWCONTROLLER IOS IN IOS
- MODULE 'RAZORPAY' HAS NO MEMBER NAMED 'INITWITHKEY' IN SWIFT IN IOS
- CORE IMAGE FACE DETECTOR NO RESULT IN IOS
- IOS APPLINK NOT WORKING ON THE DEVICE BUT OPENS APP ON SIMULATOR IN IOS
- REMOVE SINGLE SEPARATOR LINE FROM UITABLEVIEWCELL IN IOS