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

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

新規登録して質問してみよう
ただいま回答率
85.48%
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回答

379閲覧

CustomAlertについて

退会済みユーザー

退会済みユーザー

総合スコア0

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グッド

0クリップ

投稿2018/01/04 01:57

困っている事
現状のalertでは私のイメージしているものが作れなかったのでcustomAlertで一からalertを作ることにしたのですがcutotomで作ったalertのコードはどこに書けば良いかとviewcontoroller.swiftに結びつける方法が分からなくて困っています。

やったこと
一応新しいソースファイルを作りにそこにcustom alertで使ったlabelやtextfieldなどを結びつけました。

swift

1import UIKit 2 3class CustomAlert: UIView { 4 5 let item = ["円","ドル"] 6 @IBOutlet var _myview: UIView! 7 @IBOutlet weak var titlelbl: UILabel! 8 @IBOutlet weak var exlbl: UILabel! 9 @IBOutlet weak var lepslbl: UILabel! 10 @IBOutlet weak var otherlbl: UILabel! 11 @IBOutlet weak var leps: UITextField! 12 @IBOutlet weak var kg: UITextField! 13 @IBOutlet weak var sub: UIPickerView! 14 @IBAction func cancelbtr(_ sender: Any) { 15 } 16 17 @IBAction func okbtr(_ sender: Any) { 18 } 19 // PickerViewの列数 20 func numberOfComponents(in pickerView: UIPickerView) -> Int { 21 return 1 22 } 23 24 // PickerViewの行数 25 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { 26 return item.count 27 } 28 29 // PickerViewの項目 30 func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { 31 return item[row] 32 } 33 34 // PickerViewの項目選択時 35 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 36 37 } 38 39 40} 41

swift

1import UIKit 2 3class ViewController: 4 @IBAction func btr(_ sender: Any) { 5}

以下のボタンをタップ時にcustomで作ったalertを表示させたいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ボタンを押すたびにCustomAlertがaddSubviewされる雑なコードですが参考にしてください。
CustomAlertクラスにイニシャライザとPickerのデリゲート処理を追加しました。

CustomAlert.swift

Swift

1import UIKit 2 3class CustomAlert: UIView ,UIPickerViewDataSource,UIPickerViewDelegate { 4 5 let item = ["円","ドル"] 6 @IBOutlet var _myview: UIView! 7 @IBOutlet weak var titlelbl: UILabel! 8 @IBOutlet weak var exlbl: UILabel! 9 @IBOutlet weak var lepslbl: UILabel! 10 @IBOutlet weak var otherlbl: UILabel! 11 @IBOutlet weak var leps: UITextField! 12 @IBOutlet weak var kg: UITextField! 13 @IBOutlet weak var sub: UIPickerView! 14 15 16 //コードから 17 override init(frame: CGRect) { 18 super.init(frame: frame) 19 self.commonInit() 20 } 21 22 //ストボーから 23 required init?(coder aDecoder: NSCoder) { 24 super.init(coder: aDecoder) 25 self.commonInit() 26 } 27 28 fileprivate func commonInit() { 29 30 guard let view = UINib(nibName: "CustomAlert", bundle: nil).instantiate(withOwner: self, options: nil).first as? UIView else { 31 return 32 } 33 34 // デリゲート設定 35 sub.delegate = self 36 sub.dataSource = self 37 38 view.frame = self.bounds 39 40 self.addSubview(view) 41 42 } 43 44 @IBAction func cancelbtr(_ sender: Any) { 45 } 46 47 @IBAction func okbtr(_ sender: Any) { 48 } 49 // PickerViewの列数 50 func numberOfComponents(in pickerView: UIPickerView) -> Int { 51 return 1 52 } 53 54 // PickerViewの行数 55 func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { 56 return item.count 57 } 58 59 // PickerViewの項目 60 func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { 61 return item[row] 62 } 63 64 // PickerViewの項目選択時 65 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { 66 67 } 68 69 70} 71

ViewController.swift

Swift

1import UIKit 2 3class ViewController: UIViewController { 4 5 @IBAction func btr(_ sender: Any) { 6 let customAlert = CustomAlert(frame: CGRect(x: 0.0, y: 0.0, width: 300 , height: 200)) 7 customAlert.center = self.view.center 8 self.view.addSubview(customAlert) 9 } 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 // Do any additional setup after loading the view, typically from a nib. 14 15 } 16 17 override func didReceiveMemoryWarning() { 18 super.didReceiveMemoryWarning() 19 // Dispose of any resources that can be recreated. 20 } 21 22 23} 24

投稿2018/01/04 03:48

fromageblanc

総合スコア2724

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

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

退会済みユーザー

退会済みユーザー

2018/01/04 06:03

なるほど!こうすればよかったんですね! それとなんですがcustomで作ったalertはどうメインストーリーボードに反映させれば良いのでしょうか? コードだけじゃエラーが起きてしまったのでもし宜しければ教えて頂きたいです。
fromageblanc

2018/01/04 07:06

@IBOutlet〜のコードが見えるので、CustomAlertのnib(xib)ファイルは出来てるものと思ったのですが、出来てない? xibファイルを作成したら、file's ownerに「CustomAlert」を設定してください。 参考 https://dev.classmethod.jp/smartphone/xib/
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問