GLMapManager

Objective-C


@interface GLMapManager : NSObject

Swift

class GLMapManager : NSObject

Map Manager is used to work with the list of offline maps.

  • Activates the GLMap framework. Should be called before usage.

    Declaration

    Objective-C

    + (void)activateWithApiKey:(nonnull NSString *)apiKey
               resourcesBundle:(NSBundle *_Nullable)resourcesBundle
                andStoragePath:(NSString *_Nullable)storagePath;

    Swift

    class func activate(withApiKey apiKey: String, resourcesBundle: Bundle?, andStoragePath storagePath: String?)

    Parameters

    apiKey

    API key.

    resourcesBundle

    Bundle with framework resources: world.vm, fonts, and DefaultStyle.bundle. If null, uses the main bundle.

    storagePath

    A path to the folder where offline maps are stored. If null, uses the documents folder.

  • Unavailable

    It’s a singleton object. Use [GLMapManager sharedManager]

    Default -init is disabled.

    Declaration

    Objective-C

    - (nonnull instancetype)init;

Properties

  • A path to the folder where offline maps are stored.

    Declaration

    Objective-C

    @property (strong) NSString *_Nonnull storagePath;

    Swift

    var storagePath: String { get set }
  • Path to the network activity log file. By default, it’s nil and logging is disabled.

    Declaration

    Objective-C

    @property (strong) NSString *_Nullable networkActivityLogPath;

    Swift

    var networkActivityLogPath: String? { get set }
  • Allows downloading map tiles one by one. By default, tileDownloadingAllowed is set to NO. GLMapView checks the tile in the world offline map first, then in the embedded and downloaded offline maps, then in the downloaded earlier tiles, and finally, if tile downloading is allowed, it tries to download the map tile.

    Declaration

    Objective-C

    @property BOOL tileDownloadingAllowed;

    Swift

    var tileDownloadingAllowed: Bool { get set }
  • Cached tiles will be refreshed if they remain in the cache beyond the specified time interval. This interval is measured in seconds. By default, tileRefreshTimeInterval is set to 2,592,000 seconds (30 days). If tileRefreshTimeInterval is less than 0, no tile refreshing will be triggered. Note: Tiles will continue to operate offline even after the refresh interval has passed, although the framework will attempt to download them again.

    Declaration

    Objective-C

    @property int64_t tileRefreshTimeInterval;

    Swift

    var tileRefreshTimeInterval: Int64 { get set }
  • Number of downloaded maps. The world map is not counted as a downloaded map.

    Declaration

    Objective-C

    @property (readonly) NSInteger downloadedMapsCount;

    Swift

    var downloadedMapsCount: Int { get }
  • All tasks created by [GLMapManager downloadMap:withCompletionBlock]. The map download task is removed from the array when the map downloading is finished.

    Declaration

    Objective-C

    @property (readonly) NSArray<GLMapDownloadTask *> *_Nonnull allDownloadTasks;

    Swift

    var allDownloadTasks: [GLMapDownloadTask] { get }

Shared Methods

  • Singleton manager object.

    Declaration

    Objective-C

    @property (class, nonatomic, readonly) GLMapManager *_Nonnull sharedManager;

    Swift

    class var shared: GLMapManager { get }
  • Bundle with resources.

    Declaration

    Objective-C

    @property (nonatomic, readonly) NSBundle *_Nonnull resourcesBundle;

    Swift

    var resourcesBundle: Bundle { get }

