🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Xcode

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

Swift

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

Q&A

解決済

1回答

1517閲覧

UITextFieldへの入力がシミュレーター上でできません

1101hiroki_n

総合スコア4

Xcode

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

Swift

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

0グッド

0クリップ

投稿2019/12/28 14:27

編集2019/12/28 14:34

UITextFieldへ入力ができません。

シミュレーター上でのTextFieldへのキーボード入力ができません。(実機テストはまだです。)

書籍検索アプリでStoryboardはほとんど利用していません。

画面構造は、上部にUIButtonクラスを拡張したMainCenterButtonクラスで作成した検索ボタンが配置されていて、
UIScrollView上のUIViewへ書籍名や著者名などの入力欄をappendMainInputs()メソッドでループ処理で配置しています。

入力欄はUILabelを拡張したMainInputLabelクラスとUITextfFieldを拡張したMainInputTextFieldクラスから成ります。

問題が起こっているViewController

swift

1class SearchViewController: UIViewController { 2 //検索ボタンの上下空白 3 private let buttonVerticalMargin: CGFloat = 60.0 4 5 //APIのための構造体 6 struct searchingBookInfo { 7 var title: String? 8 var authors: [String?] 9 var publisher: String? 10 var edition: String? 11 var condition: String? 12 var priceUpperLimit: String? 13 var ISBNCode: String? 14 } 15 16 //入力欄ひとつ分を表す構造体 17 struct MainInputStruct { 18 var label: MainInputLabel 19 var textField: MainInputTextField 20 var labelText: String 21 var placeholderText: String 22 var keyboardType: Int = 0 23 } 24 25 //入力欄UIのインスタンス郡 26 private let titleInputLabel: MainInputLabel = MainInputLabel() 27 private let titleInputTextField: MainInputTextField = MainInputTextField() 28 29 private let authorInputLabel: MainInputLabel = MainInputLabel() 30 private let authorInputTextField: MainInputTextField = MainInputTextField() 31 32 private let publisherInputLabel: MainInputLabel = MainInputLabel() 33 private let publisherInputTextField: MainInputTextField = MainInputTextField() 34 35 private let editionInputLabel: MainInputLabel = MainInputLabel() 36 private let editionInputTextField: MainInputTextField = MainInputTextField() 37 38 private let conditionInputLabel: MainInputLabel = MainInputLabel() 39 private let conditionInputTextField: MainInputTextField = MainInputTextField() 40 41 private let upperLimitInputLabel: MainInputLabel = MainInputLabel() 42 private let upperLimitInputTextField: MainInputTextField = MainInputTextField() 43 44 private let isbnCodeInputLabel: MainInputLabel = MainInputLabel() 45 private let isbnCodeInputTextField: MainInputTextField = MainInputTextField() 46 47 private let searchButton: MainCenterButton = MainCenterButton() 48 49 @objc private func searchButtonEvent(_ sender: MainCenterButton) { 50 //検索ボタン押下処理 51 } 52 53 override func viewDidLoad() { 54 super.viewDidLoad() 55 56 //入力欄の配置ViewとScrollView 57 let searchPageScrollView: UIScrollView = UIScrollView() 58 self.view.addSubview(searchPageScrollView) 59 searchPageScrollView.translatesAutoresizingMaskIntoConstraints = false 60 NSLayoutConstraint.activate([ 61 searchPageScrollView.topAnchor.constraint(equalTo: self.view.topAnchor, constant: 0.0), 62 searchPageScrollView.bottomAnchor.constraint(equalTo: self.view.bottomAnchor, constant: 0.0), 63 searchPageScrollView.rightAnchor.constraint(equalTo: self.view.rightAnchor, constant: 0.0), 64 searchPageScrollView.leftAnchor.constraint(equalTo: self.view.leftAnchor, constant: 0.0), 65 ]) 66 67 let searchPageContentView: UIView = UIView(frame: CGRect(x:0,y:0,width:0.0,height: 0.0)) 68 searchPageScrollView.addSubview(searchPageContentView) 69 searchPageContentView.translatesAutoresizingMaskIntoConstraints = false 70 NSLayoutConstraint.activate([ 71 searchPageContentView.bottomAnchor.constraint(equalTo: searchPageScrollView.contentLayoutGuide.bottomAnchor), 72 searchPageContentView.leadingAnchor.constraint(equalTo: searchPageScrollView.contentLayoutGuide.leadingAnchor), 73 searchPageContentView.topAnchor.constraint(equalTo: searchPageScrollView.contentLayoutGuide.topAnchor), 74 searchPageContentView.widthAnchor.constraint(equalToConstant: searchPageContentView.frame.width), 75 searchPageContentView.trailingAnchor.constraint(equalTo: searchPageScrollView.contentLayoutGuide.trailingAnchor), 76 ]) 77 78 NSLayoutConstraint.activate([ 79 searchPageScrollView.contentLayoutGuide.bottomAnchor.constraint(equalTo: searchPageContentView.bottomAnchor) 80 ]) 81 82 //検索ボタン 83 searchButton.setTitle("検索", for: UIControl.State.normal) 84 searchButton.addTarget(self, action: #selector(searchButtonEvent(_:)), for: UIControl.Event.touchUpInside) 85 self.view.addSubview(searchButton) 86 searchButton.translatesAutoresizingMaskIntoConstraints = false 87 NSLayoutConstraint.activate([ 88 searchButton.centerXAnchor.constraint(equalTo: self.view.centerXAnchor), 89 searchButton.topAnchor.constraint(equalTo: self.view.topAnchor, constant: buttonVerticalMargin), 90 searchButton.heightAnchor.constraint(equalToConstant: 60.0), 91 searchButton.widthAnchor.constraint(equalTo: self.view.widthAnchor, multiplier: 0.86), 92 ]) 93 94     //入力欄構造体MainInputStructの配列 95 let mainInputs:[MainInputStruct] = [ 96 MainInputStruct(label: titleInputLabel, textField: titleInputTextField, labelText: "タイトル・書籍名", placeholderText: "タイトル・書籍名を入力"), 97 MainInputStruct(label: authorInputLabel, textField: authorInputTextField, labelText: "筆者・訳者", placeholderText: "筆者・訳者名を入力"), 98 MainInputStruct(label: publisherInputLabel, textField: publisherInputTextField, labelText: "出版社", placeholderText: "出版社名を入力"), 99 MainInputStruct(label: editionInputLabel, textField: editionInputTextField, labelText: "版数", placeholderText: "版数を入力", keyboardType: UIKeyboardType.numberPad.rawValue), 100 MainInputStruct(label: conditionInputLabel, textField: conditionInputTextField, labelText: "状態", placeholderText: "書籍の状態を選択"), 101 MainInputStruct(label: upperLimitInputLabel, textField: upperLimitInputTextField, labelText: "価格上限", placeholderText: "値段の上限を入力", keyboardType: UIKeyboardType.numberPad.rawValue), 102 MainInputStruct(label: isbnCodeInputLabel, textField: isbnCodeInputTextField, labelText: "ISBNコード", placeholderText: "ISBNコードを入力"), 103 ] 104 105 //appendMainInputs()メソッドで配置 106 self.appendMainInputs(structArray: mainInputs, target: searchPageContentView.topAnchor, firstConstant: (buttonVerticalMargin*2 + 60.0), appendTargetView: searchPageContentView) 107 NSLayoutConstraint.activate([ 108 searchPageContentView.heightAnchor.constraint(equalToConstant: 1200.0), 109 ]) 110 } 111 112 private func appendMainInputs(structArray inputs : [MainInputStruct], target targetAnchor: NSLayoutYAxisAnchor, firstConstant:CGFloat = 30.0, constant:CGFloat = 30.0, appendTargetView: UIView) { 113 var constantLength : CGFloat = firstConstant 114 var topTargetAnchor : NSLayoutYAxisAnchor = targetAnchor 115 for (index, input) in inputs.enumerated() { 116 if(index > 0) { 117 constantLength = constant 118 } 119 input.label.text = input.labelText 120 input.label.translatesAutoresizingMaskIntoConstraints = false 121 appendTargetView.addSubview(input.label) 122 NSLayoutConstraint.activate([ 123 input.label.leftAnchor.constraint(equalTo: appendTargetView.leftAnchor, constant: 9.0), 124 125 input.label.topAnchor.constraint(equalTo: topTargetAnchor, constant: constantLength), 126 ]) 127 input.textField.placeholder = input.placeholderText 128 input.textField.keyboardType = UIKeyboardType.asciiCapable 129 input.textField.translatesAutoresizingMaskIntoConstraints = false 130 appendTargetView.addSubview(input.textField) 131 NSLayoutConstraint.activate([ 132 input.textField.leftAnchor.constraint(equalTo: appendTargetView.leftAnchor), 133 input.textField.widthAnchor.constraint(equalTo: self.view.widthAnchor), 134 input.textField.heightAnchor.constraint(equalToConstant: 44.0), 135 136 input.textField.topAnchor.constraint(equalTo: input.label.bottomAnchor, constant: 6.0), 137 ]) 138 if(index == inputs.count) { 139 NSLayoutConstraint.activate([ 140 input.textField.bottomAnchor.constraint(equalTo: appendTargetView.bottomAnchor, constant: 0.0) 141 ]) 142 } 143 144 topTargetAnchor = input.textField.bottomAnchor 145 } 146 } 147}

試したこと

Hardware > Connect Hardware Keyboardはチェック済みです。
Simulatorの再起動とmacの再起動は試しました。

環境

Xcode11.3

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

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

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

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

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

eytyet

2019/12/29 07:23

「シミュレーター上でのTextFieldへのキーボード入力ができません。」というのは、具体的にどういう症状でしょうか。テキストフィールドをタップしてもカーソルが出ない、シミュレーター画面上にキーボードが表示されない、シュミレーターを動かしているmacでキーボードを打ってもテキストフィールドに入力されない、など、具体的な現象と、どうなって欲しいのかを教えてください。
1101hiroki_n

2019/12/29 08:21

ご返事ありがとうございます 挙動はdisabledに設定したような挙動で、カーソルが全く表示されません
eytyet

2019/12/30 06:40 編集

テキストフィールド上をタップしても反応してくれないのですね。 1) MainInputTextFieldの中で、isUserInteractionEnabledをfalseにはしていないですよね。MainInputTextFieldのコードは開示可能ですか? 2) 他の見えないUIViewが上にいて邪魔をしているというのがよくあるケースです。Debug View Hierarchyを表示して他のビューが邪魔をしてないか調べてみてはどうでしょうか。
1101hiroki_n

