OpenLayers官网提供的例子:点标记的添加
我每一个功能都用了一个单独的JS文件,并且是以类为接口的方式。
OpenLayer添加点标记的顺序是:Map —— Layer —— Source —— Feature (Style) —— Geometry
上面从大到小,Geometry就是设置经纬度了。
1.设置Layer和Source
/** 设置点图层 */
var markVectorSource = new ol.source.Vector();
var markVectorLayer = new ol.layer.Vector({
source: markVectorSource
});
2.设置Geometry和Feature
我们常用的坐标系是WGS84,对应过来空间坐标系是EPSG:4326,但OpenLayers默认示例是EPSG:900913。所以经纬度必须经过转换。
var iconFeature = new ol.Feature({
//geometry: new ol.geom.Point(markSettings.markCoordinate)
geometry: new ol.geom.Point(ol.proj.fromLonLat(markSettings.markCoordinate))//纬度 经度
});
3.设置Style
其中,src与img只需要设置一个值。src是一个字符串,为引用图片的路径,而img是指真正的图片,也就是html中的,但不能直接把放进去,而是要先添加到地图中的Canvas上,然后再在此处调用。imgSize用来定义img属性的大小,如果img未定义,那它也必须未定义。
var iconStyle = new ol.style.Style({
image: new ol.style.Icon(/** @type {olx.style.IconOptions} **/({
anchor: markSettings.markAnchor, //点图片偏移量
src: markSettings.markImage, //图片路径
img: undefined, //图片
imgSize: undefined
}))
});
4.添加到Map
iconFeature.setStyle(iconStyle);
markVectorSource.addFeature(iconFeature);
map.removeLayer(markVectorLayer);
map.addLayer(markVectorLayer);
5.删除点,需要先从Feature里移除icon,然后再移除图层,如果不从Feature里移除icon而直接移除图层,则同一个实例化方法中icon一直存在,只是由于图层不存在而未在地图上显示出来。
markVectorSource.removeFeature(iconFeature);
map.removeLayer(markVectorLayer);
6.改变样式
iconFeature.setStyle(new ol.style.Style({
image: new ol.style.Icon(/** @type {olx.style.IconOptions} */({
anchor: markSettings.markAnchor,
src: markImage,
img: undefined,
imgSize: undefined
}))
}));
综合以上,完整的点标记的类的代码为 SetMark.js:
var SetMark = (function() {
/** 设置点图层 */
var markVectorSource = new ol.source.Vector();
var markVectorLayer = new ol.layer.Vector({
source: markVectorSource
});
var SetIcon = function(markOptions){
var markSettings = $.extend({
markCoordinate: [0, 0],
markAnchor: [0.5, 0.96],
markImage: 'https://openlayers.org/en/v4.0.1/examples/data/icon.png',
}, markOptions); //传参变量
var iconFeature = new ol.Feature({
//geometry: new ol.geom.Point(markSettings.markCoordinate)
geometry: new ol.geom.Point(ol.proj.fromLonLat(markSettings.markCoordinate))//纬度 经度
});
/** 创建点图标 */
this.createMark = function () {
var iconStyle = new ol.style.Style({
image: new ol.style.Icon(/** @type {olx.style.IconOptions} **/({
anchor: markSettings.markAnchor,
src: markSettings.markImage,
img: undefined,
imgSize: undefined
}))
});
iconFeature.setStyle(iconStyle);
markVectorSource.addFeature(iconFeature);
map.removeLayer(markVectorLayer);
map.addLayer(markVectorLayer);
/** 选择点 */
if (true) {
var selectStyle = {};
var select = new ol.interaction.Select({
style: function(feature) {
var image = feature.get('style').getImage().getImage();
if (!selectStyle[image.src]) {
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
canvas.width = image.width;
canvas.height = image.height;
context.drawImage(image, 0, 0, image.width, image.height);
var imageData = context.getImageData(0, 0, canvas.width, canvas.height);
var data = imageData.data;
for (var i = 0, ii = data.length; i < ii; i = i + (i % 4 == 2 ? 2 : 1)) {
data[i] = 255 - data[i];
}
context.putImageData(imageData, 0, 0);
selectStyle[image.src] = createStyle(undefined, canvas);
}
return selectStyle[image.src];
}
});
map.addInteraction(select);
map.on('pointermove', function(evt) {
map.getTargetElement().style.cursor =
map.hasFeatureAtPixel(evt.pixel) ? 'pointer' : '';
});
}
}
/** 删除点 */
this.deleteMark = function () {
markVectorSource.removeFeature(iconFeature);
map.removeLayer(markVectorLayer);
}
/** 修改点图片 */
this.changeMark = function (markImage) {
iconFeature.setStyle(new ol.style.Style({
image: new ol.style.Icon(/** @type {olx.style.IconOptions} */({
anchor: markSettings.markAnchor,
src: markImage,
img: undefined,
imgSize: undefined
}))
}));
/** 使用img和imgSize来改变图片 */
// var markIcon = new Image();
// markIcon.src = markImage;
// markIcon.width = 70;
// markIcon.height = 70;
// //markIcon.hidden = true;
// var markPicture = document.getElementsByClassName("ol-unselectable")[0].appendChild(markIcon);
// iconFeature.setStyle(new ol.style.Style({
// image: new ol.style.Icon(/** @type {olx.style.IconOptions} */({
// anchor: markSettings.markAnchor,
// src: undefined,
// img: markIcon,
// imgSize: [markIcon.width, markIcon.height]
// }))
// }));
/** 等比例缩小图片 */
// if( markIcon.width> 70) {
// var scaling = 1-(markIcon.width-70)/markIcon.width;
// //计算缩小比例
// markIcon.width = markIcon.width * scaling;
// markIcon.height = markIcon.height * scaling;
// }
}
}
return SetIcon;
})()
实例化上面的类,就可以使用了 Function.js
/** add mark
* para
* var mark = new SetMark({
markCoordinate: [0, 0],
markAnchor: [0.5, 0.96],
markImage: 'https://openlayers.org/en/v4.0.1/examples/data/icon.png',
});
**/
/** add one point **/
function MarkTesting() {
var mark = new SetMark({
markCoordinate: [80, -50]
});
$("#addOneMark").click(function () {
mark.createMark();
//mark.addClick();
});
$("#delOneMark").click(function () {
mark.deleteMark();
});
$("#chaOneMark").click(function () {
mark.changeMark('timg.png');
});
}
MarkTesting();
/** add two points **/
function MarksTesting() {
var mark = new Array();
var markID = new Array(); // [[坐标对], 存放序号] 删除或修改某一个点时
var markCoordinates = [[0,0], [50, 60], [10, 80]];
var len = markCoordinates.length;
for (var i = 0; i < len; i++) {
mark[i] = new SetMark({
markCoordinate: markCoordinates[i]
});
markID[i] = [markCoordinates[i], i];
var k = 0;
}
$("#addMoreMark").click(function () {
for (var i = 0; i < len; i++) {
mark[i].createMark();
//mark[1].addClick();
}
});
$("#delMoreMark").click(function () {
for (var i = 0; i < len; i++) {
mark[i].deleteMark();
}
});
$("#chaMoreMark").click(function () {
for (var i = 0; i < len; i++) {
mark[i].changeMark('123.png');
}
});
}
MarksTesting();
HTML部分为:CommonVariable.js 和 SetMap.js见OpenLayers3学习一:地图加载(以类为接口)
OpenLayers3Exercise1