DingiRasterTileSource


@interface DingiRasterTileSource : DingiTileSource

DingiRasterTileSource is a map content source that supplies raster image tiles to be shown on the map. The location of and metadata about the tiles are defined either by an option dictionary or by an external file that conforms to the TileJSON specification. A raster tile source is added to an DingiStyle object along with one or more DingiRasterStyleLayer objects. Use a raster style layer to control the appearance of content supplied by the raster tile source.

Each raster source defined by the style JSON file is represented at runtime by an DingiRasterTileSource object that you can use to initialize new style layers. You can also add and remove sources dynamically using methods such as -[DingiStyle addSource:] and -[DingiStyle sourceWithIdentifier:].

Example

let source = DingiRasterTileSource(identifier: "clouds", tileURLTemplates: ["https://example.com/raster-tiles/{z}/{x}/{y}.png"], options: [
    .minimumZoomLevel: 9,
    .maximumZoomLevel: 16,
    .tileSize: 512,
    .attributionInfos: [
        DingiAttributionInfo(title: NSAttributedString(string: "© Mapbox"), url: URL(string: "https://mapbox.com"))
    ]
])
mapView.style?.addSource(source)
  • Returns a raster tile source initialized with an identifier and configuration URL.

    After initializing and configuring the source, add it to a map view’s style using the -[DingiStyle addSource:] method.

    The URL may be a full HTTP or HTTPS URL or, for tile sets hosted by Mapbox, a Mapbox URL indicating a map identifier (mapbox://<mapid>). The URL should point to a JSON file that conforms to the TileJSON specification.

    If a Mapbox URL is specified, this source uses a tile size of 256. For all other tile sets, the default value is 512. (See the DingiTileSourceOptionTileSize documentation for more information about tile sizes.) If you need to use a tile size other than the default, use the -initWithIdentifier:configurationURL:tileSize: method.

    Declaration

    Objective-C

    - (nonnull instancetype)initWithIdentifier:(nonnull NSString *)identifier
                              configurationURL:(nonnull NSURL *)configurationURL;

    Swift

    convenience init(identifier: String, configurationURL: URL)

    Parameters

    identifier

    A string that uniquely identifies the source in the style to which it is added.

    configurationURL

    A URL to a TileJSON configuration file describing the source’s contents and other metadata.

    Return Value

    An initialized raster tile source.

  • Returns a raster tile source initialized with an identifier, configuration URL, and tile size.

    After initializing and configuring the source, add it to a map view’s style using the -[DingiStyle addSource:] method.

    The URL may be a full HTTP or HTTPS URL or, for tile sets hosted by Mapbox, a Mapbox URL indicating a map identifier (mapbox://<mapid>). The URL should point to a JSON file that conforms to the TileJSON specification.

    Declaration

    Objective-C

    - (nonnull instancetype)initWithIdentifier:(nonnull NSString *)identifier
                              configurationURL:(nonnull NSURL *)configurationURL
                                      tileSize:(CGFloat)tileSize;

    Swift

    init(identifier: String, configurationURL: URL, tileSize: CGFloat)

    Parameters

    identifier

    A string that uniquely identifies the source in the style to which it is added.

    configurationURL

    A URL to a TileJSON configuration file describing the source’s contents and other metadata.

    tileSize

    The width and height (measured in points) of each tiled image in the raster tile source. See the DingiTileSourceOptionTileSize documentation for details.

    Return Value

    An initialized raster tile source.

  • Returns a raster tile source initialized an identifier, tile URL templates, and options.

    Tile URL templates are strings that specify the URLs of the raster tile images to load. See the “Tile URL Templates” guide for information about the format of a tile URL template.

    After initializing and configuring the source, add it to a map view’s style using the -[DingiStyle addSource:] method.

    Declaration

    Objective-C

    - (nonnull instancetype)
    initWithIdentifier:(nonnull NSString *)identifier
      tileURLTemplates:(nonnull NSArray<NSString *> *)tileURLTemplates
               options:(nullable NSDictionary<DingiTileSourceOption, id> *)options;

    Swift

    init(identifier: String, tileURLTemplates: [String], options: [DingiTileSourceOption : Any]? = nil)

    Parameters

    identifier

    A string that uniquely identifies the source in the style to which it is added.

    tileURLTemplates

    An array of tile URL template strings. Only the first string is used; any additional strings are ignored.

    options

    A dictionary containing configuration options. See DingiTileSourceOption for available keys and values. Pass in nil to use the default values.

    Return Value

    An initialized tile source.