为了在⽆⽹、弱⽹或者特殊外⽹环境下也能流畅地显示地图,腾讯地图SDK从4.3.5版本开始,提供了⼀套离线地图⽅案。可⽀持离线地图开关、城市列表获取、离线城市数据下载、下载状态回调、离线缓存管理等能⼒。 离线地图下载地址: 本篇文章为Android地图SDK离线地图使用教程,iOS离线地图教程请参考:https://lbs.qq.com/mobile/iOSMapSDK/mapGuide/offline 开启离线地图能力可按照以下步骤进⾏: 打开离线地图开关 获取离线地图的城市列表 获取某个城市的离线控制器 判断该城市是否有数据更新 执⾏离线数据下载 通过 在离线地图开关打开的前提下,通过 离线地图组件提供4个接⼝: 通过syncLatestData接口,刷新获取最新的数据 通过 在返回的 OfflineNation(国家) OfflineProvince(省会) OfflineCity(城市) 通过离线地图组件获取对某个城市的离线控制器,在三种情况下,会返回Null: 状态变化监听接⼝ 离线城市控制器提供4个接⼝: 在获取城市控制器之后,通过控制器可以检查城市是否需要进⾏数据更新,当该城市的离线数据未下 如果没有判断城市是否存在更新,直接执⾏下载,其内部也会进⾏数据更新的校验,结果都将在 通过城市控制器可以停止正在下载中的城市 通过城市控制器可以清理当前城市的缓存
iOS地图SDK、Android地图SDK
打开离线地图开关
TencentMapOptions
可以配置离线地图开关,在多个地图实例的情况下,离线地图开关状态保持
⼀致。TencentMapOptions options = new TencentMapOptions(); options.setOfflineMapEnable(true); MapView mapView = new MapView(context, options); TencentMap map = mapView.getMap();
获取离线地图的城市列表
TencentMap
的getMapComponent
接⼝,来获取离线地图组件OfflineMapComponent offlineComp = map.getMapComponent(OfflineMapComponent.class);
public interface OfflineMapComponent extends TencentMapComponent.Component { /** * 判断离线地图是否打开 * * @return 离线地图状态 */ boolean isOfflineMapEnable(); /** * 同步最新数据 * * @param listener 同步结果回调 */ void syncLatestData(OfflineMapSyncedListener listener); /** * 获取某一Item的离线地图数据 * * @param item 指定离线Item * @param listener 状态监听 * @return 离线地图数据,当传入的Item无效(null或者未包含在离线服务内) * 或 没有开启离线地图模式 * 或 离线地图初始化未完成时,返回null */ OfflineItemController getOfflineItemController(OfflineItem item, OfflineStatusChangedListener listener); /** * 获取离线数据列表 * * @return 最新离线Item列表 */ List<OfflineItem> getOfflineItemList(); /** * 异步获取离线数据列表,触发重新请求 * * @param callback 回调最新离线Item列表 */ void getOfflineItemList(Callback<List<OfflineItem>> callback); }
offlineComp.syncLatestData(new OfflineMapSyncedListener() { @Override public void onSynced(boolean result) { Log.i("初始化同步结果:" + result); if (result) { //处理离线数据 } } });
getOfflineItemList
接⼝可异步获取离线城市列表数据,也可以等待syncLatestData
结果,同步获
取离线列表//异步获取离线城市列表 offlineComp.getOfflineItemList(new Callback<List<OfflineItem>>(){ @Override public void callback(List<OfflineMapCity> result) { if(result != null) { mOfflineCityList = result; //拿到数据之后,选择城市进行下一步操作 } } }); //同步获取,当syncLatestData结果为true时,列表不为空 mOfflineCityList = offlineComp.getOfflineItemList();
OfflineItem
列表中,将提供每个离线城市的相关数据,OfflineItem
分三类:
数据
类型
说明
name
String
下载项显示名称
pinyin
String
唯⼀标示的拼⾳
size
long
数据⼤⼩
upgrade
boolean
是否需要更新
percentage
int
数据百分⽐[0-100]
获取某个城市的离线控制器
OfflineItem beijing = findCity("北京"); OfflineItemController cityController = offlineComp.getOfflineItemController(beijing, statusChangedListener);
public interface OfflineStatusChangedListener { /** * 离线状态回调 * * @param item 城市 * @param status 状态 */ void onStatusChanged(OfflineItem item, OfflineStatus status); }
public interface OfflineItemController { /** * 检查是否无效 * * @return true表示有远程更新或者本地缓存被破坏,需要执行下载 */ boolean checkInvalidate(); /** * 开启离线 * * @return 开启结果 */ boolean open(); /** * 关闭离线 * * @return 关闭结果 */ boolean close(); /** * 开始下载 */ void startDownload(); /** * 停止下载 */ void stopDownload(); /** * 移除缓存,不影响当前正在使用的离线城市 * @return true,清理成功 */ boolean removeCache(); }
判断该城市是否有数据更新
载、数据版本升级或者缓存被清理之后,都会返回trueif(cityController != null) { boolean needDownload = cityController.checkInvalidate(); if(needDownload) { //执行下载 cityController.startDownload(); } else { //跳过更新,打开离线 cityController.open(); } }
执行离线数据下载
OfflineMapStatusChangedListener回调中返回public enum OfflineStatus { /** * 离线错误 */ ERROR, /** * 准备下载 */ READY, /** * 开始下载 */ START, /** * 下载中 */ DOWNLOADING, /** * 取消下载 */ CANCEL, /** * 完成下载 */ COMPLETED, /** * 开启离线 */ OPEN, /** * 关闭离线 */ CLOSE }
停止下载
if (cityController != null) { cityController.stopDownload(); }
清理缓存
//关闭离线 cityController.close(); //清理该城市缓存 boolean ret = cityController.removeCache();
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算