Methods

  • Declaration

    Objective-C

    - (NSArray<GLMapInfo *> *_Nullable)cachedMapList;

    Swift

    func cachedMapList() -> [GLMapInfo]?

    Return Value

    Returns an array of GLMapInfo objects downloaded earlier and cached by GLMapManager.

  • Declaration

    Objective-C

    - (NSDictionary<NSNumber *, GLMapInfo *> *_Nullable)cachedMaps;

    Swift

    func cachedMaps() -> [NSNumber : GLMapInfo]?

    Return Value

    Returns a dictionary of all GLMapInfo objects (including submaps) downloaded earlier and cached by GLMapManager.

  • Updates the map list.

    Declaration

    Objective-C

    - (void)updateMapListWithCompletionBlock:(GLMapListUpdateBlock _Nullable)block;

    Swift

    func updateMapList() async throws -> ([GLMapInfo], Bool)

    Parameters

    block

    A block called when the map list is downloaded.

  • Updates downloaded maps. Call this after placing map data files in the storage path.

    Declaration

    Objective-C

    - (void)updateDownloadedMaps;

    Swift

    func updateDownloadedMaps()
  • Sorts maps by distance from the border.

    Declaration

    Objective-C

    - (void)sortMaps:(nonnull NSMutableArray<GLMapInfo *> *)maps
           fromPoint:(GLMapPoint)point;

    Swift

    func sortMaps(_ maps: NSMutableArray, from point: GLMapPoint)

    Parameters

    maps

    Maps to sort.

    point

    Point to measure the distance.

  • Deletes downloaded map data sets.

    Declaration

    Objective-C

    - (void)deleteDataSets:(GLMapInfoDataSetMask)dataSets
                    forMap:(nonnull GLMapInfo *)map;

    Swift

    func deleteDataSets(_ dataSets: GLMapInfoDataSetMask, forMap map: GLMapInfo)

    Parameters

    dataSets

    Data sets to delete.

    map

    Map object.

  • Starts the download task. It’s up to you to save the download task or not. The active map download task can be retrieved later from -downloadTaskForMap:.

    Declaration

    Objective-C

    - (nonnull NSArray<GLMapDownloadTask *> *)
           downloadDataSets:(GLMapInfoDataSetMask)dataSets
                     forMap:(nonnull GLMapInfo *)map
        withCompletionBlock:(GLMapDownloadCompletionBlock _Nullable)completionBlock;

    Swift

    func downloadDataSets(_ dataSets: GLMapInfoDataSetMask, forMap map: GLMapInfo, withCompletionBlock completionBlock: GLMapDownloadCompletionBlock? = nil) -> [GLMapDownloadTask]

    Parameters

    dataSets

    Data sets to download.

    map

    Map object.

    completionBlock

    Completion block.

    Return Value

    A new download task object.

  • Used to check if there is a download task for a given map.

    Declaration

    Objective-C

    - (GLMapDownloadTask *_Nullable)downloadTaskForMap:(nonnull GLMapInfo *)map
                                               dataSet:(GLMapInfoDataSet)dataSet;

    Swift

    func downloadTask(forMap map: GLMapInfo, dataSet: GLMapInfoDataSet) -> GLMapDownloadTask?

    Parameters

    map

    A map info object.

    Return Value

    Returns GLMapDownloadTask previously created for a map.

  • Used to check if there is a download task for a given map and data set.

    Declaration

    Objective-C

    - (NSArray<GLMapDownloadTask *> *_Nullable)
        downloadTasksForMap:(nonnull GLMapInfo *)map
                   dataSets:(GLMapInfoDataSetMask)dataSets;

    Swift

    func downloadTasks(forMap map: GLMapInfo, dataSets: GLMapInfoDataSetMask) -> [GLMapDownloadTask]?

    Parameters

    map

    A map info object.

    dataSets

    Data set to check.

    Return Value

    Returns an array of GLMapDownloadTask previously created for a map.

  • Downloads custom data set.

    Declaration

    Objective-C

    - (int64_t)downloadDataSet:(GLMapInfoDataSet)dataSet
                          path:(nonnull NSString *)path
                          bbox:(GLMapBBox)bbox
                      progress:(nonnull GLMapDownloadProgress)progress
                    completion:(nonnull GLMapDownloadCompletion)completion;

    Swift

    func downloadDataSet(_ dataSet: GLMapInfoDataSet, path: String, bbox: GLMapBBox, progress: @escaping GLMapDownloadProgress, completion: @escaping GLMapDownloadCompletion) -> Int64

    Parameters

    dataSet

    Data set to download.

    path

    Full path to the file where to download the data set.

    bbox

    BBox of data to download.

    progress

    Progress callback.

    completion

    Completion callback.

    Return Value

    TaskID that can be used to cancel the download.

  • Cancels the download by its task id.

    Declaration

    Objective-C

    - (void)cancelDownload:(int64_t)taskID;

    Swift

    func cancelDownload(_ taskID: Int64)

    Parameters

    taskID

    ID of the task to cancel.

  • Cancels all downloads.

    Declaration

    Objective-C

    - (void)cancelAllDownloads;

    Swift

    func cancelAllDownloads()
  • Adds a custom data set. Can be used for maps embedded into the app resources. When a map is added, it becomes available for all GLMapView objects.

    Declaration

    Objective-C

    - (GLMapError)addDataSet:(GLMapInfoDataSet)dataSet
                        path:(nonnull NSString *)path
                        bbox:(GLMapBBox)bbox;

    Swift

    func add(_ dataSet: GLMapInfoDataSet, path: String, bbox: GLMapBBox) -> GLMapError

    Parameters

    dataSet

    Data set to add.

    path

    Path to the data.

    bbox

    BBox of data (can be empty).

    Return Value

    YES if the file is a valid data.

  • Removes a custom data set from the map manager. When removed, it is safe to delete the data file.

    Declaration

    Objective-C

    - (void)removeDataSet:(GLMapInfoDataSet)dataSet path:(nonnull NSString *)path;

    Swift

    func remove(_ dataSet: GLMapInfoDataSet, path: String)

    Parameters

    dataSet

    Data set to remove.

    path

    Path to the data.

  • Finds a custom data set at a point.

    Declaration

    Objective-C

    - (NSArray<NSString *> *_Nullable)customDataSet:(GLMapInfoDataSet)dataSet
                                            atPoint:(GLMapPoint)point;

    Swift

    func customDataSet(_ dataSet: GLMapInfoDataSet, at point: GLMapPoint) -> [String]?

    Parameters

    dataSet

    Data set to remove.

    point

    Point to search.

  • Returns map info with downloaded map data.

    Declaration

    Objective-C

    - (GLMapInfo *_Nullable)downloadedMapAtPoint:(GLMapPoint)point;

    Swift

    func downloadedMap(at point: GLMapPoint) -> GLMapInfo?

    Parameters

    point

    Some point in the internal format.

    Return Value

    GLMapInfo of the downloaded map.

  • Returns the map at a given point.

    Declaration

    Objective-C

    - (NSArray<GLMapInfo *> *_Nullable)mapsAtPoint:(GLMapPoint)point;

    Swift

    func maps(at point: GLMapPoint) -> [GLMapInfo]?

    Parameters

    point

    Some point in the internal format.

    Return Value

    GLMapInfo of the map.

  • Removes GLMap cached objects and closes opened databases. clearCaches is called automatically on UIApplicationDidEnterBackgroundNotification.

    Declaration

    Objective-C

    - (void)clearCaches;

    Swift

    func clearCaches()
  • Saves the state for downloading tasks. It allows resuming downloads in case of a crash or unexpected behavior. Called automatically when the app is minimized.

    Declaration

    Objective-C

    - (void)saveDownloadsState;

    Swift

    func saveDownloadsState()
  • Returns vector tiles that the bbox contains or intersects.

    Declaration

    Objective-C

    - (nonnull NSArray<NSNumber *> *)vectorTilesAtBBox:(GLMapBBox)bbox;

    Swift

    func vectorTiles(at bbox: GLMapBBox) -> [NSNumber]

    Parameters

    bbox

    BBox of the area.

    Return Value

    Returns a vector tiles array contained or intersected by the bbox.

  • Returns not cached vector tiles that bbox contains or intersects.

    Declaration

    Objective-C

    - (nonnull NSArray<NSNumber *> *)notCachedVectorTilesAtBBox:(GLMapBBox)bbox;

    Swift

    func notCachedVectorTiles(at bbox: GLMapBBox) -> [NSNumber]

    Parameters

    bbox

    BBox of the area.

    Return Value

    Returns not cached vector tiles contained or intersected by the bbox.

  • Checks if tiles are cached. If not, the tile will be downloaded.

    Declaration

    Objective-C

    - (void)cacheTiles:(nonnull NSArray<NSNumber *> *)tiles
         progressBlock:(GLMapTileDownloadProgressBlock _Nullable)progressBlock;

    Swift

    func cacheTiles(_ tiles: [NSNumber], progressBlock: GLMapTileDownloadProgressBlock? = nil)

    Parameters

    tiles

    Tiles to check.

    progressBlock

    Block that will be called when one tile is checked.

  • Returns the bbox for a given tile.

    Declaration

    Objective-C

    - (GLMapBBox)bboxForTile:(uint64_t)tile;

    Swift

    func bbox(forTile tile: UInt64) -> GLMapBBox

    Parameters

    tile

    Tile to calculate the bbox.

    Return Value

    Returns the bbox of the tile.

  • Enables the fix of gcj coordinates to wgs.

    Declaration

    Objective-C

    - (void)setNeedsChinaFix:(BOOL)needsChinaFix;

    Swift

    func setNeedsChinaFix(_ needsChinaFix: Bool)
  • The method is used to retrieve elevation and slope data for a given set of points.

    Note

    If either the elevation or slope parameters are NULL, the method will simply not fill in those values.

    Declaration

    Objective-C

    - (BOOL)samplePoints:(nonnull GLMapGeoPoint *)points
                   count:(NSInteger)count
               elevation:(float *_Nullable)elevation
                   slope:(float *_Nullable)slope;

    Swift

    func samplePoints(_ points: UnsafeMutablePointer<GLMapGeoPoint>, count: Int, elevation: UnsafeMutablePointer<Float>?, slope: UnsafeMutablePointer<Float>?) -> Bool

    Parameters

    points

    A pointer to an array of GLMapGeoPoint structures. Each structure specifies a point in geographical coordinates. This parameter must not be NULL.

    count

    The number of points in the array. This parameter can be zero.

    elevation

    A pointer to an array that the method fills in with the elevation data for each point, if not NULL. This is an output parameter.

    slope

    A pointer to an array that the method fills in with the slope data for each point, if not NULL. This is an output parameter.

    Return Value

    This method returns a BOOL value. If the method is successful, the return value is YES. If the method is not successful, the return value is NO.

  • Returns the elevation at a given point.

    Declaration

    Objective-C

    - (float)elevationAtPoint:(GLMapGeoPoint)point;

    Swift

    func elevation(at point: GLMapGeoPoint) -> Float

    Parameters

    point

    Location of elevation data.

    Return Value

    Elevation at the point in meters or NAN if no downloaded data for this point.

  • Asynchronous request for elevation.

    Declaration

    Objective-C

    - (void)elevationAtPoint:(GLMapGeoPoint)point
                  completion:(nonnull GLMapFloatBlock)completion;

    Swift

    func elevation(at point: GLMapGeoPoint) async -> Float

    Parameters

    point

    Location of elevation data.

    completion

    Block that will be called on completion.

  • Returns the slope at a given point.

    Declaration

    Objective-C

    - (float)slopeAtPoint:(GLMapGeoPoint)point;

    Swift

    func slope(at point: GLMapGeoPoint) -> Float

    Parameters

    point

    Location of slope data.

    Return Value

    Slope at the point in meters or NaN if no downloaded data for this point.

  • Asynchronous request for slope.

    Declaration

    Objective-C

    - (void)slopeAtPoint:(GLMapGeoPoint)point
              completion:(nonnull GLMapFloatBlock)completion;

    Swift

    func slope(at point: GLMapGeoPoint) async -> Float

    Parameters

    point

    Location of slope data.

    completion

    Block that will be called on completion.