has been done in the NaturalDocs branch back to trunk. Thanks to everyone who helped out in making this happen. (I could list people, but the list would be long, and I'm already mentally on vacation.) git-svn-id: http://svn.openlayers.org/trunk/openlayers@3545 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
204 lines
5.9 KiB
JavaScript
204 lines
5.9 KiB
JavaScript
/* Copyright (c) 2006 MetaCarta, Inc., published under a modified BSD license.
|
|
* See http://svn.openlayers.org/trunk/openlayers/repository-license.txt
|
|
* for the full text of the license. */
|
|
|
|
|
|
/**
|
|
* @requires OpenLayers/Control.js
|
|
* @requires OpenLayers/Feature/Vector.js
|
|
*
|
|
* Class: OpenLayers.Control.SelectFeature
|
|
* Draws features on a vector layer when active.
|
|
*
|
|
* Inherits from:
|
|
* - <OpenLayers.Control>
|
|
*/
|
|
OpenLayers.Control.SelectFeature = OpenLayers.Class.create();
|
|
OpenLayers.Control.SelectFeature.prototype =
|
|
OpenLayers.Class.inherit(OpenLayers.Control, {
|
|
|
|
/**
|
|
* APIProperty: multiple
|
|
* {Boolean} Allow selection of multiple geometries
|
|
*/
|
|
multiple: false,
|
|
|
|
/**
|
|
* APIProperty: hover
|
|
* {Boolean} Select on mouse over and deselect on mouse out. If true, this
|
|
* ignores clicks and only listens to mouse moves.
|
|
*/
|
|
hover: false,
|
|
|
|
/**
|
|
* APIProperty: onSelect
|
|
* {Function} Optional function to be called when a feature is selected.
|
|
* The function should expect to be called with a feature.
|
|
*/
|
|
onSelect: function() {},
|
|
|
|
/**
|
|
* APIProperty: onUnselect
|
|
* {Function} Optional function to be called when a feature is unselected.
|
|
* The function should expect to be called with a feature.
|
|
*/
|
|
onUnselect: function() {},
|
|
|
|
/**
|
|
* Property: layer
|
|
* {<OpenLayers.Layer.Vector>}
|
|
*/
|
|
layer: null,
|
|
|
|
/**
|
|
* APIProperty: callbacks
|
|
* {Object} The functions that are sent to the handler for callback
|
|
*/
|
|
callbacks: null,
|
|
|
|
/**
|
|
* APIProperty: selectStyle
|
|
* {Object} Hash of styles
|
|
*/
|
|
selectStyle: OpenLayers.Feature.Vector.style['select'],
|
|
|
|
/**
|
|
* Property: handler
|
|
* {<OpenLayers.Handler.Feature>}
|
|
*/
|
|
handler: null,
|
|
|
|
/**
|
|
* Constructor: <OpenLayers.Control.SelectFeature>
|
|
*
|
|
* Parameters:
|
|
* layer - {<OpenLayers.Layer.Vector>}
|
|
* handler - {<OpenLayers.Handler>}
|
|
* options - {Object}
|
|
*/
|
|
initialize: function(layer, options) {
|
|
OpenLayers.Control.prototype.initialize.apply(this, [options]);
|
|
this.callbacks = OpenLayers.Util.extend({
|
|
down: this.downFeature,
|
|
over: this.overFeature,
|
|
out: this.outFeature
|
|
}, this.callbacks);
|
|
this.layer = layer;
|
|
this.handler = new OpenLayers.Handler.Feature(this, layer, this.callbacks);
|
|
},
|
|
|
|
/**
|
|
* Method: downFeature
|
|
* Called when the feature handler detects a mouse-down on a feature
|
|
*
|
|
* Parameters:
|
|
* feature - {<OpenLayers.Vector.Feature>}
|
|
*/
|
|
downFeature: function(feature) {
|
|
if(this.hover) {
|
|
return;
|
|
}
|
|
if (this.multiple) {
|
|
if(OpenLayers.Util.indexOf(this.layer.selectedFeatures, feature) > -1) {
|
|
this.unselect(feature);
|
|
} else {
|
|
this.select(feature);
|
|
}
|
|
} else {
|
|
if(OpenLayers.Util.indexOf(this.layer.selectedFeatures, feature) > -1) {
|
|
this.unselect(feature);
|
|
} else {
|
|
if (this.layer.selectedFeatures) {
|
|
for (var i = 0; i < this.layer.selectedFeatures.length; i++) {
|
|
this.unselect(this.layer.selectedFeatures[i]);
|
|
}
|
|
}
|
|
this.select(feature);
|
|
}
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Method: overFeature
|
|
* Called when the feature handler detects a mouse-over on a feature.
|
|
* Only responds if this.hover is true.
|
|
*
|
|
* Parameters:
|
|
* feature - {<OpenLayers.Feature.Vector>}
|
|
*/
|
|
overFeature: function(feature) {
|
|
if(!this.hover) {
|
|
return;
|
|
}
|
|
if(!(OpenLayers.Util.indexOf(this.layer.selectedFeatures, feature) > -1)) {
|
|
this.select(feature);
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Method: outFeature
|
|
* Called when the feature handler detects a mouse-out on a feature.
|
|
* Only responds if this.hover is true.
|
|
*
|
|
* Parameters:
|
|
* feature - {<OpenLayers.Feature.Vector>}
|
|
*/
|
|
outFeature: function(feature) {
|
|
if(!this.hover) {
|
|
return;
|
|
}
|
|
this.unselect(feature);
|
|
},
|
|
|
|
/**
|
|
* Method: select
|
|
* Add feature to the layer's selectedFeature array, render the feature as
|
|
* selected, and call the onSelect function.
|
|
*
|
|
* Parameters:
|
|
* feature - {<OpenLayers.Feature.Vector>}
|
|
*/
|
|
select: function(feature) {
|
|
// Store feature style for restoration later
|
|
if(feature.originalStyle == null) {
|
|
feature.originalStyle = feature.style;
|
|
}
|
|
this.layer.selectedFeatures.push(feature);
|
|
this.layer.drawFeature(feature, this.selectStyle);
|
|
this.onSelect(feature);
|
|
},
|
|
|
|
/**
|
|
* Method: unselect
|
|
* Remove feature from the layer's selectedFeature array, render the feature as
|
|
* normal, and call the onUnselect function.
|
|
*
|
|
* Parameters:
|
|
* feature - {<OpenLayers.Feature.Vector>}
|
|
*/
|
|
unselect: function(feature) {
|
|
// Store feature style for restoration later
|
|
if(feature.originalStyle == null) {
|
|
feature.originalStyle = feature.style;
|
|
}
|
|
this.layer.drawFeature(feature, feature.originalStyle);
|
|
OpenLayers.Util.removeItem(this.layer.selectedFeatures, feature);
|
|
this.onUnselect(feature);
|
|
},
|
|
|
|
/**
|
|
* Method: setMap
|
|
* Set the map property for the control.
|
|
*
|
|
* Parameters:
|
|
* map - {<OpenLayers.Map>}
|
|
*/
|
|
setMap: function(map) {
|
|
this.handler.setMap(map);
|
|
OpenLayers.Control.prototype.setMap.apply(this, arguments);
|
|
},
|
|
|
|
/** @final @type String */
|
|
CLASS_NAME: "OpenLayers.Control.SelectFeature"
|
|
});
|