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
187 lines
5.3 KiB
JavaScript
187 lines
5.3 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
|
|
*
|
|
* Class: OpenLayers.PanZoom
|
|
*
|
|
* Inherits from:
|
|
* - <OpenLayers.Control>
|
|
*/
|
|
OpenLayers.Control.PanZoom = OpenLayers.Class.create();
|
|
OpenLayers.Control.PanZoom.X = 4;
|
|
OpenLayers.Control.PanZoom.Y = 4;
|
|
OpenLayers.Control.PanZoom.prototype =
|
|
OpenLayers.Class.inherit( OpenLayers.Control, {
|
|
|
|
/**
|
|
* APIProperty: slideFactor
|
|
* {Float}
|
|
*/
|
|
slideFactor: 50,
|
|
|
|
/**
|
|
* Property: buttons
|
|
* Array of Button Divs
|
|
*/
|
|
buttons: null,
|
|
|
|
/**
|
|
* Property: position
|
|
* {<OpenLayers.Pixel>}
|
|
*/
|
|
position: null,
|
|
|
|
/**
|
|
* Constructor: OpenLayers.PanZoom
|
|
*/
|
|
initialize: function() {
|
|
this.position = new OpenLayers.Pixel(OpenLayers.Control.PanZoom.X,
|
|
OpenLayers.Control.PanZoom.Y);
|
|
OpenLayers.Control.prototype.initialize.apply(this, arguments);
|
|
},
|
|
|
|
/**
|
|
* APIMethod: destroy
|
|
*/
|
|
destroy: function() {
|
|
OpenLayers.Control.prototype.destroy.apply(this, arguments);
|
|
while(this.buttons.length) {
|
|
var btn = this.buttons.shift();
|
|
btn.map = null;
|
|
OpenLayers.Event.stopObservingElement(btn);
|
|
}
|
|
this.buttons = null;
|
|
this.position = null;
|
|
},
|
|
|
|
/**
|
|
* Method: draw
|
|
*
|
|
* Parameters:
|
|
* px - {<OpenLayers.Pixel>}
|
|
*
|
|
* Returns:
|
|
* {DOMElement} A reference to the container div for the PanZoom control
|
|
*/
|
|
draw: function(px) {
|
|
// initialize our internal div
|
|
OpenLayers.Control.prototype.draw.apply(this, arguments);
|
|
px = this.position;
|
|
|
|
// place the controls
|
|
this.buttons = new Array();
|
|
|
|
var sz = new OpenLayers.Size(18,18);
|
|
var centered = new OpenLayers.Pixel(px.x+sz.w/2, px.y);
|
|
|
|
this._addButton("panup", "north-mini.png", centered, sz);
|
|
px.y = centered.y+sz.h;
|
|
this._addButton("panleft", "west-mini.png", px, sz);
|
|
this._addButton("panright", "east-mini.png", px.add(sz.w, 0), sz);
|
|
this._addButton("pandown", "south-mini.png",
|
|
centered.add(0, sz.h*2), sz);
|
|
this._addButton("zoomin", "zoom-plus-mini.png",
|
|
centered.add(0, sz.h*3+5), sz);
|
|
this._addButton("zoomworld", "zoom-world-mini.png",
|
|
centered.add(0, sz.h*4+5), sz);
|
|
this._addButton("zoomout", "zoom-minus-mini.png",
|
|
centered.add(0, sz.h*5+5), sz);
|
|
return this.div;
|
|
},
|
|
|
|
/**
|
|
* Method: _addButton
|
|
*
|
|
* Parameters:
|
|
* id - {String}
|
|
* img - {String}
|
|
* xy - {<OpenLayers.Pixel>}
|
|
* sz - {<OpenLayers.Size>}
|
|
*
|
|
* Returns:
|
|
* {DOMElement} A Div (an alphaImageDiv, to be precise) that contains the
|
|
* image of the button, and has all the proper event handlers set.
|
|
*/
|
|
_addButton:function(id, img, xy, sz) {
|
|
var imgLocation = OpenLayers.Util.getImagesLocation() + img;
|
|
var btn = OpenLayers.Util.createAlphaImageDiv(
|
|
"OpenLayers_Control_PanZoom_" + id,
|
|
xy, sz, imgLocation, "absolute");
|
|
|
|
//we want to add the outer div
|
|
this.div.appendChild(btn);
|
|
|
|
OpenLayers.Event.observe(btn, "mousedown",
|
|
this.buttonDown.bindAsEventListener(btn));
|
|
OpenLayers.Event.observe(btn, "mouseup",
|
|
this.doubleClick.bindAsEventListener(btn));
|
|
OpenLayers.Event.observe(btn, "dblclick",
|
|
this.doubleClick.bindAsEventListener(btn));
|
|
OpenLayers.Event.observe(btn, "click",
|
|
this.doubleClick.bindAsEventListener(btn));
|
|
btn.action = id;
|
|
btn.map = this.map;
|
|
btn.slideFactor = this.slideFactor;
|
|
|
|
//we want to remember/reference the outer div
|
|
this.buttons.push(btn);
|
|
return btn;
|
|
},
|
|
|
|
/**
|
|
* Method: doubleClick
|
|
*
|
|
* Parameters:
|
|
* evt - {Event}
|
|
*
|
|
* Returns: {Boolean}
|
|
*/
|
|
doubleClick: function (evt) {
|
|
OpenLayers.Event.stop(evt);
|
|
return false;
|
|
},
|
|
|
|
/**
|
|
* Method: buttonDown
|
|
*
|
|
* Parameters:
|
|
* evt - {Event}
|
|
*/
|
|
buttonDown: function (evt) {
|
|
if (!OpenLayers.Event.isLeftClick(evt)) return;
|
|
|
|
switch (this.action) {
|
|
case "panup":
|
|
this.map.pan(0, -50);
|
|
break;
|
|
case "pandown":
|
|
this.map.pan(0, 50);
|
|
break;
|
|
case "panleft":
|
|
this.map.pan(-50, 0);
|
|
break;
|
|
case "panright":
|
|
this.map.pan(50, 0);
|
|
break;
|
|
case "zoomin":
|
|
this.map.zoomIn();
|
|
break;
|
|
case "zoomout":
|
|
this.map.zoomOut();
|
|
break;
|
|
case "zoomworld":
|
|
this.map.zoomToMaxExtent();
|
|
break;
|
|
}
|
|
|
|
OpenLayers.Event.stop(evt);
|
|
},
|
|
|
|
/** @final @type String */
|
|
CLASS_NAME: "OpenLayers.Control.PanZoom"
|
|
});
|