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 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | // // ContentView.swift // SwiftUIProject // // Created by Cairocoders // import SwiftUI struct ContentView: View { @State var selected = 0 var body: some View { ZStack(alignment: .bottom){ VStack{ if self.selected == 0{ GeometryReader{_ in VStack(spacing: 15){ Spacer() Text( "Home" ) .font(.title) .foregroundColor(.white) Image( "1" ).resizable().frame(height: 250).cornerRadius(15) Spacer() }.padding() } } else if self.selected == 1{ GeometryReader{_ in VStack(spacing: 15){ Spacer() Text( "Wishlist" ) .font(.title) .foregroundColor(.white) Image( "2" ).resizable().frame(height: 250).cornerRadius(15) Spacer() }.padding() } } else { GeometryReader{_ in VStack(spacing: 15){ Spacer() Text( "Cart" ) .font(.title) .foregroundColor(.white) Image( "3" ).resizable().frame(height: 250).cornerRadius(15) Spacer() }.padding() } } }.background(Color.gray) .edgesIgnoringSafeArea(.all) FloatingTabbar(selected: self.$selected) } } } struct ContentView_Previews: PreviewProvider { static var previews: some View { ContentView() } } struct FloatingTabbar : View { @Binding var selected : Int @State var expand = false var body : some View{ HStack{ Spacer(minLength: 0) HStack{ if !self.expand{ Button(action: { self.expand.toggle() }) { Image(systemName: "arrow.left" ).foregroundColor(.green).padding() } } else { Button(action: { self.selected = 0 }) { Image(systemName: "house" ).foregroundColor(self.selected == 0 ? .green : .gray).padding(.horizontal) } Spacer(minLength: 15) Button(action: { self.selected = 1 }) { Image(systemName: "suit.heart" ).foregroundColor(self.selected == 1 ? .green : .gray).padding(.horizontal) } Spacer(minLength: 15) Button(action: { self.selected = 2 }) { Image(systemName: "cart" ).foregroundColor(self.selected == 2 ? .green : .gray).padding(.horizontal) } } }.padding(.vertical,self.expand ? 20 : 8) .padding(.horizontal,self.expand ? 35 : 8) .background(Color.white) .clipShape(Capsule()) .padding(22) .onLongPressGesture { self.expand.toggle() } .animation(.interactiveSpring(response: 0.6, dampingFraction: 0.6, blendDuration: 0.6)) } } } |