SwiftUI로 키보드로 문자가 숨기지 않도록 처리를 넣을 수 있다
UIKit과 마찬가지로 키보드가 닫히는 처리는 원래 들어 있지 않습니다.
キーボードで入力される文字が隠れないようにする
처리 만들기 구현
키보드를 모니터링하는 클래스
import SwiftUI
import Combine
class KeyboardObserver: ObservableObject {
@Published var keyboardHeight: CGFloat = 0.0
/// Observerの追加
func addObserver() {
NotificationCenter
.default
.addObserver(self,
selector: #selector(self.keyboardWillChangeFrame(_:)),
name: UIResponder.keyboardWillChangeFrameNotification,
object: nil)
}
/// Observerの削除
func removeObserver() {
NotificationCenter
.default
.removeObserver(self,
name: UIResponder.keyboardWillChangeFrameNotification,
object: nil)
}
/// キーボードのフレーム検知処理
/// - Parameter notification: Notification
@objc func keyboardWillChangeFrame(_ notification: Notification) {
if let endFrame = notification
.userInfo?[UIResponder.keyboardFrameEndUserInfoKey] as? NSValue,
let beginFrame = notification
.userInfo?[UIResponder.keyboardFrameBeginUserInfoKey] as? NSValue {
let endFrameMinY: CGFloat = endFrame.cgRectValue.minY
let beginFrameMinY: CGFloat = beginFrame.cgRectValue.minY
self.keyboardHeight = beginFrameMinY - endFrameMinY
if self.keyboardHeight < 0 {
self.keyboardHeight = 0
}
}
}
}
View 클래스
struct ContentView: View {
@ObservedObject var keyboard = KeyboardObserver()
@State var text: String = ""
var body: some View {
VStack {
Spacer()
Rectangle()
.frame(width: 300, height: 300)
TextField("入力", text: self.$text)
.padding()
}.onAppear(perform: {
self.keyboard.addObserver()
}).onDisappear(perform: {
self.keyboard.removeObserver()
}).padding(.bottom,
self.keyboard.keyboardHeight)
.animation(.easeOut)
}
}
실행 결과
요약
Reference
이 문제에 관하여(SwiftUI로 키보드로 문자가 숨기지 않도록 처리를 넣을 수 있다), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/shira-shun/items/2768393fa3e0be333639텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)