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

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

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

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

Swift

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

Q&A

解決済

1回答

1558閲覧

swift,pickerView:ドラムロールの選択をさげるコードがわかりません。完了ボタンを作成したいです。(ストーリーボードは使用してません)

naka-1234

総合スコア1

Xcode

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

Swift

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

0グッド

0クリップ

投稿2020/08/09 07:31

編集2020/08/09 11:47

ドラムロールの選択肢で動物の名前をタップすると、その動物の名前が表示され選択肢が閉じるコードを作りたいのですが、下にあるコードでは選択した動物の名前は表示できますが選択肢が消えません。
右上に完了ボタンを作成し、そのボタンをタップするとドラムロールが消えるようにしたいです。

今回はストーリーボードは使わず、コードのみで作成してます。

どなたかお時間がある時に教えていただきたいです。
よろしくお願いします。

swift

1 2import UIKit 3 4 class ViewController: UIViewController , UIPickerViewDelegate, UIPickerViewDataSource { 5 6 var pickerView = UIPickerView() 7 8 var label = UILabel() 9 10 let dataList = [ 11 "いぬ","ねこ","くま","うさぎ", 12 "ライオン" ] 13 14 override func viewDidLoad() { 15 super.viewDidLoad() 16 pickerView.frame = CGRect(x: 0, y: 0, width: self.view.frame.width, height: 300) 17 18 pickerView.center = self.view.center 19 20 pickerView.delegate = self 21 pickerView.dataSource = self 22 23 let yPosition = pickerView.frame.origin.y 24 label.frame = CGRect(x: 0, y: yPosition - 100, width: self.view.frame.width, height: 100) 25 26 label.numberOfLines = 2 27 label.text = "動物の種類" 28 label.textAlignment = NSTextAlignment.center 29 30 self.view.addSubview(pickerView) 31 self.view.addSubview(label) 32 } 33 34 func numberOfComponents(in pickerView: UIPickerView) -> Int { 35 return 1 36 } 37 38 func pickerView(_ pickerView: UIPickerView, 39 numberOfRowsInComponent component: Int) -> Int { 40 return dataList.count 41 } 42 43 func pickerView(_ pickerView: UIPickerView, 44 titleForRow row: Int, 45 forComponent component: Int) -> String? { 46 47 return dataList[row] 48 } 49 50 func pickerView(_ pickerView: UIPickerView, 51 didSelectRow row: Int, 52 inComponent component: Int) { 53 54 label.text = dataList[row] 55 } 56 57} 58

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

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

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

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

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

TsukubaDepot

2020/08/09 09:18 編集

> ドラムロールの選択肢で動物の名前をタップすると、その動物の名前が表示され選択肢が閉じるコードを作りたいのですが、 念のため確認ですが、「タップ」というのは次のどちらになるのでしょうか。 1. ドラッグでPickerView を操作し終えたあとに消したい 2. 移動し終えた後、その項目をタップしたら消したい のどちらになるのでしょうか。
naka-1234

2020/08/09 10:21

すみません、詳しく書き忘れました。 ご質問ありがとうございます。 選択肢をタップして、例えばうさぎと表示されたら、ドラムロールの左上の完了ボタンをタップするとドラムロールが閉じるようにしたいです。 よろしくお願いします。
naka-1234

2020/08/09 10:22

何度もすみません、左上ではなく右上です。
guest

回答1

0

ベストアンサー

PickerView に直接ツールバーを追加(addSubView)できれば良いのですが、それはできないようなので、一度 UIVew を生成し、そこにツールバーとピッカービュー両方を入れた後、view に追加する方法で実現できそうです。

細かい点はコード中のコメントを参考にしてみてください。

Swift

