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

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

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

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

Swift

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

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

Q&A

解決済

1回答

1417閲覧

pickerViewで選択した項目を画面遷移先で画像として表示させるようにしたい

magiee

総合スコア28

Xcode

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

Swift

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

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

0グッド

0クリップ

投稿2020/05/05 12:04

現状のswiftの動き

①PickerViewで、ハート、クローバー、ダイヤ、スペードの4つの項目を選択できる。
②画面遷移先では、画面をタップすると項目に関係なく、ダイヤの画像が表示される。

実現したいこと

選択した項目を、画面遷移先に画像として表示させたいです。
※ハートを選択すると、画面遷移先で、画面をタップするとハートの画像が表示されるようにしたい。

どのようにしたら、PickerViewで選択した項目が画面遷移先に反映することができるのか
また、画像として表示させることができるのか分かりません。

ご教授のほど、よろしくお願い致します。

該当のソースコード

import UIKit class ViewController: UIViewController,UIPickerViewDataSource,UIPickerViewDelegate { var mark = ["hart", "spade", "daiya", "club"] func numberOfComponents(in pickerView: UIPickerView) -> Int { return 1 } func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { return mark.count } func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { return mark[row] } func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { pickLabel.text = mark[row] } @IBOutlet weak var pickLabel: UILabel! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view. pickLabel.text = "hart" } @IBAction func nextButton(_ sender: Any) { performSegue(withIdentifier: "nextPages", sender: nil) } }

画面遷移先

import UIKit class secondPagesViewController: UIViewController { @IBAction func addImage(_ sender: UITapGestureRecognizer) { let mark = UIImageView(image: UIImage(named: "mark1")) mark.frame = CGRect(x: 0, y: 0, width: 100, height: 100) mark.center = sender.location(in: self.view) self.view.addSubview(mark) } override func viewDidLoad() { super.viewDidLoad() } }

使用している言語

swift
Xvode 11.4

ご教授のほど、よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

いわゆる、画面遷移時の値渡しというのを行えばいいかと思います。

考え方としては

1. 遷移先に値を受け取る変数(プロパティ)を準備しておく

swift

1class secondPagesViewController: UIViewController { 2 // 呼び出し元から情報を受け取るプロパティ 3 var imageName: String!

2.segueが実行される時に呼び出されるメソッドで値を渡す

swift

1class ViewController: UIViewController,UIPickerViewDataSource,UIPickerViewDelegate { 2 // 中略 3 // perfonrmSegue が実行された後に呼び出される処理 4 override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 5 // segue の遷移先が secondViewCOntroller だった場合の処理 6 if let nextVC = segue.destination as? secondPagesViewController { 7 // nextVC (= secondViewController のインスタンス) の imageName にラベルの値を入れる 8 nextVC.imageName = pickLabel.text 9 } 10 }

3.遷移先で渡ってきた値を元に適切に処理する

swift

1class secondPagesViewController: UIViewController { 2 // 中略 3 4 override func viewDidLoad() { 5 super.viewDidLoad() 6 // 前のページで値が入った imageName を表示する 7 print(imageName!) 8 } 9 10 @IBAction func addImage(_ sender: UITapGestureRecognizer) { 11 // UIImage の引数として imageName を渡す 12 let mark = UIImageView(image: UIImage(named: imageName)) 13 // 後略 14 } 15}

この場合、ラベルとして表示した文字列に対応する画像の名前を一致させておく必要があります。
一致させなくても対応する画像を表示させることは可能ですが、考えることが増えてしまいます。

まずは、上記の方法で試してみてはいかがでしょうか。

投稿2020/05/05 13:16

TsukubaDepot

総合スコア5086

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

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

magiee

2020/05/05 15:23

解決することができました。 丁寧に解説していただきまして、ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問