亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS 10自定義相機功能

2020-07-26 02:20:29
字體:
來源:轉載
供稿:網友

本文實例為大家分享了iOS 10自定義相機功能的具體代碼,供大家參考,具體內容如下

直接上代碼

//// TGCameraVC.swift// TGPhotoPicker//// Created by targetcloud on 2017/7/25.// Copyright © 2017年 targetcloud. All rights reserved.// import UIKitimport AVFoundationimport Photos @available(iOS 10.0, *)class TGCameraVC: UIViewController {  var callbackPicutureData: ((Data?) -> ())?  private var device: AVCaptureDevice? private var input: AVCaptureDeviceInput? private var imageOutput: AVCapturePhotoOutput? private var session: AVCaptureSession? private var previewLayer: AVCaptureVideoPreviewLayer? fileprivate var showImageContainerView: UIView? fileprivate var showImageView: UIImageView? fileprivate var picData: Data? private var flashMode: AVCaptureFlashMode = .auto private weak var flashButton: UIButton?  override func viewDidLoad() {  super.viewDidLoad()   setupCamera()  setupUI()    if #available(iOS 9.0, *) {   let isVCBased = Bundle.main.infoDictionary?["UIViewControllerBasedStatusBarAppearance"] as? Bool ?? false   if !isVCBased{    UIApplication.shared.setStatusBarHidden(false, with: .none)   }  }else {   UIApplication.shared.statusBarStyle = .lightContent   UIApplication.shared.setStatusBarHidden(false, with: .none)  } }  override var prefersStatusBarHidden: Bool{  return false }  override var preferredStatusBarStyle: UIStatusBarStyle {  return .lightContent }  private func setupCamera() {  AVCaptureDevice.requestAccess(forMediaType: AVMediaTypeVideo) { success in   if !success {    let alertVC = UIAlertController(title: TGPhotoPickerConfig.shared.cameraUsage, message: TGPhotoPickerConfig.shared.cameraUsageTip, preferredStyle: .actionSheet)    alertVC.addAction(UIAlertAction(title: TGPhotoPickerConfig.shared.confirmTitle, style: .default, handler: nil))    self.present(alertVC, animated: true, completion: nil)   }  }  device = cameraWithPosistion(.back)  input = try? AVCaptureDeviceInput(device: device)  guard input != nil else {   return  }    imageOutput = AVCapturePhotoOutput()  session = AVCaptureSession()  session?.beginConfiguration()  session?.sessionPreset = TGPhotoPickerConfig.shared.sessionPreset  if session!.canAddInput(input) {   session!.addInput(input)  }  if session!.canAddOutput(imageOutput) {   session!.addOutput(imageOutput)  }  previewLayer = AVCaptureVideoPreviewLayer(session: session)  previewLayer?.frame = view.bounds  previewLayer?.videoGravity = TGPhotoPickerConfig.shared.videoGravity  view.layer.addSublayer(previewLayer!)  session?.commitConfiguration()  session?.startRunning() }  private func cameraWithPosistion(_ position: AVCaptureDevicePosition) -> AVCaptureDevice {  let type = AVCaptureDeviceType(rawValue: TGPhotoPickerConfig.shared.captureDeviceType.rawValue)  return AVCaptureDevice.defaultDevice(withDeviceType: type, mediaType: AVMediaTypeVideo, position: position) }  private func setupUI() {  let takeButton = UIButton(frame: CGRect(x: 0, y: 0, width: TGPhotoPickerConfig.shared.takeWH, height: TGPhotoPickerConfig.shared.takeWH))  takeButton.center = CGPoint(x: UIScreen.main.bounds.width / 2, y: UIScreen.main.bounds.height - TGPhotoPickerConfig.shared.buttonEdge.bottom)  takeButton.setImage(UIImage.size(width: TGPhotoPickerConfig.shared.takeWH, height: TGPhotoPickerConfig.shared.takeWH).border(width: 3).border(color: .white).color(.clear).corner(radius: TGPhotoPickerConfig.shared.takeWH / 2).image +   UIImage.size(width: TGPhotoPickerConfig.shared.takeWH - 10, height: TGPhotoPickerConfig.shared.takeWH - 10).color(UIColor(white: 0.95, alpha: 1) ).corner(radius: (TGPhotoPickerConfig.shared.takeWH - 10) / 2).image, for: .normal)  takeButton.setImage(UIImage.size(width: TGPhotoPickerConfig.shared.takeWH, height: TGPhotoPickerConfig.shared.takeWH).border(width: 3).border(color: .white).color(.clear).corner(radius: TGPhotoPickerConfig.shared.takeWH / 2).image +   UIImage.size(width: TGPhotoPickerConfig.shared.takeWH - 10, height: TGPhotoPickerConfig.shared.takeWH - 10).color(UIColor(white: 0.8, alpha: 1) ).corner(radius: (TGPhotoPickerConfig.shared.takeWH - 10) / 2).image, for: .highlighted)  takeButton.addTarget(self, action: #selector(takePhotoAction), for: .touchUpInside)  view.addSubview(takeButton)    let cameraChangeButton = UIButton(frame: CGRect(x: 0, y: 0, width: TGPhotoPickerConfig.shared.takeWH * 0.6, height: TGPhotoPickerConfig.shared.takeWH * 0.6))  cameraChangeButton.setImage(TGPhotoPickerConfig.getImageNo2x3xSuffix("camera"), for: .normal)  cameraChangeButton.center = CGPoint(x: UIScreen.main.bounds.width - TGPhotoPickerConfig.shared.buttonEdge.right, y: takeButton.center.y)  cameraChangeButton.addTarget(self, action: #selector(changeCameraPositionAction), for: .touchUpInside)  cameraChangeButton.contentMode = .scaleAspectFit  view.addSubview(cameraChangeButton)    let flashChangeButton = UIButton(frame: CGRect(x: 0, y: 0, width: TGPhotoPickerConfig.shared.takeWH * 0.5, height: TGPhotoPickerConfig.shared.takeWH * 0.5))  flashChangeButton.center = CGPoint(x: cameraChangeButton.center.x, y: TGPhotoPickerConfig.shared.buttonEdge.top)  flashChangeButton.setImage(TGPhotoPickerConfig.getImageNo2x3xSuffix("flashauto"), for: .normal)  flashChangeButton.addTarget(self, action: #selector(flashChangeAction), for: .touchUpInside)  flashChangeButton.contentMode = .scaleAspectFit  flashButton = flashChangeButton  view.addSubview(flashChangeButton)    let backButton = UIButton(frame: CGRect(x: 0, y: 0, width: TGPhotoPickerConfig.shared.takeWH * 0.4, height: TGPhotoPickerConfig.shared.takeWH * 0.4))  backButton.center = CGPoint(x: TGPhotoPickerConfig.shared.buttonEdge.left , y: flashChangeButton.center.y)  backButton.setImage(UIImage.size(width: TGPhotoPickerConfig.shared.takeWH * 0.4, height: TGPhotoPickerConfig.shared.takeWH * 0.4)   .corner(radius: TGPhotoPickerConfig.shared.takeWH * 0.2)   .color(.clear)   .border(color: UIColor.white.withAlphaComponent(0.7))   .border(width: TGPhotoPickerConfig.shared.isShowBorder ? TGPhotoPickerConfig.shared.checkboxLineW : 0)   .image   .with({ context in    context.setLineCap(.round)    UIColor.white.setStroke()    context.setLineWidth(TGPhotoPickerConfig.shared.checkboxLineW)    let WH = TGPhotoPickerConfig.shared.takeWH * 0.4    context.move(to: CGPoint(x: WH * 0.6, y: WH * 0.2))    context.addLine(to: CGPoint(x: WH * 0.35, y: WH * 0.5))    context.move(to: CGPoint(x: WH * 0.35, y: WH * 0.5))    context.addLine(to: CGPoint(x: WH * 0.6, y: WH * 0.8))    context.strokePath()   }), for: .normal)  backButton.contentMode = .scaleAspectFit  backButton.addTarget(self, action: #selector(backAction), for: .touchUpInside)  view.addSubview(backButton)    showImageContainerView = UIView(frame: view.bounds)  showImageContainerView?.backgroundColor = TGPhotoPickerConfig.shared.previewBGColor  view.addSubview(showImageContainerView!)    let height = showImageContainerView!.bounds.height - TGPhotoPickerConfig.shared.takeWH - TGPhotoPickerConfig.shared.buttonEdge.bottom - TGPhotoPickerConfig.shared.previewPadding * 2  showImageView = UIImageView(frame: CGRect(x: TGPhotoPickerConfig.shared.previewPadding, y: TGPhotoPickerConfig.shared.previewPadding * 2, width: showImageContainerView!.bounds.width - 2 * TGPhotoPickerConfig.shared.previewPadding, height: height))  showImageView?.contentMode = .scaleAspectFit  showImageContainerView?.addSubview(showImageView!)  showImageContainerView?.isHidden = true    let giveupButton = createImageOperatorButton(nil, CGPoint(x: TGPhotoPickerConfig.shared.takeWH * 1.5, y: showImageContainerView!.bounds.height - TGPhotoPickerConfig.shared.takeWH * 1.5), TGPhotoPickerConfig.shared.getCheckboxImage(true, true, .circle, TGPhotoPickerConfig.shared.takeWH * 0.7).unselect)  giveupButton.addTarget(self, action: #selector(giveupImageAction), for: .touchUpInside)  showImageContainerView?.addSubview(giveupButton)    let ensureButton = createImageOperatorButton(nil, CGPoint(x: showImageContainerView!.bounds.width - TGPhotoPickerConfig.shared.takeWH * 1.5, y: showImageContainerView!.bounds.height - TGPhotoPickerConfig.shared.takeWH * 1.5), TGPhotoPickerConfig.shared.getCheckboxImage(true, false, .circle, TGPhotoPickerConfig.shared.takeWH * 0.7).select)  ensureButton.addTarget(self, action: #selector(useImageAction), for: .touchUpInside)  showImageContainerView?.addSubview(ensureButton) }  private func createImageOperatorButton(_ title: String?, _ center: CGPoint, _ img: UIImage?) -> UIButton {  let btn = UIButton(frame: CGRect(x: 0, y: 0, width: TGPhotoPickerConfig.shared.takeWH * 0.7, height: TGPhotoPickerConfig.shared.takeWH * 0.7))  btn.center = center  btn.setTitle(title, for: .normal)  btn.setImage(img, for: .normal)  btn.contentMode = .scaleAspectFit  return btn }  @objc private func flashChangeAction() {  switch flashMode {  case .auto:   flashMode = .on   flashButton?.setImage(TGPhotoPickerConfig.getImageNo2x3xSuffix("flash"), for: .normal)  case .on:   flashMode = .off   flashButton?.setImage(TGPhotoPickerConfig.getImageNo2x3xSuffix("flashno"), for: .normal)  case .off:   flashMode = .auto   flashButton?.setImage(TGPhotoPickerConfig.getImageNo2x3xSuffix("flashauto"), for: .normal)  } }  @objc private func backAction() {  dismiss(animated: true, completion: nil) }  @objc private func takePhotoAction() {  let connection = imageOutput?.connection(withMediaType: AVMediaTypeVideo)  guard connection != nil else {   return  }  let photoSettings = AVCapturePhotoSettings()  photoSettings.flashMode = flashMode  imageOutput?.capturePhoto(with: photoSettings, delegate: self) }  @objc private func changeCameraPositionAction() {  let animation = CATransition()  animation.duration = 0.5  animation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut)  animation.type = TGPhotoPickerConfig.shared.transitionType    let newDevice: AVCaptureDevice!  let newInput: AVCaptureDeviceInput?  let position = input?.device.position  if position == .front {   newDevice = cameraWithPosistion(.back)   animation.subtype = kCATransitionFromLeft  } else {   newDevice = cameraWithPosistion(.front)   animation.subtype = kCATransitionFromRight  }  newInput = try? AVCaptureDeviceInput(device: newDevice)  guard newInput != nil else{   return  }    previewLayer?.add(animation, forKey: nil)    session?.beginConfiguration()  session?.removeInput(input)  if session!.canAddInput(newInput) {   session?.addInput(newInput!)   input = newInput  } else {   session?.addInput(input)  }  session?.commitConfiguration() }  @objc private func giveupImageAction() {  showImageView?.image = UIImage()  showImageContainerView?.isHidden = true }  @objc private func useImageAction() {  callbackPicutureData?(picData)  dismiss(animated: true, completion: nil) }} @available(iOS 10.0, *)extension TGCameraVC: AVCapturePhotoCaptureDelegate { func capture(_ captureOutput: AVCapturePhotoOutput, didFinishProcessingPhotoSampleBuffer photoSampleBuffer: CMSampleBuffer?, previewPhotoSampleBuffer: CMSampleBuffer?, resolvedSettings: AVCaptureResolvedPhotoSettings, bracketSettings: AVCaptureBracketedStillImageSettings?, error: Error?) {  if error != nil {   print("error = /(String(describing: error?.localizedDescription))")  } else {   if let imageData = AVCapturePhotoOutput.jpegPhotoDataRepresentation(forJPEGSampleBuffer: photoSampleBuffer!, previewPhotoSampleBuffer: previewPhotoSampleBuffer){    picData = imageData    showImageContainerView?.isHidden = false    showImageView?.image = UIImage(data: imageData)    if TGPhotoPickerConfig.shared.saveImageToPhotoAlbum{     self.saveImageToPhotoAlbum(UIImage(data: imageData)!)    }   }  } }  fileprivate func saveImageToPhotoAlbum(_ savedImage:UIImage){  UIImageWriteToSavedPhotosAlbum(savedImage, self, #selector(imageDidFinishSavingWithErrorContextInfo), nil) }  @objc fileprivate func imageDidFinishSavingWithErrorContextInfo(image:UIImage,error:NSError?,contextInfo:UnsafeMutableRawPointer?){  if canUseAlbum(){   let msg = (error != nil) ? TGPhotoPickerConfig.shared.saveImageFailTip : TGPhotoPickerConfig.shared.saveImageSuccessTip   let alert = UIAlertView(title: TGPhotoPickerConfig.shared.saveImageTip, message: msg, delegate: self, cancelButtonTitle: TGPhotoPickerConfig.shared.confirmTitle)   alert.show()  } }  fileprivate func canUseAlbum()-> Bool{  if PHPhotoLibrary.authorizationStatus() != PHAuthorizationStatus.authorized {   let alertView = UIAlertView(title: TGPhotoPickerConfig.shared.PhotoLibraryUsage, message: TGPhotoPickerConfig.shared.PhotoLibraryUsageTip, delegate: nil, cancelButtonTitle: TGPhotoPickerConfig.shared.confirmTitle, otherButtonTitles: TGPhotoPickerConfig.shared.cancelTitle)   alertView.tag = TGPhotoPickerConfig.shared.alertViewTag   alertView.show()   return false  }else{   return true  } }}

