Reputation: 173
I have one view, there is one button and one ImageView. When pressed, the button triggers UIImagePickerController and the UIView will display the picked image. I tried to do this without using storyboard, but I keep getting a "fatal error: unexpectedly found nil while unwrapping an Optional value"
at this line imageView.contentMode = .ScaleAspectFit
. I've looked at other stackoverflow posts that suggest using editingInfo[UIImagePickerControllerOriginalImage]
instead of info[UIImagePickerControllerOriginalImage]
, but it hasn't worked. How do you fix this issue?
import UIKit
class EditViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate {
var imageView: UIImageView!=nil
override func viewDidLoad() {
super.viewDidLoad()
createBackground()
createImageView()
createButton()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
func createBackground() {
let backgroundImage = UIImage(named: "pinetree")
var imageView: UIImageView!
imageView = UIImageView(frame: view.bounds)
imageView.contentMode = .ScaleAspectFill
imageView.clipsToBounds = true
imageView.image = backgroundImage
imageView.center = view.center
view.addSubview(imageView)
self.view.sendSubviewToBack(imageView)
}
func createImageView() {
var image: UIImage!
var imageView = UIImageView(image: image)
imageView.frame = CGRectMake(view.bounds.width/2, view.bounds.height/2, view.bounds.width, view.bounds.height*(3/4))
self.view.addSubview(imageView)
}
func createButton() {
let size = view.bounds.width
let cx = view.bounds.width/2
let cy = view.bounds.height * 4/5
let button = UIButton();
button.frame = CGRectMake(0, 0, size, size)
button.center.x = cx
button.center.y = cy
button.setTitle("Load Image", forState: .Normal)
button.addTarget(self, action: "loadImageButtonPressed:", forControlEvents: .TouchUpInside)
self.view.addSubview(button)
}
func loadImageButtonPressed(sender: UIButton!) {
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.PhotoLibrary){
var imagePicker = UIImagePickerController()
imagePicker.delegate = self
imagePicker.sourceType = UIImagePickerControllerSourceType.PhotoLibrary;
//imagePicker.mediaTypes = [kUTTypeImage];
imagePicker.allowsEditing = false
self.presentViewController(imagePicker, animated: true, completion: nil)
}
}
func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) {
if let pickedImage = info[UIImagePickerControllerOriginalImage] as? UIImage {
imageView.contentMode = .ScaleAspectFit
imageView.image = pickedImage
}
dismissViewControllerAnimated(true, completion: nil)
}
func imagePickerControllerDidCancel(picker: UIImagePickerController) {
dismissViewControllerAnimated(true, completion: nil)
}
}
Upvotes: 0
Views: 1646
Reputation: 173
I found the answer! I realized I had initiated the variable imageView
twice (in the class EditViewController
& in the function createImageView()
). I deleted the imageView
in the function createImageView()
and edited the initiation of imageView in the class. My updated code is:
import UIKit
class EditViewController: UIViewController, UINavigationControllerDelegate, UIImagePickerControllerDelegate {
var imageView = UIImageView(image: UIImage(named: "ClearImage"))
override func viewDidLoad() {
super.viewDidLoad()
}
override func viewDidAppear(animated: Bool) {
super.viewDidAppear(animated)
createBackground()
createImageView()
createButton()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
func createBackground() {
let backgroundImage = UIImage(named: "pinetree")
var imageView: UIImageView!
imageView = UIImageView(frame: view.bounds)
imageView.contentMode = .ScaleAspectFill
imageView.clipsToBounds = true
imageView.image = backgroundImage
imageView.center = view.center
view.addSubview(imageView)
self.view.sendSubviewToBack(imageView)
}
func createImageView() {
imageView.frame = CGRectMake(0,0, view.bounds.width, view.bounds.height*(3/4))
self.view.addSubview(imageView)
}
func createButton() {
let size = view.bounds.width
let cx = view.bounds.width/2
let cy = view.bounds.height * 4/5
let button = UIButton();
button.frame = CGRectMake(0, 0, 200, 200)
button.center.x = cx
button.center.y = cy
button.setTitle("Load Image", forState: .Normal)
button.addTarget(self, action: "loadImageButtonPressed:", forControlEvents: .TouchUpInside)
self.view.addSubview(button)
}
func loadImageButtonPressed(sender: UIButton!) {
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.PhotoLibrary){
var imagePicker = UIImagePickerController()
imagePicker.delegate = self
imagePicker.sourceType = UIImagePickerControllerSourceType.PhotoLibrary;
//imagePicker.mediaTypes = [kUTTypeImage];
imagePicker.allowsEditing = false
self.presentViewController(imagePicker, animated: true, completion: nil)
}
}
func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) {
if let pickedImage = info[UIImagePickerControllerOriginalImage] as? UIImage {
imageView.contentMode = .ScaleAspectFit
imageView.image = pickedImage
}
dismissViewControllerAnimated(true, completion: nil)
}
func imagePickerControllerDidCancel(picker: UIImagePickerController) {
dismissViewControllerAnimated(true, completion: nil)
}
}
Upvotes: 1