// // ContentView.swift // Testapp // // Created by Cairocoders // import SwiftUI struct ContentView: View { let getURL = "https://images.pexels.com/photos/3225517/pexels-photo-3225517.jpeg?auto=compress&cs=tinysrgb&dpr=1&w=500" var body: some View { URLImage(url: getURL) .aspectRatio(contentMode: .fit) .frame(width: 200) } } struct ContentView_Previews: PreviewProvider { static var previews: some View { ContentView() } } struct URLImage: View { private enum LoadState { case loading, success, failure } private class Loader: ObservableObject { var data = Data() var state = LoadState.loading init(url: String) { guard let parsedURL = URL(string: url) else { fatalError("Invalid URL: \(url)") } URLSession.shared.dataTask(with: parsedURL) { data, response, error in if let data = data, data.count > 0 { self.data = data self.state = .success } else { self.state = .failure } DispatchQueue.main.async { self.objectWillChange.send() } }.resume() } } @StateObject private var loader: Loader var loading: Image var failure: Image var body: some View { selectImage() .resizable() } init(url: String, loading: Image = Image(systemName: "photo"), failure: Image = Image(systemName: "multiply.circle")) { _loader = StateObject(wrappedValue: Loader(url: url)) self.loading = loading self.failure = failure } private func selectImage() -> Image { switch loader.state { case .loading: return loading case .failure: return failure default: if let image = UIImage(data: loader.data) { return Image(uiImage: image) } else { return failure } } } }
article
Tuesday, May 25, 2021
SwiftUI how to add URL image
SwiftUI how to add URL image