2019/12/30 03:58 編集

こちらMainInputTextField.swiftです ___ import UIKit class MainInputTextField: UITextField { @IBInspectable var padding: CGPoint = CGPoint(x: 9.0, y: 0.0) override func draw(_ rect: CGRect) { self.layer.backgroundColor = CGColor(srgbRed: 247/255, green: 247/255, blue: 247/255, alpha: 1.0) self.layer.borderWidth = 1.0 self.layer.borderColor = CGColor(srgbRed: 234/255, green: 234/255, blue: 234/255, alpha: 1.0) self.minimumFontSize = 16.0 self.isUserInteractionEnabled = true self.textColor = UIColor.init(red: 43/255, green: 43/255, blue: 43/255, alpha: 1.0) super.draw(rect) } override func textRect(forBounds bounds: CGRect) -> CGRect { return bounds.insetBy(dx: self.padding.x, dy: self.padding.y) } override func editingRect(forBounds bounds: CGRect) -> CGRect { return bounds.insetBy(dx: self.padding.x, dy: self.padding.y) } override func placeholderRect(forBounds bounds: CGRect) -> CGRect { return bounds.insetBy(dx: self.padding.x, dy: self.padding.y) } } ___ (1)のご指摘に関して、isUserInteractionEnabledはtrueで明記していました。 (2)でいただいたご指摘を受け確認したところ、特に悪さをしているviewは見当たりませんでした。
1101hiroki_n

2019/12/30 04:19

MainInputTextFieldとsearchPageContentView、searchPageContentViewとsearchPageScrollViewの間の制約の掛け方に問題があったようです。解決いたしました。 eytyet様、ご相談に応じていただきありがとうございました。
guest

回答1

0

自己解決

MainInputTextFieldとsearchPageContentView、searchPageContentViewとsearchPageScrollViewの間の制約の掛け方に問題があったようです。

MainInputTextFieldのwidthAnchorをsearchPageContentViewのwidthAnchorに、
searchPageContentViewのwidthAnchoをsearchPageScrollViewのwidthAnchorに設定したところ動作しました。

投稿2019/12/30 04:22

1101hiroki_n

総合スコア4

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問