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

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

詳細はこちら
iOS

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

Xcode

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

Swift

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

iPhone

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

Q&A

解決済

1回答

1794閲覧

SwiftUI キーボード開閉判定文があると画面遷移先のキーボードが一度閉じてしまう

LIATARET

総合スコア17

iOS

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

Xcode

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

Swift

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

iPhone

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

0グッド

0クリップ

投稿2021/02/16 15:50

ContentViewで、キーボードを出した時は栞アイコンをグレーアウトさせるために、.onReceive(NotificationCenter.default.publisher〜の箇所を加えました。

ContentViewでは期待通りにキーボードも開き、栞アイコンもアクティブ・非アクティブになりましたが、ContentView ➡️ AlphabetView ➡️ BetaView にあるテキストフィールドをタップすると、キーボードが開かず AlphabetViewに戻ってしまいます。

それ以降は戻ったAlphabetViewからそのままBetaViewに遷移するとテキストフィールドが開きます。

ただ、ContentViewまで戻るとBetaViewで同じ結果となります。

.onReceive(NotificationCenter.default.publisher〜の箇所を削除するとBetaViewのキーボードは開くのですが、栞アイコンをグレーアウト出来ません。

どのようにすれば解決するでしょうか?
(Xcode12.4)

Swift

1 2import SwiftUI 3import Foundation 4 5struct ContentView: View { 6 @State private var isAlphabetModal = false 7 @State private var string: String = "" 8 @State private var keyboardOpen = false 9 10 var body: some View { 11 ZStack { 12 VStack(alignment: .center) { 13 HStack { 14 TextField("", text: $string) 15 .overlay(RoundedRectangle(cornerRadius: 5).stroke(Color.blue, lineWidth: 1)) 16 .keyboardType(.decimalPad) 17 .textFieldStyle(RoundedBorderTextFieldStyle()) 18 .frame(width: 80, height: 30, alignment: .center) 19 } 20 } 21 Group { 22 VStack { 23 Spacer() 24 HStack { 25 Spacer() 26 if (self.keyboardOpen == false) { 27 Button(action: { self.isAlphabetModal = true }) { 28 Image(systemName: "bookmark.fill") 29 .resizable() 30 .scaledToFit() 31 .frame(width: 40, height: 40, alignment: .center) 32 }.sheet(isPresented: self.$isAlphabetModal) { AlphabetView() } 33 .padding() 34 } else { 35 Button(action: {}) { 36 Image(systemName: "bookmark.fill") 37 .resizable() 38 .scaledToFit() 39 .frame(width: 40, height: 40, alignment: .center) 40 .foregroundColor(Color(UIColor.opaqueSeparator)) 41 }.padding() 42 } 43 Spacer() 44 } 45 } 46 } 47 } 48 .onReceive(NotificationCenter.default.publisher(for: UIResponder.keyboardWillShowNotification)) { _ in 49 self.keyboardOpen = true 50 } 51 .onReceive(NotificationCenter.default.publisher(for: UIResponder.keyboardWillHideNotification)) { _ in 52 self.keyboardOpen = false 53 } 54 } 55} 56 57struct AlphabetView: View { 58 @State private var isBetaModal = false 59 @State private var newAlpha = "" 60 @State private var items = ["A", "B", "C", "D", "E", "F", "G", "H"] 61 62 var body: some View { 63 ZStack(alignment: .bottomTrailing) { 64 List { 65 ForEach(items, id: .self) { item in Text(item) } 66 } 67 .sheet(isPresented: $isBetaModal, onDismiss: { 68 if (self.newAlpha != "") { 69 self.items.append(self.newAlpha) 70 self.newAlpha = "" 71 } 72 }) { BetaView(inputItem: $newAlpha) 73 } 74 Button(action: { self.isBetaModal.toggle() }) { 75 Image(systemName: "plus.circle.fill") 76 .resizable() 77 .frame(width: 30, height: 30) 78 }.padding() 79 } 80 } 81} 82 83struct BetaView: View { 84 @Environment(.presentationMode) var presentationMode 85 @Binding var inputItem: String 86 87 var body: some View { 88 VStack { 89 Spacer() 90 TextField("TEST", text: $inputItem) 91 .frame(width: 120, height: 30) 92 .background(Color.white) 93 .overlay(RoundedRectangle(cornerRadius: 5).stroke(Color.blue, lineWidth: 1)) 94 Spacer() 95 .frame(width: 120, height: 30) 96 Spacer() 97 HStack { 98 Spacer() 99 Button(action: { self.inputItem = "" 100 self.presentationMode.wrappedValue.dismiss() 101 }) { Text("CANCEL") 102 } 103 Spacer() 104 Button(action: { self.presentationMode.wrappedValue.dismiss() 105 }) { Text("OK") 106 }.disabled(inputItem.count == 0) 107 Spacer() 108 } 109 }.padding() 110 } 111} 112 113extension UIApplication { 114 func closeKeyboard() { 115 sendAction(#selector(UIResponder.resignFirstResponder), to: nil, from: nil, for: nil) 116 } 117 118 func addTapGestureRecognizer() { 119 guard let window = windows.first else { return } 120 let tapGesture = UITapGestureRecognizer(target: window, action: #selector(UIView.endEditing)) 121 tapGesture.cancelsTouchesInView = false 122 tapGesture.delegate = self 123 tapGesture.name = "MyTapGesture" 124 window.addGestureRecognizer(tapGesture) 125 } 126} 127 128extension UIApplication: UIGestureRecognizerDelegate { 129 public func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, 130 shouldRecognizeSimultaneouslyWith otherGestureRecognizer: UIGestureRecognizer) -> Bool { 131 return false 132 } 133} 134 135struct ContentView_Previews: PreviewProvider { 136 static var previews: some View { 137 ContentView() 138 } 139} 140 141 142//////////////////////////////////////////////////////////////// 143import SwiftUI 144 145@main 146struct AlphabetApp: App { 147 var body: some Scene { 148 WindowGroup { 149 ContentView() 150 .onAppear(perform: UIApplication.shared.addTapGestureRecognizer) 151 } 152 } 153}

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

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

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

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

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

guest

回答1

0

自己解決

ContentViewのGroup配下のVStack{}に.ignoresSafeArea(.keyboard, edges: .bottom)を追加して、グレーアウトではなく栞アイコン自体を表示させないことで解決としました。

投稿2021/02/17 04:47

LIATARET

総合スコア17

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問