BMKOfflineMap.h 3.36 KB
/*
 *  BMKOfflineMap.h
 *  BMapKit
 *
 *  Copyright 2011 Baidu Inc. All rights reserved.
 *
 */

#import <Foundation/Foundation.h>
#import "BMKOfflineMapType.h"


@protocol BMKOfflineMapDelegate;

///离线地图事件类型
enum  {
	TYPE_OFFLINE_UPDATE = 0,        ///<下载或更新
	TYPE_OFFLINE_ZIPCNT	= 1,        ///<检测到的压缩包个数
	TYPE_OFFLINE_UNZIP = 2,			///<当前解压的离线包
	TYPE_OFFLINE_ERRZIP = 3,		///<错误的离线包
	TYPE_OFFLINE_NEWVER = 4,		///<有新版本
	TYPE_OFFLINE_UNZIPFINISH = 5,	///<扫描完毕
	TYPE_OFFLINE_ADD = 6			///<新增离线包
};

///离线地图服务
@interface BMKOfflineMap : NSObject

@property (nonatomic, weak) id<BMKOfflineMapDelegate> delegate;



/**
 *扫描离线地图压缩包,异步函数
 *@return 成功返回YES,否则返回NO
 */
- (BOOL)scan:(BOOL)deleteFailed;

/**
 *启动下载指定城市id的离线地图
 *@param cityID 指定的城市id
 *@return 成功返回YES,否则返回NO
 */
- (BOOL)start:(int)cityID;

/**
 *启动更新指定城市id的离线地图
 *@param cityID 指定的城市id
 *@return 成功返回YES,否则返回NO
 */
- (BOOL)update:(int)cityID;

/**
 *暂停下载指定城市id的离线地图
 *@param cityID 指定的城市id
 *@return 成功返回YES,否则返回NO
 */
- (BOOL)pause:(int)cityID;

/**
 *删除下载指定城市id的离线地图
 *@param cityID 指定的城市id
 *@return 成功返回YES,否则返回NO
 */
- (BOOL)remove:(int)cityID;

/**
 *返回热门城市列表
 *@return 热门城市列表,用户需要显示释放该数组,数组元素为BMKOLSearchRecord
 */
- (NSArray*)getHotCityList;

/**
 *返回所有支持离线地图的城市列表
 *@return 支持离线地图的城市列表,用户需要显示释放该数组,数组元素为BMKOLSearchRecord
 */
- (NSArray*)getOfflineCityList;

/**
 *根据城市名搜索该城市离线地图记录
 *@param cityName 城市名
 *@return 该城市离线地图记录,用户需要显示释放该数组,数组元素为BMKOLSearchRecord
 */
- (NSArray*)searchCity:(NSString*)cityName;

/**
 *返回各城市离线地图更新信息
 *@return 各城市离线地图更新信息,用户需要显示释放该数组,数组元素为BMKOLUpdateElement
 */
- (NSArray*)getAllUpdateInfo;

/**
 *返回指定城市id离线地图更新信息
 *@param cityID 指定的城市id
 *@return 指定城市id离线地图更新信息,用户需要显示释放该数据
 */
- (BMKOLUpdateElement*)getUpdateInfo:(int)cityID;

@end


///离线地图delegate,用于获取通知
@protocol BMKOfflineMapDelegate<NSObject>
/**
 *返回通知结果
 *@param type 事件类型: TYPE_OFFLINE_UPDATE,TYPE_OFFLINE_ZIPCNT,TYPE_OFFLINE_UNZIP, TYPE_OFFLINE_ERRZIP, TYPE_VER_UPDATE, TYPE_OFFLINE_UNZIPFINISH, TYPE_OFFLINE_ADD
 *@param state 事件状态,当type为TYPE_OFFLINE_UPDATE时,表示正在下载或更新城市id为state的离线包,当type为TYPE_OFFLINE_ZIPCNT时,表示检测到state个离线压缩包,当type为TYPE_OFFLINE_ADD时,表示新安装的离线地图数目,当type为TYPE_OFFLINE_UNZIP时,表示正在解压第state个离线包,当type为TYPE_OFFLINE_ERRZIP时,表示有state个错误包,当type为TYPE_VER_UPDATE时,表示id为state的城市离线包有更新,当type为TYPE_OFFLINE_UNZIPFINISH时,表示扫瞄完成,成功导入state个离线包
 */
- (void)onGetOfflineMapState:(int)type withState:(int)state;

@end