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}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。