selection. Use CSS ClassName in FF, and onselectstart attribute in IE, to control selection. Fix inappropriate overriding of className in some Control subclasses in order to let this work. Prevents accidental selection of controls in IE and FF. r=euzuro. (Closes #1378) git-svn-id: http://svn.openlayers.org/trunk/openlayers@6727 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
167 lines
3.7 KiB
JavaScript
167 lines
3.7 KiB
JavaScript
/* Copyright (c) 2006-2008 MetaCarta, Inc., published under the Clear BSD
|
|
* license. See http://svn.openlayers.org/trunk/openlayers/license.txt for the
|
|
* full text of the license. */
|
|
|
|
|
|
/**
|
|
* @requires OpenLayers/Control.js
|
|
*/
|
|
|
|
/**
|
|
* Class: OpenLayers.Control.MousePosition
|
|
*/
|
|
OpenLayers.Control.MousePosition = OpenLayers.Class(OpenLayers.Control, {
|
|
|
|
/**
|
|
* Property: element
|
|
* {DOMElement}
|
|
*/
|
|
element: null,
|
|
|
|
/**
|
|
* APIProperty: prefix
|
|
* {String}
|
|
*/
|
|
prefix: '',
|
|
|
|
/**
|
|
* APIProperty: separator
|
|
* {String}
|
|
*/
|
|
separator: ', ',
|
|
|
|
/**
|
|
* APIProperty: suffix
|
|
* {String}
|
|
*/
|
|
suffix: '',
|
|
|
|
/**
|
|
* APIProperty: numDigits
|
|
* {Integer}
|
|
*/
|
|
numdigits: 5,
|
|
|
|
/**
|
|
* APIProperty: granularity
|
|
* {Integer}
|
|
*/
|
|
granularity: 10,
|
|
|
|
/**
|
|
* Property: lastXy
|
|
* {<OpenLayers.LonLat>}
|
|
*/
|
|
lastXy: null,
|
|
|
|
/**
|
|
* APIProperty: displayProjection
|
|
* {<OpenLayers.Projection>} A projection that the
|
|
* mousecontrol will display.
|
|
*/
|
|
displayProjection: null,
|
|
|
|
/**
|
|
* Constructor: OpenLayers.Control.MousePosition
|
|
*
|
|
* Parameters:
|
|
* options - {DOMElement} Options for control.
|
|
*/
|
|
initialize: function(options) {
|
|
OpenLayers.Control.prototype.initialize.apply(this, arguments);
|
|
},
|
|
|
|
/**
|
|
* Method: destroy
|
|
*/
|
|
destroy: function() {
|
|
if (this.map) {
|
|
this.map.events.unregister('mousemove', this, this.redraw);
|
|
}
|
|
OpenLayers.Control.prototype.destroy.apply(this, arguments);
|
|
},
|
|
|
|
/**
|
|
* Method: draw
|
|
* {DOMElement}
|
|
*/
|
|
draw: function() {
|
|
OpenLayers.Control.prototype.draw.apply(this, arguments);
|
|
|
|
if (!this.element) {
|
|
this.div.left = "";
|
|
this.div.top = "";
|
|
this.element = this.div;
|
|
}
|
|
|
|
this.redraw();
|
|
return this.div;
|
|
},
|
|
|
|
/**
|
|
* Method: redraw
|
|
*/
|
|
redraw: function(evt) {
|
|
|
|
var lonLat;
|
|
|
|
if (evt == null) {
|
|
lonLat = new OpenLayers.LonLat(0, 0);
|
|
} else {
|
|
if (this.lastXy == null ||
|
|
Math.abs(evt.xy.x - this.lastXy.x) > this.granularity ||
|
|
Math.abs(evt.xy.y - this.lastXy.y) > this.granularity)
|
|
{
|
|
this.lastXy = evt.xy;
|
|
return;
|
|
}
|
|
|
|
lonLat = this.map.getLonLatFromPixel(evt.xy);
|
|
if (!lonLat) {
|
|
// map has not yet been properly initialized
|
|
return;
|
|
}
|
|
if (this.displayProjection) {
|
|
lonLat.transform(this.map.getProjectionObject(),
|
|
this.displayProjection );
|
|
}
|
|
this.lastXy = evt.xy;
|
|
|
|
}
|
|
|
|
var newHtml = this.formatOutput(lonLat);
|
|
|
|
if (newHtml != this.element.innerHTML) {
|
|
this.element.innerHTML = newHtml;
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Method: formatOutput
|
|
* Override to provide custom display output
|
|
*
|
|
* Parameters:
|
|
* lonLat - {<OpenLayers.LonLat>} Location to display
|
|
*/
|
|
formatOutput: function(lonLat) {
|
|
var digits = parseInt(this.numdigits);
|
|
var newHtml =
|
|
this.prefix +
|
|
lonLat.lon.toFixed(digits) +
|
|
this.separator +
|
|
lonLat.lat.toFixed(digits) +
|
|
this.suffix;
|
|
return newHtml;
|
|
},
|
|
|
|
/**
|
|
* Method: setMap
|
|
*/
|
|
setMap: function() {
|
|
OpenLayers.Control.prototype.setMap.apply(this, arguments);
|
|
this.map.events.register( 'mousemove', this, this.redraw);
|
|
},
|
|
|
|
CLASS_NAME: "OpenLayers.Control.MousePosition"
|
|
});
|