Merge pull request #1807 from ahocevar/float-no-zero
Modify interaction sometimes does not allow to create a new vertex
This commit is contained in:
@@ -26,6 +26,10 @@
|
|||||||
<div class="row-fluid">
|
<div class="row-fluid">
|
||||||
<div class="span12">
|
<div class="span12">
|
||||||
<div id="map" class="map"></div>
|
<div id="map" class="map"></div>
|
||||||
|
<select id="layer-select">
|
||||||
|
<option selected>Test data</option>
|
||||||
|
<option>RealData (topology)</option>
|
||||||
|
</select>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -33,8 +37,9 @@
|
|||||||
|
|
||||||
<div class="span12">
|
<div class="span12">
|
||||||
<h4 id="title">Modify features example</h4>
|
<h4 id="title">Modify features example</h4>
|
||||||
<p id="shortdesc">Example of using the Modify interaction. Select a feature and drag the circle that appears when the cursor gets close to the selected geometry.</p>
|
<p id="shortdesc">Example of using the Modify interaction.</p>
|
||||||
<div id="docs">
|
<div id="docs">
|
||||||
|
<p>Select a feature on the <b>Test Data</b> layer and drag the circle that appears when the cursor gets close to the selected geometry. On the <b>Real data (topology)</b> layer, editing adjacent countries that are selected preserves the topology.</p>
|
||||||
<p>See the <a href="modify-features.js" target="_blank">modify-features.js source</a> to see how this is done.</p>
|
<p>See the <a href="modify-features.js" target="_blank">modify-features.js source</a> to see how this is done.</p>
|
||||||
</div>
|
</div>
|
||||||
<div id="tags">modify, edit, vector</div>
|
<div id="tags">modify, edit, vector</div>
|
||||||
|
|||||||
@@ -67,7 +67,7 @@ var styleFunction = (function() {
|
|||||||
};
|
};
|
||||||
})();
|
})();
|
||||||
|
|
||||||
var vectorSource = new ol.source.GeoJSON(
|
var testDataSource = new ol.source.GeoJSON(
|
||||||
/** @type {olx.source.GeoJSONOptions} */ ({
|
/** @type {olx.source.GeoJSONOptions} */ ({
|
||||||
object: {
|
object: {
|
||||||
'type': 'FeatureCollection',
|
'type': 'FeatureCollection',
|
||||||
@@ -96,7 +96,14 @@ var vectorSource = new ol.source.GeoJSON(
|
|||||||
'type': 'Feature',
|
'type': 'Feature',
|
||||||
'geometry': {
|
'geometry': {
|
||||||
'type': 'LineString',
|
'type': 'LineString',
|
||||||
'coordinates': [[4e6, -2e6], [8e6, 2e6]]
|
'coordinates': [[4e6, -2e6], [8e6, 2e6], [9e6, 2e6]]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'type': 'Feature',
|
||||||
|
'geometry': {
|
||||||
|
'type': 'LineString',
|
||||||
|
'coordinates': [[4e6, -2e6], [8e6, 2e6], [8e6, 3e6]]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -159,9 +166,18 @@ var vectorSource = new ol.source.GeoJSON(
|
|||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
var testDataLayer = new ol.layer.Vector({
|
||||||
|
source: testDataSource,
|
||||||
|
style: styleFunction
|
||||||
|
});
|
||||||
|
|
||||||
var vectorLayer = new ol.layer.Vector({
|
var realDataSource = new ol.source.GeoJSON({
|
||||||
source: vectorSource,
|
projection: 'EPSG:3857',
|
||||||
|
url: 'data/geojson/countries.geojson'
|
||||||
|
});
|
||||||
|
|
||||||
|
var realDataLayer = new ol.layer.Vector({
|
||||||
|
source: realDataSource,
|
||||||
style: styleFunction
|
style: styleFunction
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -239,7 +255,7 @@ var modify = new ol.interaction.Modify({
|
|||||||
|
|
||||||
var map = new ol.Map({
|
var map = new ol.Map({
|
||||||
interactions: ol.interaction.defaults().extend([select, modify]),
|
interactions: ol.interaction.defaults().extend([select, modify]),
|
||||||
layers: [raster, vectorLayer],
|
layers: [raster, testDataLayer, realDataLayer],
|
||||||
renderer: 'canvas',
|
renderer: 'canvas',
|
||||||
target: 'map',
|
target: 'map',
|
||||||
view: new ol.View2D({
|
view: new ol.View2D({
|
||||||
@@ -247,3 +263,14 @@ var map = new ol.Map({
|
|||||||
zoom: 2
|
zoom: 2
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$('#layer-select').change(function() {
|
||||||
|
select.getFeatures().clear();
|
||||||
|
var index = $(this).children().index($(this).find(':selected'));
|
||||||
|
var layers = [testDataLayer, realDataLayer];
|
||||||
|
var i, ii;
|
||||||
|
for (i = 0, ii = layers.length; i < ii; ++i) {
|
||||||
|
layers[i].setVisible(index == i);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$('#layer-select').trigger('change');
|
||||||
|
|||||||
@@ -49,6 +49,13 @@ ol.interaction.Modify = function(options) {
|
|||||||
*/
|
*/
|
||||||
this.vertexFeature_ = null;
|
this.vertexFeature_ = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Segments intersecting {@link this.vertexFeature_} by segment uid.
|
||||||
|
* @type {Object.<string, boolean>}
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
this.vertexSegments_ = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @type {boolean}
|
* @type {boolean}
|
||||||
* @private
|
* @private
|
||||||
@@ -379,8 +386,7 @@ ol.interaction.Modify.prototype.handleDragStart = function(evt) {
|
|||||||
this.dragSegments_.push([segmentDataMatch, 0]);
|
this.dragSegments_.push([segmentDataMatch, 0]);
|
||||||
} else if (ol.coordinate.equals(segment[1], vertex)) {
|
} else if (ol.coordinate.equals(segment[1], vertex)) {
|
||||||
this.dragSegments_.push([segmentDataMatch, 1]);
|
this.dragSegments_.push([segmentDataMatch, 1]);
|
||||||
} else if (
|
} else if (goog.getUid(segment) in this.vertexSegments_) {
|
||||||
ol.coordinate.squaredDistanceToSegment(vertex, segment) === 0) {
|
|
||||||
insertVertices.push([segmentDataMatch, vertex]);
|
insertVertices.push([segmentDataMatch, vertex]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -504,20 +510,37 @@ ol.interaction.Modify.prototype.handleMouseAtPixel_ = function(pixel, map) {
|
|||||||
if (nodes.length > 0) {
|
if (nodes.length > 0) {
|
||||||
nodes.sort(sortByDistance);
|
nodes.sort(sortByDistance);
|
||||||
var node = nodes[0];
|
var node = nodes[0];
|
||||||
var segment = node.segment; // the closest segment
|
var closestSegment = node.segment;
|
||||||
var vertex = (ol.coordinate.closestOnSegment(pixelCoordinate, segment));
|
var vertex = (ol.coordinate.closestOnSegment(pixelCoordinate,
|
||||||
|
closestSegment));
|
||||||
var vertexPixel = map.getPixelFromCoordinate(vertex);
|
var vertexPixel = map.getPixelFromCoordinate(vertex);
|
||||||
if (Math.sqrt(ol.coordinate.squaredDistance(pixel, vertexPixel)) <=
|
if (Math.sqrt(ol.coordinate.squaredDistance(pixel, vertexPixel)) <=
|
||||||
this.pixelTolerance_) {
|
this.pixelTolerance_) {
|
||||||
var pixel1 = map.getPixelFromCoordinate(segment[0]);
|
var pixel1 = map.getPixelFromCoordinate(closestSegment[0]);
|
||||||
var pixel2 = map.getPixelFromCoordinate(segment[1]);
|
var pixel2 = map.getPixelFromCoordinate(closestSegment[1]);
|
||||||
var squaredDist1 = ol.coordinate.squaredDistance(vertexPixel, pixel1);
|
var squaredDist1 = ol.coordinate.squaredDistance(vertexPixel, pixel1);
|
||||||
var squaredDist2 = ol.coordinate.squaredDistance(vertexPixel, pixel2);
|
var squaredDist2 = ol.coordinate.squaredDistance(vertexPixel, pixel2);
|
||||||
var dist = Math.sqrt(Math.min(squaredDist1, squaredDist2));
|
var dist = Math.sqrt(Math.min(squaredDist1, squaredDist2));
|
||||||
if (dist <= 10) {
|
if (dist <= 10) {
|
||||||
vertex = squaredDist1 > squaredDist2 ? segment[1] : segment[0];
|
vertex = squaredDist1 > squaredDist2 ?
|
||||||
|
closestSegment[1] : closestSegment[0];
|
||||||
}
|
}
|
||||||
this.createOrUpdateVertexFeature_(vertex);
|
this.createOrUpdateVertexFeature_(vertex);
|
||||||
|
var vertexSegments = {};
|
||||||
|
vertexSegments[goog.getUid(closestSegment)] = true;
|
||||||
|
var segment;
|
||||||
|
for (var i = 1, ii = nodes.length; i < ii; ++i) {
|
||||||
|
segment = nodes[i].segment;
|
||||||
|
if ((ol.coordinate.equals(closestSegment[0], segment[0]) &&
|
||||||
|
ol.coordinate.equals(closestSegment[1], segment[1]) ||
|
||||||
|
(ol.coordinate.equals(closestSegment[0], segment[1]) &&
|
||||||
|
ol.coordinate.equals(closestSegment[1], segment[0])))) {
|
||||||
|
vertexSegments[goog.getUid(segment)] = true;
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.vertexSegments_ = vertexSegments;
|
||||||
this.modifiable_ = true;
|
this.modifiable_ = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user