openlayers官网:OpenLayers - Welcomehttps://openlayers.org/
1、页面
2、导入
import { onMounted, shallowRef } from "vue";
import { Map, View } from "ol";
import TileLayer from "ol/layer/Tile";
import { XYZ } from "ol/source";
import "ol/ol.css";
import { defaults } from "ol/control";
import { Vector as SourceVec, Cluster } from "ol/source";
import { Feature } from "ol";
import { Point } from "ol/geom";
import { Style, Icon } from "ol/style";
import VectorSource from "ol/source/Vector.js";
import VectorLayer from "ol/layer/Vector.js";
3、数据定义,(坐标、图片)
图片是百度的图片的路径~~
const imgSrc1 = "https://unpkg.com/[email protected]/dist/images/marker-icon.png";
const lnglats1 = [
[125.927905, 42.178945],
[116.927905, 35.278945],
[107.927905, 33.378945],
[128.227905, 44.478945],
[139.327905, 34.578945],
[124.227905, 35.578945],
];
// 坐标
var lnglats2 = [
[100.927905, 22.178945],
[84.927905, 42.278945],
[101.927905, 32.378945],
[92.227905, 22.478945],
[113.327905, 23.578945],
[72.227905, 25.578945],
];
const imgSrc2 =
"";
4、地图实例化
const map = shallowRef(); // 存放地图实例
function initMap() {
// 地图实例
map.value = new Map({
// 让id为map的div作为地图的容器
target: "map",
// 设置地图图层
layers: [
new TileLayer({
source: new XYZ({
url: "http://map.geoq.cn/ArcGIS/rest/services/ChinaOnlineStreetPurplishBlue/MapServer/tile/{z}/{y}/{x}", //暗色
}),
}),
],
// 设置显示地图的视图
view: new View({
// 设置地图中心范围
// extent参数类型为[minX, minY, maxX, maxY]的ol.Extent
projection: "EPSG:4326", //EPSG:3857坐标系(投影坐标) EPSG:4326 坐标系(地理坐标)
center: [113.927905, 22.578945], // 定义地图显示中心于经度,纬度
zoom: 13,
maxZoom: 18,
minZoom: 4, // 并且定义地图显示层级为
constrainResolution: true, //自动缩放到距离最近的整数级,非整数级别时地图会糊
}),
//设置地图控件
controls: defaults({
zoom: false, //不显示放大放小按钮;
rotate: false, //不显示指北针控件;
attribution: false, //不显示右下角的地图信息控件;
}).extend([]),
});
//添加标记点
addMarker(lnglats1, imgSrc1, { name: "block" });
addMarker(lnglats2, imgSrc2, { name: "spot" });
}
5、添加标记点的方法
option参数可选择不用,此处是为了区别该坐标点属于哪个分组,图层控制可能用得上
//添加标记点
function addMarker(lnglat: any, imgSrc: string, options = {}) {
const lnglats = lnglat;
// 创建Feature对象集合
const features1 = [];
for (let i = 0; i < lnglats.length; i++) {
const numAry = new Feature({
geometry: new Point([Number(lnglats[i][0]), Number(lnglats[i][1])]),
...lnglats[i],
});
features1.push(numAry);
}
// 矢量要素数据源
const source1 = new VectorSource({
features: features1,
});
const clusterSource = new Cluster({
distance: 5, //标注之间
source: source1,
});
const iconStyle = new Style({
image: new Icon({
opacity: 1,
src: imgSrc,
anchor: [0.5, 3], // 偏移位置
anchorOrigin: "bottom-left",
anchorXUnits: "fraction",
anchorYUnits: "pixels",
offsetOrigin: "top-right",
offset: [0, 1], //偏移量设置
scale: 1, //图标缩放比例
}),
});
const clusters = new VectorLayer({
source: clusterSource,
style: iconStyle,
...options,
});
map.value!.addLayer(clusters);
return source1;
}
6、页面挂载
onMounted(() => {
initMap();
});
7、完整代码
8、页面效果