1import UIKit 2 3class ViewController: UIViewController , UIPickerViewDelegate, UIPickerViewDataSource { 4 5 var pickerWithButtonView: UIView! 6 // 中略 7 8 override func viewDidLoad() { 9 super.viewDidLoad() 10 11 // MARK: PickerView, ToolBar 両方の高さを定義しておく 12 let pickerViewHeight = CGFloat(300) 13 let toolBarHeight = CGFloat(35) 14 let pickerWithButtonViewHeight = pickerViewHeight + toolBarHeight 15 16 // MARK: PickerView と ToolBar の両方を表示するビューを生成する 17 pickerWithButtonView = UIView(frame: CGRect(x: 0, y: view.frame.height / 2, width: view.frame.width, height: pickerWithButtonViewHeight)) 18 19 // MARK; ツールバーの生成 20 let toolbar = UIToolbar(frame: CGRect(x: 0, y: 0, width: pickerWithButtonView.frame.width, height: toolBarHeight)) 21 let spacelItem = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: self, action: nil) 22 // done ボタンを押すと、done() が呼ばれる 23 let doneItem = UIBarButtonItem(barButtonSystemItem: .done, target: self, action: #selector(done)) 24 // [doneItem, spaceItem] の順にすれば [Done] が左側に来る 25 toolbar.setItems([spacelItem, doneItem], animated: true) 26 // UIViewに追加する 27 pickerWithButtonView.addSubview(toolbar) 28 29 // MARK: PickerView の生成 30 // ToolBar の高さの分だけ、Y座標を上げる(表示を下げる) 31 pickerView.frame = CGRect(x: 0, y: toolBarHeight, width: pickerWithButtonView.frame.width, height: pickerViewHeight) 32 33 pickerView.delegate = self 34 pickerView.dataSource = self 35 // UIViewに追加する 36 pickerWithButtonView.addSubview(pickerView) 37 38 // 39 let yPosition = pickerWithButtonView.frame.origin.y 40 label.frame = CGRect(x: 0, y: yPosition - 100, width: self.view.frame.width, height: 100) 41 42 label.numberOfLines = 2 43 label.text = "動物の種類" 44 label.textAlignment = NSTextAlignment.center 45 46 // ToolBar 付きのピッカービューを表示させる 47 self.view.addSubview(pickerWithButtonView) 48 self.view.addSubview(label) 49 } 50 51 // [Done] を押した時の処理 52 @objc func done() { 53 // pickerWithButtonView を親ビューから取り除く 54 pickerWithButtonView.removeFromSuperview() 55 } 56 // 後略 57}

ちなみに、[Done]ボタンは右上でも左上でもどちらでも可能です。

##追記

pickerWithButtonView の Y 軸方向の原点を変更すれば、pickerWithButtonView を縦方向に移動させることが可能です。

たとえば、現在はスクリーンサイズの中央を原点にしていますが、

Swift

1 pickerWithButtonView = UIView(frame: CGRect(x: 0, y: view.frame.height / 2, width: view.frame.width, height: pickerWithButtonViewHeight))

下端(つまり、スクリーンサイズの高さ)からpickerWithButtonView分だけ上に戻った位置にすれば見切れることはなくなるかと思います(その分、上方向の余白は少なくなります)。

Swift

1 pickerWithButtonView = UIView(frame: CGRect(x: 0, y: view.frame.height - pickerWithButtonViewHeight, width: view.frame.width, height: pickerWithButtonViewHeight))

あるいは、コードで拘束を設定するのが、端末間のスクリーンサイズに左右されずいいかもしれません。

投稿2020/08/10 03:36

編集2020/08/10 08:17
TsukubaDepot

総合スコア5086

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

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

naka-1234

2020/08/10 06:44

回答ありがとうございます! 完了ボタンできました。 ただ、完了ボタンのツールバーとドラムロールの選択肢の部分が離れてしまい、選択肢だけ画面下に隠れてしまいました。 もしよろしければ、追加で教えてはいただけないでしょうか? 本当に助かりました。 ありがとうございます。
TsukubaDepot

2020/08/10 08:17

回答に追記しましたので参考にしてみていただければと思います。
naka-1234

2020/08/10 09:01

何度もすみません。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問