我正在开发一个基于 map 的应用程序。我使用 MKTileOverlay
来显示一些动态内容。有时,当新信息到达时,某些图 block 需要重新加载。
我尝试在主线程中调用 overlayRenderer.setNeedsDisplayInMapRect(mapRect)
但显然在我的情况下它不会触发 map 重绘。到目前为止,唯一可行的方法是 overlayRenderer.reloadData()
。但是,这将导致重新加载整个内容(而不仅仅是特定区域)并导致 View 闪烁,所以这不是我的选择。
任何人都可以就此提供任何建议吗?谢谢和干杯。
我终于想通了。事实上,叠加层没有更新并不是由于setNeedsDisplayInMapRect
。经过多次检查,我发现 setNeedsDisplayInMapRect
实际上导致了 drawMapRect:zoomScale:inContext:
的运行,但是,默认重绘会以某种方式生成相同的平铺图像。我猜这可能是由于 MKTileOverlayRender 的一些内部缓存。
我的解决方案是继承 MKTileOverlayRender
,并在新类中:
override func canDrawMapRect(mapRect: MKMapRect, zoomScale: MKZoomScale) -> Bool {
let tilePath = self.tilePathForMapRect(mapRect, andZoomScale: zoomScale)
let tilePathString = stringForTilePath(tilePath)
if let _ = self.cache.objectForKey(tilePathString) {
return true
} else {
let tileOverlay = self.overlay as! MKTileOverlay
tileOverlay.loadTileAtPath(tilePath, result: {
data, error in
if error == nil && data != nil {
if let image = UIImage(data: data!) {
self.cache.setObject(image, forKey: tilePathString)
self.setNeedsDisplayInMapRect(mapRect, zoomScale: zoomScale)
}
}
})
return false
}
}
override func drawMapRect(mapRect: MKMapRect, zoomScale: MKZoomScale, inContext context: CGContext) {
let tilePath = self.tilePathForMapRect(mapRect, andZoomScale: zoomScale)
let tilePathString = stringForTilePath(tilePath)
if let image = self.cache.objectForKey(tilePathString) as? UIImage {
CGContextDrawImage(context, self.rectForMapRect(mapRect), image.CGImage)
} else {
super.setNeedsDisplayInMapRect(mapRect, zoomScale: zoomScale)
}
self.cache.removeObjectForKey(tilePathString)
}
关于ios - MKTileOverlay:如何重新加载特定的图 block 或区域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38081372/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |