ContentView.swift
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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 | // // ContentView.swift // SwiftUIProject // // Created by Cairocoders // import SwiftUI struct ContentView: View { @State var progress: CGFloat = 0 @State var doneLoading: Bool = false var body: some View { ZStack { if doneLoading { HomeView() .transition(AnyTransition.opacity.animation(.easeInOut(duration: 1.0))) } else { LoadingView(content: Image( "logo" ) .resizable() .scaledToFit() .padding(.horizontal, 50), progress: $progress) // Added to simulate asynchronous data loading .onAppear { DispatchQueue.main.asyncAfter(deadline: .now() + 2) { withAnimation { self.progress = 0 } DispatchQueue.main.asyncAfter(deadline: .now() + 0.8) { withAnimation { self.doneLoading = true } } } } } } } } struct ContentView_Previews: PreviewProvider { static var previews: some View { ContentView() } } struct ScaledMaskModifier<Mask: View>: ViewModifier { var mask: Mask var progress: CGFloat func body(content: Content) -> some View { content .mask(GeometryReader(content: { geometry in self.mask.frame(width: self.calculateSize(geometry: geometry) * self.progress, height: self.calculateSize(geometry: geometry) * self.progress, alignment: .center) })) } // Calculate Max Size of Mask func calculateSize(geometry: GeometryProxy) -> CGFloat { if geometry.size.width > geometry.size.height { return geometry.size.width } return geometry.size.height } } struct LoadingView<Content: View>: View { var content: Content @Binding var progress: CGFloat @State var logoOffset: CGFloat = 0 //Animation Y Offset var body: some View { content .modifier(ScaledMaskModifier(mask: Circle(), progress: progress)) .offset(x: 0, y: logoOffset) .onAppear { withAnimation(Animation.easeInOut(duration: 1)) { self.progress = 1.0 } withAnimation(Animation.easeInOut(duration: 0.4).repeatForever(autoreverses: true )) { self.logoOffset = 10 } } } } |
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 | // // HomeView.swift // SwiftUIProject // // Created by Cairocoders // import SwiftUI struct HomeView: View { var body: some View { ZStack { Color.blue.ignoresSafeArea() VStack { Text( "Hello, SwiftUI!" ) .font(.largeTitle) .bold() Button( "Getting Started" ) { } } } .accentColor(Color.black) } } struct HomeView_Previews: PreviewProvider { static var previews: some View { HomeView() } } |