티스토리 뷰

iOS/SwiftUI

[SwiftUI] 화면전환

HarryJeonn 2022. 4. 28. 19:49

기본적인 화면전환은 NavigationLink를 사용해서 화면전환을 한다고 알고있다.

QR 코드 리더기를 테스트 해보는 중이였는데, QR코드가 인식되면 자동으로 화면전환이 이루어지는 것을 해보고 싶었다.

// Model

// ...

if metaObject.type == AVMetadataObject.ObjectType.qr {
    if let outputValue = metaObject.stringValue {
        print(outputValue)
        isCompleted = true
        session.stopRunning()
    }
}

// ...

QR코드 인식이 될 때 isCompleted라는 변수에 true값을 줬다.

// ViewModel

// ...

var isCompleted: Bool {
	model.isCompleted
}

// ...

ViewModel에서는 Model의 값이 변하는지 지켜보게 했다.

// View

// ...

@State var showProductView = false

// ...

NavigationLink(isActive: $showProductView) {
    SettingView()
} label: {
    // Scan 버튼
    Button(action: {}) {
        Circle()
            .frame(width: 71, height: 71)
            .foregroundColor(isPress ? Color(red: 209/255, green: 131/255, blue: 183/255) : Color(red: 114/255, green: 114/255, blue: 114/255))
            .overlay(
                Circle()
                    .stroke(lineWidth: 10)
                    .foregroundColor(isPress ? Color(red: 243/255, green: 165/255, blue: 217/255) : Color(red: 148/255, green: 148/255, blue: 148/255))
            )
            .onLongPressGesture(minimumDuration: .infinity) {
                print("long press")
            } onPressingChanged: { isPress in
                self.isPress = isPress
                self.showProductView = viewModel.isCompleted
                viewModel.changeScanState(isPress)
            }

    }.padding(.bottom, 20)
}.isDetailLink(false)

// ...

showProductView라는 @State 변수를 만들고 isCompleted가 true로 변경되면 화면전환을 했다.

NavigationLink(isActive: Binding<Bool>) {
	// 전환할 뷰
	View()
} label: {
	// 버튼 생김새
	Button()
}

🤔

지금 구현한 것도 어딘가 엉성하고 허점 투성이 인 것 같다..

이런 방식이 MVVM이 맞는지 의문이 좀 든다.. 어느 동작을 어디서 처리해야할지 잘 모르겠다.

누가 누구를 바라보고있고 이런건 대충 감이 잡히는데 구현하고 적용하는데는 조금 시간이 걸릴 것 같다.

많이 써보고 많이 삽질해보고 익숙해지는 방법밖에 없는 것 같다.

 

 

제가 틀렸거나 다른 의견이 있으시다면 댓글로 남겨주시면 감사하겠습니다 :)

'iOS > SwiftUI' 카테고리의 다른 글

[SwiftUI] UIRepresentable  (0) 2022.05.02
[SwiftUI] Custom Alert  (0) 2022.04.28
[SwiftUI] Stack  (0) 2022.04.24
[SwiftUI] Image  (0) 2022.04.24
[SwiftUI] Text  (0) 2022.04.24
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/05   »
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
글 보관함