单军华
2017-07-12 20d1260d26b028897f3c0935c12fc35aa37b2e93
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
//
//  BMKTileLayer.h
//  MapComponent
//
//  Created by wzy on 15/8/7.
//  Copyright © 2015年 baidu. All rights reserved.
//
 
#ifndef BMKTileLayer_h
#define BMKTileLayer_h
#import "BMKOverlay.h"
 
/**
 @brief 该类是覆盖在球面墨卡托投影上的图片tiles的数据源,是抽象类,不能直接使用该类添加瓦片图,需要使用其子类(BMKURLTileLayer或BMKSyncTileLayer)
 *瓦片图片是jpeg或者png格式,size为256x256
 */
@interface BMKTileLayer : NSObject <BMKOverlay>
 
/// tileLayer的可见最小Zoom值,默认3
@property (nonatomic, assign) NSInteger minZoom;
 
/// tileLayer的可见最大Zoom值,默认21,且不能小于minZoom
@property (nonatomic, assign) NSInteger maxZoom;
 
/// tileOverlay的可渲染区域,默认世界范围
@property (nonatomic) BMKMapRect visibleMapRect;
 
@end
 
/**
 @brief 通过提供url模板的方法,提供数据源。不应该继承该类,且必须通过 initWithURLTemplate: 来初始化
 *瓦片图片是jpeg或者png格式,size为256x256
 */
@interface BMKURLTileLayer : BMKTileLayer
 
/// 同initWithURLTemplate:中的URLTemplate
@property (readonly) NSString *URLTemplate;
 
/*!
 @brief 根据指定的URLTemplate生成tileOverlay
 @param URLTemplate是一个包含"{x}","{y}","{z}"的字符串,"{x}","{y}"表示tile的坐标,"{z}"表示当tile显示的级别。"{x}","{y}","{z}"会被tile的坐标值所替换,并生成用来加载tile图片数据的URL 。例如: http://server/path?x={x}&y={y}&z={z}。
 @return 以指定的URLTemplate字符串生成tileOverlay
 */
- (id)initWithURLTemplate:(NSString *)URLTemplate;
 
/**
 @brief 清除当前瓦片图层缓存图片
 */
- (BOOL)cleanTileDataCache;
 
@end
 
/**
 @brief 通过同步方法获取瓦片数据,是一个抽象类,需要通过继承该类,并重载 tileForX:y:zoom: 方法
 *瓦片图片是jpeg或者png格式,size为256x256
 */
@interface BMKSyncTileLayer : BMKTileLayer
 
/**
 @brief 通过同步方法获取瓦片数据,子类必须实现该方法
        这个方法会在多个线程中调用,需要考虑线程安全
 @param (x, y, zoom)瓦片坐标
 @return (x, y, zoom)所对应瓦片的UIImage对象
*/
- (UIImage *)tileForX:(NSInteger)x y:(NSInteger)y zoom:(NSInteger)zoom;
 
@end
 
/**
 @brief 通过异步方法获取瓦片数据,是一个抽象类,需要通过继承该类,并重载 loadTileForX:y:zoom:result: 方法
 *瓦片图片是jpeg或者png格式,size为256x256
 */
@interface BMKAsyncTileLayer : BMKTileLayer
 
/**
 @brief 通过异步方法获取瓦片数据,子类必须实现该方法
 @param (x, y, zoom)瓦片坐标
 @return result 用来传入瓦片数据或加载瓦片失败的error访问的回调block
 */
- (void)loadTileForX:(NSInteger)x y:(NSInteger)y zoom:(NSInteger)zoom result:(void (^)(UIImage *tileImage, NSError *error))result;
 
@end
 
#endif /* BMKTileLayer_h */