RMMapboxSource.h
7.5 KB
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
//
// RMMapboxSource.h
//
// Created by Justin R. Miller on 5/17/11.
// Copyright 2012-2013 Mapbox.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
//
// * Neither the name of Mapbox, nor the names of its contributors may be
// used to endorse or promote products derived from this software
// without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
#import "RMAbstractWebMapSource.h"
#define kMapboxDefaultTileSize 256
#define kMapboxDefaultMinTileZoom 0
#define kMapboxDefaultMaxTileZoom 18
#define kMapboxDefaultLatLonBoundingBox ((RMSphericalTrapezium){ .northEast = { .latitude = 90, .longitude = 180 }, \
.southWest = { .latitude = -90, .longitude = -180 } })
#define kMapboxPlaceholderMapID @"examples.map-z2effxa8"
// constants for the image quality API (see https://www.mapbox.com/developers/api/maps/#format)
typedef enum : NSUInteger {
RMMapboxSourceQualityFull = 0, // default
RMMapboxSourceQualityPNG32 = 1, // 32 color indexed PNG
RMMapboxSourceQualityPNG64 = 2, // 64 color indexed PNG
RMMapboxSourceQualityPNG128 = 3, // 128 color indexed PNG
RMMapboxSourceQualityPNG256 = 4, // 256 color indexed PNG
RMMapboxSourceQualityJPEG70 = 5, // 70% quality JPEG
RMMapboxSourceQualityJPEG80 = 6, // 80% quality JPEG
RMMapboxSourceQualityJPEG90 = 7 // 90% quality JPEG
} RMMapboxSourceQuality;
@class RMMapView;
/** An RMMapboxSource is used to display map tiles from a network-based map hosted on [Mapbox](https://mapbox.com/plans) or the open source [TileStream](https://github.com/mapbox/tilestream) software. Maps are referenced by their Mapbox map ID or by a file or URL containing [TileJSON](https://www.mapbox.com/foundations/an-open-platform/#tilejson). */
@interface RMMapboxSource : RMAbstractWebMapSource
/** @name Creating Tile Sources */
/** Initialize a tile source using the Mapbox map ID.
*
* This method requires a network connection in order to download the TileJSON used to define the tile source.
*
* @param mapID The Mapbox map ID string, typically in the format `<username>.map-<random characters>`.
* @return An initialized Mapbox tile source. */
- (id)initWithMapID:(NSString *)mapID;
/** Initialize a tile source with either a remote or local TileJSON structure.
*
* Passing a remote URL requires a network connection. If offline functionality is desired, you should cache the TileJSON locally at a prior date, then pass a file path URL to this method.
*
* @see tileJSON
*
* @param referenceURL A remote or file path URL pointing to a TileJSON structure.
* @return An initialized Mapbox tile source. */
- (id)initWithReferenceURL:(NSURL *)referenceURL;
/** Initialize a tile source with TileJSON.
* @param tileJSON A string containing TileJSON.
* @return An initialized Mapbox tile source. */
- (id)initWithTileJSON:(NSString *)tileJSON;
/** For TileJSON 2.1.0+ layers, initialize a tile source and automatically find and add point annotations from [simplestyle](https://www.mapbox.com/foundations/an-open-platform/#simplestyle) data.
*
* This method requires a network connection in order to download the TileJSON used to define the tile source.
*
* @param mapID The Mapbox map ID string, typically in the format `<username>.map-<random characters>`.
* @param mapView A map view on which to display the annotations.
* @return An initialized Mapbox tile source. */
- (id)initWithMapID:(NSString *)mapID enablingDataOnMapView:(RMMapView *)mapView;
/** For TileJSON 2.1.0+ layers, initialize a tile source and automatically find and add point annotations from [simplestyle](https://www.mapbox.com/foundations/an-open-platform/#simplestyle) data.
* @param tileJSON A string containing TileJSON.
* @param mapView A map view on which to display the annotations.
* @return An initialized Mapbox tile source. */
- (id)initWithTileJSON:(NSString *)tileJSON enablingDataOnMapView:(RMMapView *)mapView;
/** For TileJSON 2.1.0+ layers, initialize a tile source and automatically find and add point annotations from [simplestyle](https://www.mapbox.com/foundations/an-open-platform/#simplestyle) data.
*
* Passing a remote URL requires a network connection. If offline functionality is desired, you should cache the TileJSON locally at a prior date, then pass a file path URL to this method.
*
* @see tileJSON
*
* @param referenceURL A remote or file path URL pointing to a TileJSON structure.
* @param mapView A map view on which to display the annotations.
* @return An initialized Mapbox tile source. */
- (id)initWithReferenceURL:(NSURL *)referenceURL enablingDataOnMapView:(RMMapView *)mapView;
/** @name Querying Tile Source Information */
/** Any available HTML-formatted map legend data for the tile source, suitable for display in a `UIWebView`. */
- (NSString *)legend;
/** A suggested starting center coordinate for the map layer. */
- (CLLocationCoordinate2D)centerCoordinate;
/** A suggested starting center zoom level for the map layer. */
- (float)centerZoom;
/** Returns `YES` if the tile source provides full-world coverage; otherwise, returns `NO`. */
- (BOOL)coversFullWorld;
/** The TileJSON for the map layer. Useful for saving locally to use in instantiating a tile source while offline. */
@property (nonatomic, readonly, strong) NSString *tileJSON;
/** The TileJSON URL for the map layer. Useful for retrieving TileJSON to save locally to use in instantiating a tile source while offline. */
@property (nonatomic, readonly, strong) NSURL *tileJSONURL;
/** The TileJSON data in dictionary format. Useful for retrieving info about the layer without having to parse TileJSON. */
@property (nonatomic, readonly, strong) NSDictionary *infoDictionary;
/** @name Configuring Map Options */
/** Image quality that is retrieved from the network. Useful for lower-bandwidth environments. The default is to provide full-quality imagery.
*
* Note that you may want to clear the tile cache after changing this value in order to provide a consistent experience. */
@property (nonatomic, assign) RMMapboxSourceQuality imageQuality;
+ (BOOL)isUsingLargeTiles;
#if OS_OBJECT_USE_OBJC
@property (nonatomic, readonly, strong) dispatch_queue_t dataQueue;
#else
@property (nonatomic, readonly, assign) dispatch_queue_t dataQueue;
#endif
@end