Only start dragging when we are over a feature. r=tschaub (closes #3252)
git-svn-id: http://svn.openlayers.org/trunk/openlayers@11888 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
This commit is contained in:
@@ -171,7 +171,7 @@ OpenLayers.Control.DragFeature = OpenLayers.Class(OpenLayers.Control, {
|
|||||||
* feature - {<OpenLayers.Feature.Vector>}
|
* feature - {<OpenLayers.Feature.Vector>}
|
||||||
*/
|
*/
|
||||||
clickFeature: function(feature) {
|
clickFeature: function(feature) {
|
||||||
if (this.overFeature(feature)) {
|
if (!this.over && this.overFeature(feature)) {
|
||||||
this.handlers.drag.dragstart(this.handlers.feature.evt);
|
this.handlers.drag.dragstart(this.handlers.feature.evt);
|
||||||
// to let the events propagate to the feature handler (click callback)
|
// to let the events propagate to the feature handler (click callback)
|
||||||
this.handlers.drag.stopDown = false;
|
this.handlers.drag.stopDown = false;
|
||||||
@@ -186,8 +186,10 @@ OpenLayers.Control.DragFeature = OpenLayers.Class(OpenLayers.Control, {
|
|||||||
* feature - {<OpenLayers.Feature.Vector>}
|
* feature - {<OpenLayers.Feature.Vector>}
|
||||||
*/
|
*/
|
||||||
clickoutFeature: function(feature) {
|
clickoutFeature: function(feature) {
|
||||||
this.outFeature(feature);
|
if (this.over) {
|
||||||
this.handlers.drag.stopDown = true;
|
this.outFeature(feature);
|
||||||
|
this.handlers.drag.stopDown = true;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -357,6 +357,24 @@
|
|||||||
"onLeave called with expected feature");
|
"onLeave called with expected feature");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function test_Control_DragFeature_click(t) {
|
||||||
|
t.plan(1);
|
||||||
|
var map = new OpenLayers.Map("map");
|
||||||
|
var layer = new OpenLayers.Layer.Vector();
|
||||||
|
map.addLayer(layer);
|
||||||
|
var feature = new OpenLayers.Feature.Vector();
|
||||||
|
feature.layer = layer;
|
||||||
|
var control = new OpenLayers.Control.DragFeature(layer);
|
||||||
|
map.addControl(control);
|
||||||
|
|
||||||
|
control.activate();
|
||||||
|
|
||||||
|
control.overFeature(feature);
|
||||||
|
control.handlers.feature.evt = {which: 1};
|
||||||
|
control.clickFeature(feature);
|
||||||
|
t.eq(control.handlers.drag.started, false, "click after over does not start drag handler");
|
||||||
|
}
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|||||||
Reference in New Issue
Block a user