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
129 lines
3.4 KiB
JavaScript
129 lines
3.4 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/ZoomBox.js
|
|
* @requires OpenLayers/Control/DragPan.js
|
|
* @requires OpenLayers/Handler/MouseWheel.js
|
|
*
|
|
* Class: OpenLayers.Control.Navigation
|
|
*/
|
|
OpenLayers.Control.Navigation = OpenLayers.Class.create();
|
|
OpenLayers.Control.Navigation.prototype =
|
|
OpenLayers.Class.inherit( OpenLayers.Control, {
|
|
|
|
/**
|
|
* Property: dragPan
|
|
* {<OpenLayers.Control.ZoomBox>}
|
|
*/
|
|
dragPan: null,
|
|
|
|
/**
|
|
* Property: zoomBox
|
|
* {<OpenLayers.Control.ZoomBox>}
|
|
*/
|
|
zoomBox: null,
|
|
|
|
/**
|
|
* Property: wheelHandler
|
|
* {<OpenLayers.Handler.MouseWheel>}
|
|
*/
|
|
wheelHandler: null,
|
|
|
|
/**
|
|
* Method: activate
|
|
*/
|
|
activate: function() {
|
|
this.dragPan.activate();
|
|
this.wheelHandler.activate();
|
|
this.zoomBox.activate();
|
|
return OpenLayers.Control.prototype.activate.apply(this,arguments);
|
|
},
|
|
|
|
/**
|
|
* Method: deactivate
|
|
*/
|
|
deactivate: function() {
|
|
this.zoomBox.deactivate();
|
|
this.dragPan.deactivate();
|
|
this.wheelHandler.deactivate();
|
|
return OpenLayers.Control.prototype.deactivate.apply(this,arguments);
|
|
},
|
|
|
|
/**
|
|
* Method: draw
|
|
*/
|
|
draw: function() {
|
|
this.map.events.register( "dblclick", this, this.defaultDblClick );
|
|
this.dragPan = new OpenLayers.Control.DragPan({map: this.map});
|
|
this.zoomBox = new OpenLayers.Control.ZoomBox(
|
|
{map: this.map, keyMask: OpenLayers.Handler.MOD_SHIFT});
|
|
this.dragPan.draw();
|
|
this.zoomBox.draw();
|
|
this.wheelHandler = new OpenLayers.Handler.MouseWheel(
|
|
this, {"up" : this.wheelUp,
|
|
"down": this.wheelDown} );
|
|
this.activate();
|
|
},
|
|
|
|
/**
|
|
* Method: defaultDblClick
|
|
*
|
|
* Parameters:
|
|
* evt - {Event}
|
|
*/
|
|
defaultDblClick: function (evt) {
|
|
var newCenter = this.map.getLonLatFromViewPortPx( evt.xy );
|
|
this.map.setCenter(newCenter, this.map.zoom + 1);
|
|
OpenLayers.Event.stop(evt);
|
|
return false;
|
|
},
|
|
|
|
/**
|
|
* Method: wheelChange
|
|
*
|
|
* Parameters:
|
|
* evt - {Event}
|
|
*/
|
|
wheelChange: function(evt, deltaZ) {
|
|
var newZoom = this.map.getZoom() + deltaZ;
|
|
if (!this.map.isValidZoomLevel(newZoom)) return;
|
|
|
|
var size = this.map.getSize();
|
|
var deltaX = size.w/2 - evt.xy.x;
|
|
var deltaY = evt.xy.y - size.h/2;
|
|
var newRes = this.map.baseLayer.resolutions[newZoom];
|
|
var zoomPoint = this.map.getLonLatFromPixel(evt.xy);
|
|
var newCenter = new OpenLayers.LonLat(
|
|
zoomPoint.lon + deltaX * newRes,
|
|
zoomPoint.lat + deltaY * newRes );
|
|
this.map.setCenter( newCenter, newZoom );
|
|
},
|
|
|
|
/**
|
|
* Method: wheelUp
|
|
* User spun scroll wheel up
|
|
*
|
|
* Parameters:
|
|
* evt - {Event}
|
|
*/
|
|
wheelUp: function(evt) {
|
|
this.wheelChange(evt, 1);
|
|
},
|
|
|
|
/**
|
|
* Method: wheelDown
|
|
* User spun scroll wheel down
|
|
*
|
|
* Parameters:
|
|
* evt - {Event}
|
|
*/
|
|
wheelDown: function(evt) {
|
|
this.wheelChange(evt, -1);
|
|
},
|
|
|
|
/** @final @type String */
|
|
CLASS_NAME: "OpenLayers.Control.Navigation"
|
|
});
|