मैंने एक स्विफ्टयूआई वर्ग बनाने की कोशिश की जो UIViewRepresentable के अनुरूप है और makeUIView और updateUIView लागू करता है। लेकिन इसे पूरा करने में सक्षम नहीं है। यहाँ कोड है:
कोड:
struct ImagePicker : UIViewRepresentable {
@Binding var image: UIImage
class Coordinator: NSObject, UIImagePickerControllerDelegate, UINavigationControllerDelegate {
@Binding var image: UIImage
init(image: Binding<UIImage>) {
$image = image
}
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
if let possibleImage = info[.editedImage] as? UIImage {
image = possibleImage
} else if let possibleImage = info[.originalImage] as? UIImage {
image = possibleImage
} else {
}
}
}
func makeCoordinator() -> Coordinator {
return Coordinator(image: $image)
}
func makeUIView(context: UIViewRepresentableContext<ImagePicker>) -> UIImageView {
let imageview = UIImageView()
let picker = UIImagePickerController()
picker.delegate = context.coordinator
return imageview
}
func updateUIView(_ uiView: UIImageView,
context: UIViewRepresentableContext<ImagePicker>) {
uiView.image = image
}
}
मैंने इमेजपिकर को नियंत्रण के रूप में आजमाया लेकिन उपयोग करने में असमर्थ।
3
Monil Gandhi
19 जुलाई 2019, 13:17
2 जवाब
सबसे बढ़िया उत्तर
मैं यहां presentationMode
का उपयोग कर रहा हूं, यह देखने के लिए कि यह प्रस्तुत कर रहा है या नहीं?
इसका उपयोग करके आप dismiss()
UIImagePickerController
कर सकते हैं।
स्विफ्टयूआई पूर्वावलोकन के लिए नमूना कोड:
import SwiftUI
struct ContentView: View {
@State var isShowPicker: Bool = false
@State var image: Image? = Image("placeholder")
var body: some View {
NavigationView {
ZStack {
VStack {
image?
.resizable()
.scaledToFit()
.frame(height: 320)
Button(action: {
withAnimation {
self.isShowPicker.toggle()
}
}) {
Image(systemName: "photo")
.font(.headline)
Text("IMPORT").font(.headline)
}.foregroundColor(.black)
Spacer()
}
}
.sheet(isPresented: $isShowPicker) {
ImagePicker(image: self.$image)
}
.navigationBarTitle("Pick Image")
}
}
}
struct ImagePicker: UIViewControllerRepresentable {
@Environment(\.presentationMode)
var presentationMode
@Binding var image: Image?
class Coordinator: NSObject, UINavigationControllerDelegate, UIImagePickerControllerDelegate {
@Binding var presentationMode: PresentationMode
@Binding var image: Image?
init(presentationMode: Binding<PresentationMode>, image: Binding<Image?>) {
_presentationMode = presentationMode
_image = image
}
func imagePickerController(_ picker: UIImagePickerController,
didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
let uiImage = info[UIImagePickerController.InfoKey.originalImage] as! UIImage
image = Image(uiImage: uiImage)
presentationMode.dismiss()
}
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
presentationMode.dismiss()
}
}
func makeCoordinator() -> Coordinator {
return Coordinator(presentationMode: presentationMode, image: $image)
}
func makeUIViewController(context: UIViewControllerRepresentableContext<ImagePicker>) -> UIImagePickerController {
let picker = UIImagePickerController()
picker.delegate = context.coordinator
return picker
}
func updateUIViewController(_ uiViewController: UIImagePickerController,
context: UIViewControllerRepresentableContext<ImagePicker>) {
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
NavigationView {
ContentView()
}
}
}
3
Kampai
25 पद 2019, 16:22
कृपया इसे आजमाएं
कोड:
import SwiftUI
struct OpenGallary: UIViewControllerRepresentable {
let isShown: Binding<Bool>
let image: Binding<Image?>
class Coordinator: NSObject, UINavigationControllerDelegate, UIImagePickerControllerDelegate {
let isShown: Binding<Bool>
let image: Binding<Image?>
init(isShown: Binding<Bool>, image: Binding<Image?>) {
self.isShown = isShown
self.image = image
}
func imagePickerController(_ picker: UIImagePickerController,
didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
let uiImage = info[UIImagePickerController.InfoKey.originalImage] as! UIImage
self.image.wrappedValue = Image(uiImage: uiImage)
self.isShown.wrappedValue = false
}
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
isShown.wrappedValue = false
}
}
func makeCoordinator() -> Coordinator {
return Coordinator(isShown: isShown, image: image)
}
func makeUIViewController(context: UIViewControllerRepresentableContext<OpenGallary>) -> UIImagePickerController {
let picker = UIImagePickerController()
picker.delegate = context.coordinator
return picker
}
func updateUIViewController(_ uiViewController: UIImagePickerController,
context: UIViewControllerRepresentableContext<OpenGallary>) {
}
}
पिकर को दृश्य के ठीक ऊपर प्रदर्शित किया जाता है, संक्रमण के बिना चयनित छवि किसी भी प्रकार के एनीमेशन के बिना दिखाई देती है, और छवि पिकर दिखाएँ बटन को बदल देती है
उसके बाद डिस्प्ले व्यू बनाएं जिसमें आप कॉल कर सकते हैं इस इमेज को दिखाएं
struct ContentView: View {
@State var showImagePicker: Bool = false
@State var image: Image?
var body: some View {
ZStack {
VStack {
Button(action: {
withAnimation {
self.showImagePicker.toggle()
}
}) {
Text("Show image picker")
}
image?.resizable().frame(width: 100, height: 100)
}
if (showImagePicker) {
OpenGallary(isShown: $showImagePicker, image: $image)
}
}
}
}
1
NøBi Mac
4 फरवरी 2020, 13:32