2017-11-25 17 views
1

CoreMLを使用する画像認識アプリケーションを作成しました。そして、UIの面からは、私が画像を選んで、機能detect()の後に結果を表示した後、メインビューに戻りたいと思います。しかし、DispatchQueue.mainを使用しても、常に結果とメインビューが同時に表示されます。 detect()のうちDispatchQueue.mainを使用すると動作します。しかし、私はそれがそこにあるべきではないと思う。 さらに、SVProgressHUD.show()が動作しないという問題があります。Swift 4.0でDispatchQueueを使用する方法

import UIKit 
import CoreML 
import Vision 
import SVProgressHUD 

class ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate { 

    @IBOutlet weak var imageView: UIImageView! 

    @IBOutlet weak var cameraButton: UIBarButtonItem! 
    let imagePicker = UIImagePickerController() 

    override func viewDidLoad() { 
     super.viewDidLoad() 
     imagePicker.delegate = self 


    } 

    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) { 
     cameraButton.isEnabled = false 
     SVProgressHUD.show() 



     if let userPickedImage = info[UIImagePickerControllerOriginalImage] as? UIImage{ 

      imageView.image = userPickedImage 
      imagePicker.dismiss(animated: true, completion: nil) 


      let userPickedImage = info[UIImagePickerControllerOriginalImage] as! UIImage 
      guard let ciImage = CIImage(image: userPickedImage) else { 
       fatalError("WRONG") 
      } 
      detect(image: ciImage) 
     } 
    } 

    func detect(image: CIImage){ 

     guard let model = try? VNCoreMLModel(for: Inceptionv3().model) else { 
      fatalError("Loading CoreML Model Failed") 
     } 

     let request = VNCoreMLRequest(model: model) { (request, error) in 
      guard let results = request.results as? [VNClassificationObservation] else{ 
       fatalError("Model failed to process image") 
      } 
      if let firstResult = results.first { 
       let r = firstResult.identifier.split(separator: ",") 
       DispatchQueue.main.async { 
        self.cameraButton.isEnabled = true 
        SVProgressHUD.dismiss() 
        self.navigationItem.title = r.last?.description 
       } 
      } 
     } 


     let handler = VNImageRequestHandler(ciImage: image) 
     do{ 
      try handler.perform([request]) 
     } 
     catch { 
      print(error) 
     } 

    } 

    @IBAction func cameraTapped(_ sender: UIBarButtonItem) { 
     imagePicker.sourceType = .savedPhotosAlbum 
     imagePicker.allowsEditing = false 
     present(imagePicker, animated: true, completion: nil) 
    } 
} 

答えて

0

私が正しくあなたの質問を理解していれば、あなたは以下のように変更することができます。

func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) { 
    cameraButton.isEnabled = false 
    SVProgressHUD.show() 

    if let userPickedImage = info[UIImagePickerControllerOriginalImage] as? UIImage{ 
     imageView.image = userPickedImage 
     imagePicker.dismiss(animated: true) { 
     guard let ciImage = CIImage(image: userPickedImage) else { 
      fatalError("WRONG") 
     } 
     self.detect(image: ciImage) 
     } 
    } 
} 
関連する問題