# 地图数据源
# 概述
数据源定义地图上能够被应用的数据,每个数据源都必须有唯一的 ID 标识,不能重复。
每个数据源都必须要有指定一个数据源类型,数据源类型范围如下:
["vector", "raster", "geojson", "image", "video"];
1
# vector 类型说明
vector 类型表示矢量数据类型,数据提供的形式为矢量瓦片服务的形式,数据返回格式为 protubuf 格式。
详细说明如下:
map.addSource("Source1", {
  /*Source1代表数据源ID,是唯一的,不能重复*/
  type: "vector" /*数据源类型*/,
  tiles: ["http://yourwebsite/{z}/{x}/{y}.mvt"] /*数据源请求地址URL,可以是多个*/,
});
1
2
3
4
5
2
3
4
5
# raster 类型说明
raster 类型表示栅格类型,数据提供的形式为瓦片服务的形式,数据返回栅格图片。
详细说明如下:
map.addSource("Source1", {
  /*Source1代表数据源ID,是唯一的,不能重复*/
  type: "raster" /*数据源类型*/,
  tileSize: 256 /*返回栅格图片尺寸,如果不添加该参数,默认为512*/,
  tiles: ["http://yourwebsite/{z}/{x}/{y}.png"] /*数据源请求地址URL,可以是多个*/,
});
1
2
3
4
5
6
2
3
4
5
6
# geojson 类型说明
geojson 类型表示 geojson 类型,数据提供的形式为 geojson 结构的数据,数据一次性加载。
详细说明如下:
示例一:
map.addSource("jsonSource", { /*jsonSource代表数据源ID,是唯一的,不能重复*/
    "type": "geojson",   /*数据源类型*/
    "data": "./data.json"
    /*data参数为geojson格式的数据,支持两种结构:1、url形式,返回的结果为geojson格式;2、具体的geojson格式的数据*/
});
1
2
3
4
5
2
3
4
5
示例二:
var jsonData = {"type": "FeatureCollection",
    "features": [{
        "type": "Feature",
        "geometry": {
            "type": "Point",
            "coordinates": [116.46, 39.92]
        },
        "properties": {
            "title": "大学"
        }
    }]
};
map.addSource("jsonSource", {
    "type": "geojson",
    "data": jsonData
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
geojson 数据源数据内容更新,调用 setData 方法:
map.addSource("jsonSource", {
    "type": "geojson",
    "data": {"type": "FeatureCollection","features": []}    /*空数据*/
});
//  某些业务场景先定义geojson数据源,数据内容设为空,添加具体的图层,当业务数据组织好后,通过调用setData方法更新数据
map.getSource('jsonSource').setData(json) /*参数json可以是url或具体的geojson数据*/
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# image 类型说明
image 类型表示图像类型,图像格式可以为 gif、png、jpg、jpeg 形式。
详细说明如下:
map.addSource("imageSource", { /*imageSource代表数据源ID,是唯一的,不能重复*/
    "type": "image",   /*数据源类型*/
    "url": "./images/flash.gif",    /*图像url地址*/
    "coordinates": [[106.45, 29.93],[106.47, 29.93],[106.47, 29.91],[106.45, 29.91]]
    /*图像在地图上的坐标点边界,边界值为顺时针方式,依次为:左上、右上、右下、左下。*/
});
1
2
3
4
5
6
2
3
4
5
6
# video 类型说明
video 类型表示视频类型,视频格式可以为 mp4 等形式。
详细说明如下:
map.addSource("videoSource", { /*videoSource代表数据源ID,是唯一的,不能重复*/
    "type": "video",   /*数据源类型*/
    "urls": ["http://yourwebsite/assets/v.mp4"],    /*视频请求地址URL,可以是多个*/
    "coordinates": [[106.45, 29.93],[106.47, 29.93],[106.47, 29.91],[106.45, 29.91]]
    /*图像在地图上的坐标点边界,边界值为顺时针方式,依次为:左上、右上、右下、左下。*/
});
1
2
3
4
5
6
2
3
4
5
6