效果如下

完整使用DEMO見:點擊打開鏈接

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲午夜视频在线观看| 色综合91久久精品中文字幕| 国产做受69高潮| 欧美中文字幕视频在线观看| 国产98色在线| 欧日韩在线观看| 欧美日韩精品中文字幕| 92看片淫黄大片看国产片| 亚洲欧美日韩国产中文| 中文字幕欧美日韩| 国产精品视频久久久| 久久久久久美女| 欧美精品生活片| 欧美精品一区三区| 欧美日韩在线另类| 欧美www视频在线观看| 91探花福利精品国产自产在线| 国产亚洲精品va在线观看| 欧美香蕉大胸在线视频观看| 欧美日韩精品在线视频| 色综合久久中文字幕综合网小说| 成人网在线免费看| 精品中文字幕在线2019| 欧美精品手机在线| 日韩风俗一区 二区| 国产精品欧美日韩| 成人国产精品久久久| 欧美成人激情视频| 伊人亚洲福利一区二区三区| 亚洲免费伊人电影在线观看av| 另类天堂视频在线观看| 中文字幕免费精品一区高清| 欧美日韩国产综合视频在线观看中文| 欧美日韩中文字幕在线视频| 97精品国产91久久久久久| yw.139尤物在线精品视频| 国产欧美精品在线播放| 国产v综合ⅴ日韩v欧美大片| 成人在线播放av| 51精品国产黑色丝袜高跟鞋| 国产精品久久久久久av| 亚洲国产一区二区三区四区| 日韩影视在线观看| 亚洲精品欧美一区二区三区| 欧美自拍大量在线观看| 国产日韩欧美日韩大片| 亚洲精品之草原avav久久| 在线观看成人黄色| 久久久精品国产亚洲| 在线观看国产精品日韩av| 日日狠狠久久偷偷四色综合免费| 精品国产区一区二区三区在线观看| 国产亚洲美女久久| 亚洲黄在线观看| 欧美性感美女h网站在线观看免费| 欧美日韩国产中文精品字幕自在自线| 国产精品久久久久久久久久久新郎| 亚洲乱码一区二区| 国产亚洲成av人片在线观看桃| 韩国精品美女www爽爽爽视频| 亚洲国产精品人久久电影| 国产精品青青在线观看爽香蕉| 日韩精品免费综合视频在线播放| 亚洲国语精品自产拍在线观看| 亚洲成年人在线播放| 欧美极度另类性三渗透| 中文字幕免费精品一区| 91精品视频观看| 国产成人一区二区三区| 九九热在线精品视频| 中文欧美日本在线资源| 91亚洲精品在线观看| 成人信息集中地欧美| 日本一区二区在线播放| 亚洲成人久久一区| 精品日韩美女的视频高清| 亚洲最新av在线网站| 久久久精品久久久久| 亚洲国产精品美女| 国产一区二区三区在线视频| 久久久久久久久久久免费| 欧美性猛交xxxx免费看| 亚洲国产精品网站| 久久亚洲国产精品成人av秋霞| 欧美最猛性xxxxx(亚洲精品)| 日韩在线中文字| 日韩精品一区二区视频| 日本精品性网站在线观看| 日韩av在线最新| 精品无人区乱码1区2区3区在线| 欧美一乱一性一交一视频| 中文欧美日本在线资源| 91tv亚洲精品香蕉国产一区7ujn| 2020久久国产精品| 欧美大肥婆大肥bbbbb| 亚洲人成电影在线播放| 日韩精品在线免费观看| 国产亚洲免费的视频看| 高清欧美性猛交xxxx| 一道本无吗dⅴd在线播放一区| 欧美成人在线免费视频| 亚洲精品第一页| 性欧美暴力猛交69hd| 久久久影视精品| 亚洲成人教育av| 国产精品香蕉在线观看| 国产一区视频在线播放| 国产成人精品久久久| 日韩欧美在线视频观看| 成人啪啪免费看| 亚洲在线免费视频| 精品久久久久久久久久| 欧美—级a级欧美特级ar全黄| 91精品一区二区| 狠狠色狠色综合曰曰| 性色av一区二区三区红粉影视| 亚洲xxxx在线| 97视频在线观看成人| 欧美三级免费观看| 亚洲第一网站男人都懂| 国产欧美一区二区三区在线看| 欧美另类暴力丝袜| 久久成人综合视频| 日韩欧美福利视频| 亚洲第一区中文字幕| 久久久精品电影| 国产精品自拍偷拍视频| 欧美插天视频在线播放| 精品中文字幕在线| 91精品视频专区| 精品国产31久久久久久| 久久精品99无色码中文字幕| 久久99精品久久久久久琪琪| 成人免费午夜电影| 日韩免费不卡av| 一区二区亚洲精品国产| 精品成人国产在线观看男人呻吟| 欧美日韩日本国产| 国产精品香蕉国产| 中文字幕一精品亚洲无线一区| 91精品视频免费观看| 一区二区三区动漫| 中国日韩欧美久久久久久久久| 亚洲国产天堂久久国产91| 国产日韩欧美夫妻视频在线观看| 亚洲色图第三页| 九色91av视频| 伊人久久久久久久久久久| 成人夜晚看av| 日本成人精品在线| 97国产精品视频| 亚洲国产精品yw在线观看| 91av在线免费观看视频| 成人中文字幕在线观看| 欧美三级欧美成人高清www| 久久综合免费视频| 欧美不卡视频一区发布| 青青草国产精品一区二区| 欧美视频在线看| 国产精品久久久久久久久久尿| 黑人狂躁日本妞一区二区三区| 亚洲精品久久久一区二区三区| 97av在线视频免费播放| 欧美一级视频在线观看|