UIImage (contentsOfFile :) devuelve cero a pesar del archivo existente en el directorio de caches

Intento guardar una instant谩nea de un mapa con una superposici贸n en el directorio de cach茅s y recuperarla cuando existe. Sin embargo, a pesar del archivo que se est谩 creando, UIImage (contentsOfFile 馃檪 devuelve nulo cuando bash recuperarlo. Imprim铆 las rutas de archivos tanto para escritura como para lectura y son las mismas y he verificado que el archivo existe al descargar el contenedor y consultar el directorio, y definitivamente el archivo existe.

驴Alguna idea de cu谩l es el problema aqu铆?

let cachesDirectory: URL = { let urls = FileManager.default.urls(for: .cachesDirectory, in: .userDomainMask) return urls[urls.endIndex - 1] }() let mapCachesDirectory = cachesDirectory.appendingPathComponent("map-snapshots", isDirectory: true) func configureMap(data: NSSet?) { mapView.isZoomEnabled = false mapView.isScrollEnabled = false mapView.isUserInteractionEnabled = false guard let data = data as? Set, data.count > 0 else { return } activityIndicatorView.isHidden = false activityIndicatorView.startAnimating() DispatchQueue.global(qos: .userInitiated).async { var points = [CLLocationCoordinate2D]() for object in data { guard object.locationLatitude != 0, object.locationLatitude != 0 else { continue } points.append(CLLocationCoordinate2DMake(object.locationLatitude, object.locationLongitude)) } DispatchQueue.main.async(execute: { self.createOverlay(points: points) self.activityIndicatorView.stopAnimating() self.activityIndicatorView.isHidden = true self.cacheMapImage(view: self.mapView) }) } } func cacheMapImage(view: UIView) { UIGraphicsBeginImageContextWithOptions(view.bounds.size, true, 0) view.drawHierarchy(in: view.bounds, afterScreenUpdates: true) let compositeImage = UIGraphicsGetImageFromCurrentImageContext() UIGraphicsEndImageContext() DispatchQueue.global(qos: .userInitiated).async { if let compositeImage = compositeImage, let info = self.info { let data = UIImagePNGRepresentation(compositeImage) do { var isDirectory: ObjCBool = false let fileManager = FileManager.default if fileManager.fileExists(atPath: self.mapCachesDirectory.absoluteString, isDirectory: &isDirectory) == false { try fileManager.createDirectory(at: self.mapCachesDirectory, withIntermediateDirectories: true, attributes: nil) } let fileURL = self.mapCachesDirectory.appendingPathComponent(info.uid).appendingPathExtension("png") try data?.write(to: fileURL) print("\(fileURL.absoluteString) Saved") } catch { log.error(error) } } } } func cachedMapImage() -> UIImage? { guard let info = info else { return nil } let filePath = mapCachesDirectory.appendingPathComponent(info.uid).appendingPathExtension("png").absoluteString let image = UIImage(contentsOfFile: filePath) print("\(filePath): \(image)") return image } func createOverlay(points: [CLLocationCoordinate2D]) { guard points.count > 0 else { return } let overlay = MKGeodesicPolyline(coordinates: points, count: points.count) mapView.add(overlay) let inset: CGFloat = 50.0 mapView.setVisibleMapRect(overlay.boundingMapRect, edgePadding: UIEdgeInsetsMake(inset,inset,inset,inset), animated: true) } 

El problema es que est谩 utilizando la propiedad de URL absoluteString donde deber铆a usar la propiedad de ruta. La diferencia entre absoluteString y las propiedades de path es que absoluteString incluye el esquema de url de archivo (“file: //”) que es la raz贸n por la que no encuentra el archivo en lo que se supon铆a que era su ruta, pero en realidad es su absoluteString.