質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Delegates

Delegatesとは、オブジェクト指向型プログラミングにおいて、あるオブジェクトの操作を一部の他のオブジェクトに代替させる手法のこと。オブジェクトは他のデリゲートに頼って関数を実行することができます。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

2995閲覧

delegateが常にnilになって返される

suzumushi

総合スコア4

Delegates

Delegatesとは、オブジェクト指向型プログラミングにおいて、あるオブジェクトの操作を一部の他のオブジェクトに代替させる手法のこと。オブジェクトは他のデリゲートに頼って関数を実行することができます。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

1クリップ

投稿2020/08/25 14:00

実現したいこと

現在QRコードを読み込んでその内容を表示するiOSアプリを製作しています。
QRコードの読み込みはViewControllerとは別にCameraViewControllerで実装しています。

直面している課題

CameraViewControllerのdelegateが常にnilになってしまい、処理がそれ以上実行できません。

処理を依頼する側

swift

1import UIKit 2import Foundation 3import AVFoundation 4 5 6protocol CameraViewControllerDelegate{ 7 func ReadQRcode(data : String) 8} 9 10class CameraViewController: UIViewController, AVCaptureMetadataOutputObjectsDelegate { 11 12 var delegate : CameraViewControllerDelegate! 13 14 private var captureSession = AVCaptureSession() 15 16 override func viewDidLoad() { 17 super.viewDidLoad() 18 19     //使用するカメラの設定 20 captureSession.beginConfiguration() 21 let videoDevice = AVCaptureDevice.default(.builtInWideAngleCamera, 22 for: .video, position: .back) 23 guard 24 let videoDeviceInput = try? AVCaptureDeviceInput(device: videoDevice!), 25 captureSession.canAddInput(videoDeviceInput) 26 else {return} 27 captureSession.addInput(videoDeviceInput) 28 29 let QRCodeOutput = AVCaptureMetadataOutput() 30 guard captureSession.canAddOutput(QRCodeOutput) else { 31 return 32 } 33 captureSession.sessionPreset = .photo 34 captureSession.addOutput(QRCodeOutput) 35 captureSession.commitConfiguration() 36 37 QRCodeOutput.setMetadataObjectsDelegate(self, queue: DispatchQueue.main) 38 QRCodeOutput.metadataObjectTypes = [.qr] 39 40 // 背面カメラの映像を画面に表示するためのレイヤーを生成 41 let previewLayer = AVCaptureVideoPreviewLayer(session: self.captureSession) 42 previewLayer.frame = self.view.bounds 43 previewLayer.videoGravity = .resizeAspectFill 44 self.view.layer.addSublayer(previewLayer) 45 46 self.captureSession.startRunning() 47 } 48 49 override func didReceiveMemoryWarning() { 50 super.didReceiveMemoryWarning() 51 // Dispose of any resources that can be recreated. 52 } 53 54 internal func metadataOutput(_ output: AVCaptureMetadataOutput, didOutput metadataObjects: [AVMetadataObject], from connection: AVCaptureConnection) { 55 for metadata in metadataObjects as! [AVMetadataMachineReadableCodeObject] { 56 // QRコードのデータかどうかの確認と受け取ったデータの確認 57 if(metadata.type == .qr && metadata.stringValue != nil){ 58 self.delegate?.ReadQRcode(data: metadata.stringValue ?? "failed") 59 if delegate == nil{print("delegate is nil.")} 60 self.captureSession.stopRunning() 61 } 62 } 63 } 64} 65

処理を実行する側

swift

1import UIKit 2 3class ViewController: UIViewController,FUIAuthDelegate, CameraViewControllerDelegate{ 4 5 @IBOutlet weak var qrButton: UIButton! 6 7 override func viewDidLoad() { 8 super.viewDidLoad() 9 //... 10 CameraViewController().delegate = self 11 } 12 13 @objc func QRButtonTaped(sender: AnyObject) { 14 self.present(CameraViewController(), animated: true, completion: nil) 15 } 16 //... 17}

よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Swift

1 override func viewDidLoad() { 2 super.viewDidLoad() 3 //... 4 CameraViewController().delegate = self 5 } 6 7 @objc func QRButtonTaped(sender: AnyObject) { 8 self.present(CameraViewController(), animated: true, completion: nil) 9 }

viewDidLoad()でインスタンス化した CameraViewControllerQRButtonTapped(sender:)でインスタンス化した CameraViewController は異なっているのが原因かと思います。

なので、

Swift

1 let vc = CameraViewController() 2 vc.delegate = self 3 self.present(vc, animated: true, completion: nil)

こんな感じにすれば期待された動作になるかとおもいます。

ちなみに、delegate を宣言するときには class を継承し、変数 delegate を弱参照させることで循環参照を防ぎますので、このような変更を加えた方が良いかと思います。

Swift

1// class を継承させる 2protocol CameraViewControllerDelegate: class { 3 func ReadQRcode(data : String) 4} 5 6class CameraViewController: UIViewController, AVCaptureMetadataOutputObjectsDelegate { 7 // weak キーワードをつけて循環参照を防ぐ(class に準拠させないと weak キーワードは付けられない) 8 weak var delegate : CameraViewControllerDelegate!

投稿2020/08/25 23:24

TsukubaDepot

総合スコア5086

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

suzumushi

2020/08/26 00:23

ありがとうございます!原因をよく理解でき、無事動作させることができました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問