New SVG2 renderer for increased performance and smaller library size. Not enabled by default. To use, include 'SVG2' in the renderers array of your OpenLayers.Layer.Vector instance. r=crschmidt (closes #2802)
git-svn-id: http://svn.openlayers.org/trunk/openlayers@11616 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
This commit is contained in:
141
lib/OpenLayers/Renderer/NG.js
Normal file
141
lib/OpenLayers/Renderer/NG.js
Normal file
@@ -0,0 +1,141 @@
|
||||
/* Copyright (c) 2006-2011 by OpenLayers Contributors (see authors.txt for
|
||||
* full list of contributors). Published under the Clear BSD license.
|
||||
* See http://svn.openlayers.org/trunk/openlayers/license.txt for the
|
||||
* full text of the license. */
|
||||
|
||||
/**
|
||||
* @requires OpenLayers/Renderer/Elements.js
|
||||
*/
|
||||
|
||||
/**
|
||||
* Class: OpenLayers.Renderer.NG
|
||||
*
|
||||
* Inherits from:
|
||||
* - <OpenLayers.Renderer.Elements>
|
||||
*/
|
||||
OpenLayers.Renderer.NG = OpenLayers.Class(OpenLayers.Renderer.Elements, {
|
||||
|
||||
/**
|
||||
* Constant: labelNodeType
|
||||
* {String} The node type for text label containers. To be defined by
|
||||
* subclasses.
|
||||
*/
|
||||
labelNodeType: null,
|
||||
|
||||
/**
|
||||
* Constructor: OpenLayers.Renderer.NG
|
||||
*
|
||||
* Parameters:
|
||||
* containerID - {String}
|
||||
* options - {Object} options for this renderer. Supported options are:
|
||||
* * yOrdering - {Boolean} Whether to use y-ordering
|
||||
* * zIndexing - {Boolean} Whether to use z-indexing. Will be ignored
|
||||
* if yOrdering is set to true.
|
||||
*/
|
||||
initialize: function(containerID, options) {
|
||||
OpenLayers.Renderer.Elements.prototype.initialize.apply(this, arguments);
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: destroy
|
||||
*/
|
||||
destroy: function() {
|
||||
OpenLayers.Renderer.Elements.prototype.destroy.apply(this, arguments);
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: updateDimensions
|
||||
* To be extended by subclasses - here we set positioning related styles
|
||||
* on HTML elements, subclasses have to do the same for renderer specific
|
||||
* elements (e.g. viesBox, width and height of the rendererRoot)
|
||||
*/
|
||||
updateDimensions: function() {
|
||||
var mapExtent = this.map.getExtent();
|
||||
var renderExtent = this.map.getMaxExtent();
|
||||
this.setExtent(renderExtent, true);
|
||||
var res = this.getResolution();
|
||||
var div = this.rendererRoot.parentNode;
|
||||
var layerLeft = parseFloat(div.parentNode.style.left);
|
||||
var layerTop = parseFloat(div.parentNode.style.top);
|
||||
div.style.left = ((renderExtent.left - mapExtent.left) / res - layerLeft) + "px";
|
||||
div.style.top = ((mapExtent.top - renderExtent.top) / res - layerTop) + "px";
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: resize
|
||||
*/
|
||||
setSize: function() {
|
||||
this.map.getExtent() && this.updateDimensions();
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: drawFeature
|
||||
* Draw the feature. The optional style argument can be used
|
||||
* to override the feature's own style. This method should only
|
||||
* be called from layer.drawFeature().
|
||||
*
|
||||
* Parameters:
|
||||
* feature - {<OpenLayers.Feature.Vector>}
|
||||
* style - {<Object>}
|
||||
*
|
||||
* Returns:
|
||||
* {Boolean} true if the feature has been drawn completely, false if not,
|
||||
* undefined if the feature had no geometry
|
||||
*/
|
||||
drawFeature: function(feature, style) {
|
||||
if(style == null) {
|
||||
style = feature.style;
|
||||
}
|
||||
if (feature.geometry) {
|
||||
var rendered = this.drawGeometry(feature.geometry, style, feature.id);
|
||||
if(rendered !== false && style.label) {
|
||||
var location = feature.geometry.getCentroid();
|
||||
this.drawText(feature.id, style, location);
|
||||
} else {
|
||||
this.removeText(feature.id);
|
||||
}
|
||||
return rendered;
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: drawText
|
||||
* Function for drawing text labels.
|
||||
* This method is only called by the renderer itself.
|
||||
*
|
||||
* Parameters:
|
||||
* featureId - {String|DOMElement}
|
||||
* style - {Object}
|
||||
* location - {<OpenLayers.Geometry.Point>}, will be modified inline
|
||||
*
|
||||
* Returns:
|
||||
* {DOMElement} container holding the text label (to be populated by
|
||||
* subclasses)
|
||||
*/
|
||||
drawText: function(featureId, style, location) {
|
||||
var label;
|
||||
if (typeof featureId !== "string") {
|
||||
label = featureId;
|
||||
} else {
|
||||
label = this.nodeFactory(featureId + this.LABEL_ID_SUFFIX, this.labelNodeType);
|
||||
label._featureId = featureId;
|
||||
}
|
||||
label._style = style;
|
||||
label._x = location.x;
|
||||
label._y = location.y;
|
||||
if(style.labelXOffset || style.labelYOffset) {
|
||||
xOffset = isNaN(style.labelXOffset) ? 0 : style.labelXOffset;
|
||||
yOffset = isNaN(style.labelYOffset) ? 0 : style.labelYOffset;
|
||||
var res = this.getResolution();
|
||||
location.move(xOffset*res, yOffset*res);
|
||||
}
|
||||
|
||||
if(label.parentNode !== this.textRoot) {
|
||||
this.textRoot.appendChild(label);
|
||||
}
|
||||
|
||||
return label;
|
||||
},
|
||||
|
||||
CLASS_NAME: "OpenLayers.Renderer.NG"
|
||||
});
|
||||
Reference in New Issue
Block a user