在雨燕3.0 在此代碼,你必須選擇這兩個選項的攝像頭和GALLARY
import UIKit
import Foundation
import AVFoundation
class HostVC: UIViewController, UIImagePickerControllerDelegate,UINavigationControllerDelegate{
@IBOutlet weak var imgHostProfile:UIImageView!
let captureSession = AVCaptureSession()
let stillImageOutput = AVCaptureStillImageOutput()
var previewLayer : AVCaptureVideoPreviewLayer?
var captureDevice : AVCaptureDevice?
@IBAction func btnChangeprofileTapped(_ sender: UIButton)
{
DispatchQueue.main.async
{
let alert = UIAlertController(title: "Alert", message: "Choose profile picture from Camera or Gallery", preferredStyle: UIAlertControllerStyle.alert)
alert.addAction(UIAlertAction(title: "Take a photo", style: UIAlertActionStyle.default, handler: { (action: UIAlertAction!) in
DispatchQueue.main.async
{
if AVCaptureDevice.authorizationStatus(forMediaType: AVMediaTypeVideo) == AVAuthorizationStatus.authorized {
self.Cemara()
} else {
AVCaptureDevice.requestAccess(forMediaType: AVMediaTypeVideo, completionHandler: { (granted: Bool) -> Void in
if granted == true {
self.Cemara()
} else {
self.showalert(strMessage: Validation.kCameraAccess)
}
})
}
}
}))
alert.addAction(UIAlertAction(title: "Choose from Library", style: UIAlertActionStyle.default, handler: { (action: UIAlertAction!) in
DispatchQueue.main.async
{
let imagepicker = UIImagePickerController()
imagepicker.delegate = self
imagepicker.sourceType = .photoLibrary
self.present(imagepicker, animated: true, completion: nil)
}
}))
alert.addAction(UIAlertAction(title: "Cancel", style: UIAlertActionStyle.default, handler: { (action: UIAlertAction!) in}))
self.present(alert, animated: true, completion: nil)
}
}
func Cemara()
{
DispatchQueue.main.async {
if UIImagePickerController.availableCaptureModes(for: .rear) != nil
{
let imagePicker = UIImagePickerController()
imagePicker.delegate = self
imagePicker.sourceType = .camera
self.present(imagePicker, animated: true, completion: nil)
}
else
{
self.noCamera()
}
}
}
//======================================================================
// MARK: - Camera Code
//======================================================================
func noCamera()
{
captureSession.sessionPreset = AVCaptureSessionPresetHigh
if let devices = AVCaptureDevice.devices() as? [AVCaptureDevice]
{
for device in devices
{
if (device.hasMediaType(AVMediaTypeVideo))
{
if(device.position == AVCaptureDevicePosition.front)
{
captureDevice = device
if captureDevice != nil
{
print("Capture device found")
beginSession()
}
}
}
}
}
}
//======================================================================
// MARK: - Camera Capture Start Session Code Here
//======================================================================
func beginSession()
{
do
{
try captureSession.addInput(AVCaptureDeviceInput(device: captureDevice))
stillImageOutput.outputSettings = [AVVideoCodecKey:AVVideoCodecJPEG]
if captureSession.canAddOutput(stillImageOutput)
{
captureSession.addOutput(stillImageOutput)
}
}
catch
{
print("error: \(error.localizedDescription)")
}
guard let previewLayer = AVCaptureVideoPreviewLayer(session: captureSession) else
{
print("no preview layer")
return
}
self.view.layer.addSublayer(previewLayer)
previewLayer.frame = self.view.layer.frame
captureSession.startRunning()
self.view.addSubview(imgHostProfile)
}
//======================================================================
// MARK: - Gallary Code
//======================================================================
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any])
{
if let imagedata = info[UIImagePickerControllerOriginalImage] as? UIImage
{
self.imgHostProfile.image = imagedata
print(imagedata)
}
dismiss(animated: true, completion: nil)
}
@adnan沒有工作,我在同一視圖添加imageChosen,self.view –
@adnan好吧,我現在檢查 –
@adnan我在這裏看到這個代碼http://www.theappguruz.com/博客/ user-interaction-camera-using-uiimagepickercontroller-swift /,所有我想要的,所以把圖片放在imageView中,不用創建按鈕,謝謝 –