비동기 처리 중에 사용자 작업을 사용하지 않도록 설정하는 방법
문제
계정 작성이라는 비동기 처리가 있지만, 작성 중에는 사용자의 조작을 무효화하고 싶다.
다만, 조사해도 유저 조작을 무효로 하는 방법은 없는 것 같다.
그래서 ZStack을 사용하여 위에 View를 겹쳐서 해결할 수 없는지 검토했다.
해결 방법
아래의 코드와 같이, isBusy가 true일 때만 Color.white를 겹쳐 보았더니, 아래의 View를 조작할 수 없는 것을 확인할 수 있었으므로, 이것으로 좋을 것 같다.
만약, 보다 좋은 방법이 있으면 코멘트 받을 수 있으면 도움이 됩니다・・・.
ZStack{
VStack{
TextField("ユーザー名", text: $vm.userName)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
TextField("メールアドレス", text: $vm.emailAddress)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
SecureField("パスワード", text: $vm.password)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
SecureField("パスワード確認", text: $vm.passwordConfirm)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
if vm.validationText != "" {
Text(vm.validationText)
.foregroundColor(.red)
.font(.footnote)
}
Button(
action: {
vm.createAccount()
}
){
Text("アカウント作成")
.padding(4)
.frame(maxWidth: .infinity)
.foregroundColor(Color.white)
.background(Color.gray)
.cornerRadius(8)
}
}
.padding(.horizontal)
if vm.isBusy {
Color.white
.opacity(0.7)
.edgesIgnoringSafeArea(.all)
.overlay(
ProgressView("アカウント作成中...")
.foregroundColor(.black)
)
}
}
Reference
이 문제에 관하여(비동기 처리 중에 사용자 작업을 사용하지 않도록 설정하는 방법), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/fluith/items/109144406f0f940eca26
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
아래의 코드와 같이, isBusy가 true일 때만 Color.white를 겹쳐 보았더니, 아래의 View를 조작할 수 없는 것을 확인할 수 있었으므로, 이것으로 좋을 것 같다.
만약, 보다 좋은 방법이 있으면 코멘트 받을 수 있으면 도움이 됩니다・・・.
ZStack{
VStack{
TextField("ユーザー名", text: $vm.userName)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
TextField("メールアドレス", text: $vm.emailAddress)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
SecureField("パスワード", text: $vm.password)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
SecureField("パスワード確認", text: $vm.passwordConfirm)
.autocapitalization(.none)
.textFieldStyle(RoundedBorderTextFieldStyle())
if vm.validationText != "" {
Text(vm.validationText)
.foregroundColor(.red)
.font(.footnote)
}
Button(
action: {
vm.createAccount()
}
){
Text("アカウント作成")
.padding(4)
.frame(maxWidth: .infinity)
.foregroundColor(Color.white)
.background(Color.gray)
.cornerRadius(8)
}
}
.padding(.horizontal)
if vm.isBusy {
Color.white
.opacity(0.7)
.edgesIgnoringSafeArea(.all)
.overlay(
ProgressView("アカウント作成中...")
.foregroundColor(.black)
)
}
}
Reference
이 문제에 관하여(비동기 처리 중에 사용자 작업을 사용하지 않도록 설정하는 방법), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/fluith/items/109144406f0f940eca26텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)