相机在快速拍摄照片后,我无法调整照片大小。目前我在我的场景中有一个100 x 100的图像视图(对于个人资料照片)但是当我运行应用程序时,照片在我使用相机后从未显示出来。这是我的代码。我缺少的是什么:
@IBAction func employeePhotoButton(sender: AnyObject) {
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera) {
var imagePicker = UIImagePickerController()
imagePicker.delegate = self
imagePicker.sourceType = UIImagePickerControllerSourceType.Camera;
imagePicker.allowsEditing = false
self.presentViewController(imagePicker, animated: true, completion: nil)
func resizeImage(image: UIImage, newWidth: CGFloat) -> UIImage {
let scale = newWidth / image.size.width
let newHeight = image.size.height * scale
UIGraphicsBeginImageContext(CGSizeMake(newWidth, newHeight))
image.drawInRect(CGRectMake(0, 0, newWidth, newHeight))
let newImage = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return newImage
}
func imagePickerController(picker: UIImagePickerController, didFinishPickingImage image: UIImage!, editingInfo: [NSObject : AnyObject]!) {
employeePhoto.image = resizeImage(image!, newWidth: 100)
self.dismissViewControllerAnimated(true, completion: nil);
}
}
}
答案 0 :(得分:3)
尝试这样的事情(注意这是使用Swift3语法):
// your IBAction could look something like this
@IBAction func employeePhotoButton(sender: AnyObject)
{
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera)
{
showImagePicker(.camera)
}
else
{
print("camera not available")
}
}
// your function in your view controller to display the image picker with whichever
// source type you want, check for source type availability before calling
func showImagePicker(sourceType:UIImagePickerControllerSourceType)
{
// instantiates and configures class var
self.imagePickerController = UIImagePickerController.init()
self.imagePickerController?.modalPresentationStyle = .currentContext
self.imagePickerController?.sourceType = sourceType
self.imagePickerController?.delegate = self
self.imagePickerController?.allowsEditing = false
// present controller
self.present(self.imagePickerController!, animated: true, completion: nil)
}
// Image picker delegate function
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any])
{
// dismiss the picker view controller
print("Selected media with info: \(info)")
self.dismiss(animated: true, completion: nil)
// no longer need this so nil out now
self.imagePickerController = nil
// check our image is valid
guard (info[UIImagePickerControllerOriginalImage] != nil) else {
print("No image found to load...")
return
}
// sets our 'selectedImg' class var for use elsewhere if needed
selectedImg = info[UIImagePickerControllerOriginalImage] as? UIImage
// verify the image is not nil
guard selectedImg != nil else {
print("selected image is nil")
return
}
// resize our selected image
let resizedImage = selectedImg.convert(toSize:CGSize(width:100.0, height:100.0), scale: UIScreen.main.scale)
// TODO: whatever you want to do with your resized image
employeePhoto.image = resizedImage
}
extension UIImage
{
// convenience function in UIImage extension to resize a given image
func convert(toSize size:CGSize, scale:CGFloat) ->UIImage
{
let imgRect = CGRect(origin: CGPoint(x:0.0, y:0.0), size: size)
UIGraphicsBeginImageContextWithOptions(size, false, scale)
self.draw(in: imgRect)
let copied = UIGraphicsGetImageFromCurrentImageContext()
UIGraphicsEndImageContext()
return copied!
}
}