cap*_*nam 2 javascript openlayers openlayers-3 openlayers-5
我有一个具有绘制交互功能的 openlayers 地图。当用户开始在地图上绘制线串时,绘制的线串部分看起来应该与用户接下来绘制的部分不同。
简而言之,当用户在地图上放置一个点时,直到该点的线应该是块,没有破折号或任何其他样式选项。
为了说明我在这里尝试做的事情,请使用屏幕截图 -
我们可以看到用户即将在线上添加另一个点,因此直到该点的线应该变成蓝色块。
我维护了添加到地图中的点的集合,当用户选择删除最后一个点时,它将从地图中删除,但最后一段也应该从地图中消失。找不到任何东西可以实现这一目标。
另外,我还添加了ol.style.RegularShape()显示正方形的功能,但它显示的是圆形,而不知道我做错了什么。
这是我的代码的 jsbin 链接 -绘制交互线条样式问题
您需要为绘制样式使用样式函数,并将几何图形分为两部分以进行样式设置:
var drawStyle = function(feature) {
var styles = [];
if (feature.getGeometry().getType() == 'LineString') {
var coordinates = feature.getGeometry().getCoordinates();
styles.push(new ol.style.Style({
geometry: new ol.geom.LineString(coordinates.slice(-2)),
stroke: new ol.style.Stroke({
color: '#0000FF',
lineDash: [1, 20],
width: 5,
lineCap:'square',
lineJoin:'round',
lineDashOffset:10
})
}));
styles.push(new ol.style.Style({
geometry: new ol.geom.MultiPoint(coordinates),
image: new ol.style.RegularShape({
points: 4,
radius: 6,
angle: Math.PI / 4,
fill: new ol.style.Fill({
color: 'blue'
}),
stroke: new ol.style.Stroke({
color: 'blue'
}),
})
}));
if (coordinates.length > 2) {
styles.push(new ol.style.Style({
geometry: new ol.geom.LineString(coordinates.slice(0,-1)),
stroke: new ol.style.Stroke({
color: '#0000FF',
width: 2,
lineCap:'square',
lineJoin:'round'
})
}));
}
}
return styles;
}
Run Code Online (Sandbox Code Playgroud)
要从线交互中删除最后一个点,只需使用
line.removeLastPoint();
Run Code Online (Sandbox Code Playgroud)
确保var line;已声明,因此它位于按钮单击功能的范围内
| 归档时间: |
|
| 查看次数: |
3359 次 |
| 最近记录: |