我正在创建子视图,却遇到此错误:
SignInButtons.swift:54:34: error: cannot convert value of type 'String' to expected argument type 'Binding<String>'
signInUrl: "http://www.apple.com",
^~~~~~~~~~~~~~~~~~~~~~struct
我也知道了:
'ContentView' initializer is inaccessible due to 'private' protection level
===================
ContentView: View {
import SwiftUI
struct ContentView: View {
//our color palette
let colorWheel : [String: Color] = [
"darkOrange" : Color.init(hex: "F1615D"),
"mediumOrange" : Color.init(hex: "FF8761"),
"darkYellow" : Color.init(hex: "FFC575"),
"lightYellow" : Color.init(hex: "F1FAC6"),
"brightAqua" : Color.init(hex: "79E6E3"),
"lightAqua" : Color.init(hex: "a8e6cf"),
"limeGreen" : Color.init(hex: "dcedc1"),
"brightPeach" : Color.init(hex: "ff8b94"),
"mediumPeach" : Color.init(hex: "ffaaa5"),
"lightPeach" : Color.init(hex: "ffd3b6"),
]
@State private var backgroundColor:Color
@State private var signInUrl = "http://www.apple.com"
@State private var showModal = false
private var detailSize = CGSize(width: 0, height: UIScreen.main.nativeBounds.height)
var body: some View {
ZStack{
VStack {
AnimatedContentView()
Spacer()
SignInButtons(backgroundColor: self.backgroundColor,
signInUrl: self.$signInUrl,
showModal: self.$showModal)
Spacer().frame(height: CGFloat(100))
}
.onAppear() {
self.backgroundColor = self.colorWheel["darkOrange"]!
}
.foregroundColor(Color.black.opacity(0.7))
.edgesIgnoringSafeArea(.all)
VStack {
AskForEmailView(showModal: self.$showModal)
.offset( self.showModal ? CGSize.zero : detailSize)
}
} //end zStack
}
}
struct ContentView_Previews: PreviewProvider {
enum MyDeviceNames: String, CaseIterable {
case iPhoneXrMax = "iPhone 11 Pro Max"
// case iphoneX = "iPhone X"
// case iPhoneXs = "iPhone Xs"
// case iPhoneXsMax = "iPhone Xs Max"
// case iPad = "iPad Pro (11-inch)"
static var all: [String] {
return MyDeviceNames.allCases.map { $0.rawValue }
}
}
static var previews: some View {
//ContentView()
Group {
ForEach(MyDeviceNames.all, id: \.self) { deviceName in
ContentView(detailSize: CGSize.zero)
.previewDevice(PreviewDevice(rawValue: deviceName))
.previewDisplayName(deviceName)
}
// ForEach(MyDeviceNames.all, id: \.self) { deviceName in
// ContentView()
// .colorScheme(.dark)
// .background(Color.black)
// .edgesIgnoringSafeArea(.all)
// .previewDevice(PreviewDevice(rawValue: deviceName))
// .previewDisplayName(deviceName)
// }
}
}
}
import SwiftUI
struct SignInButtons: View {
var backgroundColor:Color
@Binding var signInUrl : String
@Binding var showModal : Bool
var body: some View {
VStack(spacing: 0) {
//using text w tap gesture - to do: make into its own component
Text("Sign in with Facebook")
.fontWeight(.light)
.font(.title)
.padding()
.frame(minWidth: 0, maxWidth: .infinity, minHeight: 0, maxHeight: 70, alignment: .top)
.background(Color.blue.opacity(0.8))
.foregroundColor(Color.white)
.onTapGesture {
self.signInUrl = "http://www.facebook.com"
self.showModal.toggle()
}
//using a button
Button(action: {
print("Button Pushed")
self.signInUrl = "http://www.google.com"
self.showModal.toggle()
}) {
Text("Sign in with Google")
.fontWeight(.light)
.font(.title)
.padding()
.frame(minWidth: 0, maxWidth: .infinity, minHeight: 0, maxHeight: 70, alignment: .top)
.background(backgroundColor)
.foregroundColor(Color.white)
}
}
.navigationBarHidden(true)
.edgesIgnoringSafeArea([.top, .bottom])
}
}
struct SignInButtons_Previews: PreviewProvider {
static var previews: some View {
SignInButtons(backgroundColor: Color.blue,
signInUrl: "http://www.apple.com",
showModal: false)
}
}
答案 0 :(得分:4)
这里是可行的方法-对预览使用常量绑定
struct SignInButtons_Previews: PreviewProvider {
static var previews: some View {
SignInButtons(backgroundColor: Color.blue,
signInUrl: .constant("http://www.apple.com"),
showModal: .constant(false))
}
}