# 地图常用方法

# 初始化地图

使用 vjmap.Map 对象初始化一个 地图。

// 新建地图服务对象,传入服务地址和token
let svc = new vjmap.Service(env.serviceUrl, env.accessToken)
// 打开地图
let res = await svc.openMap({
mapid: env.exampleMapId, // 地图ID,(请确保此ID已存在,可上传新图形新建ID)
mapopenway: vjmap.MapOpenWay.GeomRender, // 以几何数据渲染方式打开
style: vjmap.openMapDarkStyle() // div为深色背景颜色时,这里也传深色背景样式
})
if (res.error) {
console.error(res.error)
}
// 获取地图的范围
let mapExtent = vjmap.GeoBounds.fromString(res.bounds);
// 建立坐标系
let prj = new vjmap.GeoProjection(mapExtent);
// 新建地图对象
let map = new vjmap.Map({
container: 'map', // container ID
style: svc.rasterStyle(), // 栅格瓦片样式
center: prj.toLngLat(mapExtent.center()), // 中心点
zoom: 2,
renderWorldCopies: false
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

# 地图加载完成

创建地图对象后,开始加载地图资源,地图资源加载完成后触发 load 事件。

map.on("load", function() {
// 地图资源加载完成后触发
// 增加自定义数据源、自定义图层
});
1
2
3
4

await map.onLoad();
1

# 销毁地图对象

调用 remove 方法来销毁地图,该方法执行后,地图对象被注销,内存释放,地图容器被清空。

// 销毁地图,并清空地图容器
map.remove();
1
2

# 设置视图

# 基本视图设置

setCenter([lng, lat])
设置地图中心。

// 使用CAD坐标
map.setCenter(map.toLngLat([1000, 2000]));
// 直接使用经纬度
map.setCenter([120.1551, 30.2741]);
1
2
3
4

setZoom(zoomLevel)
设置地图缩放级别。

map.setZoom(14);
1

setZoomAndCenter
同时设置地图中心点和缩放级别:

// 同时传入缩放级别和中心点经纬度
map.setZoomAndCenter(12, [116.46, 39.92]);
1
2

setWheelZoomRate
设置地图整级缩放或非整级缩放:

// 设置地图整级缩放
map.scrollZoom.setWheelZoomRate(1); //设置鼠标滚轮滚动一下的缩放比例
map.scrollZoom.setZoomRate(1); //设置触摸屏的缩放比例,最大值为1
// 设置地图非整级缩放 (默认1/450)
// map.scrollZoom.setWheelZoomRate(1 / 600); //速率值越小,地图的缩放越细腻
1
2
3
4
5

setBearing(angle)
设置地图的旋转角度。

map.setBearing(90);
1

setPitch(pitch)
设置地图的倾斜角度。

map.setPitch(45);
1

jumpTo(options)
瞬间跳转到指定地图状态(无动画)。

map.jumpTo({ center: [20.1551, 30.2741], zoom: 14 });
1

flyTo(options)
使用动画飞行过渡到新视图状态。

map.flyTo({ center: [20.1551, 30.2741], zoom: 14 });
1

panBy([x, y], options)
通过像素平移地图。

map.panBy([100, 0]);
1

fitBounds(bounds, options)
自动调整地图视图以适应边界框。

// 根据CAD几何坐标范围
let bounds = vjmap.GeoBounds.fromString("100,200,300,400");
map.fitMapBounds(bounds);
1
2
3
// 根据经纬度
map.fitBounds([[120.0, 30.0], [121.0, 31.0]]);
1
2

rotateTo(bearing, options)
设置地图旋转到特定角度。

map.rotateTo(90);
1

resetNorth(options)
将地图旋转恢复到正北方向。

map.resetNorth();
1

# 视图限制

setMinZoom(minZoom)
设置地图允许的最小缩放级别。

map.setMinZoom(5);
1

setMaxZoom(maxZoom)
设置地图允许的最大缩放级别。

map.setMaxZoom(18);
1

setMaxBounds(bounds)
限制地图的最大边界,禁止拖动超出此范围。

map.setMaxBounds([[120.0, 30.0], [121.0, 31.0]]);
1

# 地图事件

on(eventType, listener)
监听地图事件,如点击、移动、缩放等。

map.on('click', (e) => {
console.log('点击位置:', e.lngLat);
});
1
2
3

off(eventType, listener)
移除特定事件的监听器。

map.off('click', listenerFunction);
1

once(eventType, listener)
只监听一次特定事件。

map.once('click', (e) => {
console.log('仅一次点击事件:', e.lngLat);
});
1
2
3

onLoad(listener)
监听地图加载完成事件。

map.on('load', () => {
console.log('地图已加载');
});
1
2
3

onMove(listener)
监听地图平移事件。

map.on('move', () => {
    console.log('地图正在移动');
});
1
2
3

onZoom(listener)
监听地图缩放事件。

map.on('zoom', () => {
    console.log('地图正在缩放');
});
1
2
3

# 添加控件

addControl(control, position)
添加控件(缩放、导航等)。

const nav = new vjmap.NavigationControl();
map.addControl(nav, 'top-right');
1
2

removeControl(control)
移除控件。

map.removeControl(nav);
1

addScaleControl(options)
添加比例尺控件。

map.addControl(new vjmap.ScaleControl());
1

addFullScreenControl()
添加全屏控件。

map.addControl(new vjmap.FullscreenControl());
1

# 添加图层

addLayer(layer)
添加图层。

map.addLayer({
    id: 'circle-layer',
    type: 'circle',
    source: 'points',
    paint: {
        'circle-radius': 10,
        'circle-color': '#007cbf'
    }
});
1
2
3
4
5
6
7
8
9

addImage(name, image)
添加自定义图像,用于图层。

map.addImage('custom-icon', 'path-to-image.png');
1

addSource(sourceId, source)
添加自定义数据源。

map.addSource('points', {
    type: 'geojson',
    data: {
        type: 'FeatureCollection',
        features: []
    }
});
1
2
3
4
5
6
7

getLayer(layerId)
获取指定的图层对象。

const layer = map.getLayer('custom-layer');
1

# 更新和移除图层

setPaintProperty(layerId, property, value)
动态设置图层绘制属性。

map.setPaintProperty('circle-layer', 'circle-radius', 15);
1

setLayoutProperty(layerId, property, value)
动态设置图层布局属性。

map.setLayoutProperty('circle-layer', 'visibility', 'none');
1

removeLayer(layerId)
移除指定的图层。

map.removeLayer('custom-layer');
1

moveLayer(layerId, beforeId)
改变图层的绘制顺序,将图层移动到另一个图层之前。

map.moveLayer('circle-layer', 'another-layer');
1

# 动态更新数据源

getSource(sourceId)
获取指定的数据源对象。

const source = map.getSource('points');
1

setData(sourceId, data)
更新指定的数据源中的数据。

map.getSource('points').setData(newGeoJsonData);
1

removeSource(sourceId)
移除指定的数据源。

map.removeSource('points');
1

removeSourceEx(sourceId)
移除指定的数据源和数据源相关的图层。

map.removeSource('points');
1

# 地图样式管理

setStyle(style)
设置地图样式。

map.setStyle(style);
1

getStyle()
获取当前地图样式。

const style = map.getStyle();
1
  1. isStyleLoaded()
    检查地图样式是否加载完成。
if (map.isStyleLoaded()) {
    console.log('样式已加载');
}
1
2
3

# 获取地图信息

getCenter()
获取当前地图中心点。

const center = map.getCenter();
console.log(center); // {lng, lat}
1
2

getZoom()
获取当前地图缩放级别。

const zoom = map.getZoom();
1

getBearing()
获取当前地图的旋转角度。

const bearing = map.getBearing();
1

getPitch()
获取当前地图的倾斜角度。

const pitch = map.getPitch();
1

getBounds()
获取当前地图的边界框(地图四个角的坐标)。

const bounds = map.getBounds();
1

getMaxZoom()
获取地图允许的最大缩放级别。

const maxZoom = map.getMaxZoom();
1

getMinZoom()
获取地图允许的最小缩放级别。

const minZoom = map.getMinZoom();
1

resize()
重新调整地图大小,在地图容器大小发生变化时使用。

map.resize();
1

toLngLat(point)
将CAD坐标转经纬度坐标。

const lnglat = map.toLngLat([1000, 3000]);
1

fromLngLat(point)
将经纬度坐标转换为CAD坐标。

const point = map.fromLngLat([120.1551, 30.2741]);
1

project(lngLat)
将经纬度坐标转换为像素坐标。

const point = map.project([120.1551, 30.2741]);
1

unproject(point)
将像素坐标转换为经纬度坐标。

const lngLat = map.unproject([200, 300]);
1

remove()
销毁地图对象并释放资源。

map.remove();
1

# 其他常用方法

getCanvas()
获取地图的 canvas 元素。

const canvas = map.getCanvas();
1

将地图导出为png格式的base64图片

let map = new vjmap.Map({
    container: 'map', // DIV容器ID
    preserveDrawingBuffer: true, // 如果true,则可以使用 将地图的画布导出为 PNG map.getCanvas().toDataURL()。这是false默认的性能优化。(可选,默认false)
    ...
});
console.log(map.getCanvas().toDataURL())
1
2
3
4
5
6

getContainer()
获取地图的容器元素。

const container = map.getContainer();
1

queryRenderedFeatures([point], options)
查询指定区域内的所有已渲染的要素。

const features = map.queryRenderedFeatures([200, 300], {
    layers: ['custom-layer']
});
1
2
3

getPadding()
获取地图当前的内边距(padding)。

const padding = map.getPadding();
1

setPadding(padding)
设置地图内边距。

map.setPadding({ top: 50, bottom: 50 });
1

getFreeCameraOptions()
获取地图的自由相机选项。

const cameraOptions = map.getFreeCameraOptions();
1

setFreeCameraOptions(options)
设置地图的自由相机选项。

map.setFreeCameraOptions(cameraOptions);
1

loadImage(url, callback)
从 URL 加载图像并在回调中返回。

map.loadImage('path-to-image.png', (error, image) => {
    if (error) throw error;
    map.addImage('custom-icon', image);
});
1
2
3
4

removeImage(name)
移除已添加的图像。

map.removeImage('custom-icon');
1

listImages()
列出所有已添加的图像名称。

const images = map.listImages();
console.log(images);
1
2

hasImage(name)
检查地图中是否已存在指定名称的图像。

const hasImage = map.hasImage('custom-icon');
1

addCustomLayer(layer)
添加自定义 WebGL 图层。

map.addLayer({
    id: 'custom-webgl-layer',
    type: 'custom',
    renderingMode: '3d',
    onAdd: (map, gl) => {
        // 初始化 WebGL 资源
    },
    render: (gl, matrix) => {
        // 绘制 WebGL 图层
    }
});
1
2
3
4
5
6
7
8
9
10
11

hasLayer(layerId)
检查地图中是否已存在指定 ID 的图层。

const hasLayer = map.hasLayer('custom-layer');
1

getLayerVisibility(layerId)
获取图层的可见性。

const visibility = map.getLayoutProperty('custom-layer', 'visibility');
1

getLight()
获取当前灯光设置。

const light = map.getLight();
1

setLight(lightOptions)
设置灯光。

map.setLight({
    anchor: 'viewport',
    color: '#ffffff',
    intensity: 0.5
});
1
2
3
4
5

getFeatureState(featureId)
获取特定要素的状态。

const state = map.getFeatureState({ source: 'my-source', id: featureId });
1

setFeatureState(featureId, state)
设置特定要素的状态。

map.setFeatureState({ source: 'my-source', id: featureId }, { selected: true });
1

removeFeatureState(featureId)
移除特定要素的状态。

map.removeFeatureState({ source: 'my-source', id: featureId });
1

getFilter(layerId)
获取图层的过滤条件。

const filter = map.getFilter('my-layer');
1

setFilter(layerId, filter)
设置图层的过滤条件。

map.setFilter('my-layer', ['==', 'property', 'value']);
1

hasClass(className)
检查地图容器是否有指定的 CSS 类。

const hasClass = map.getContainer().classList.contains('my-class');
1

addClass(className)
为地图容器添加 CSS 类。

map.getContainer().classList.add('my-class');
1

removeClass(className)
从地图容器移除指定的 CSS 类。

map.getContainer().classList.remove('my-class');
1

toggleClass(className)
切换地图容器的指定 CSS 类。

map.getContainer().classList.toggle('my-class');
1

setCursor(cursorStyle)
设置地图的光标样式。

map.getCanvas().style.cursor = 'pointer';
1

resetCursor()
重置地图的光标样式。

map.getCanvas().style.cursor = '';
1

isMoving()
检查地图是否正在移动。

const moving = map.isMoving();
1

isZooming()
检查地图是否正在缩放。

const zooming = map.isZooming();
1