Commit a change to the Strategy/Fixed to behave more like GeoRSS/Text/GML
layers, and not load by default if the layer is not visible. Includes tests. Default Behavior can be changed with 'OpenLayers.Strategy.Fixed.prototype.preload=true;'. With review from elemoine, comments from tschaub, review from me. Patch by Edgemaster. (Closes #1852) git-svn-id: http://svn.openlayers.org/trunk/openlayers@8775 dc9f47b5-9b13-0410-9fdd-eb0c1a62fdaf
This commit is contained in:
@@ -14,6 +14,14 @@
|
||||
* - <OpenLayers.Strategy>
|
||||
*/
|
||||
OpenLayers.Strategy.Fixed = OpenLayers.Class(OpenLayers.Strategy, {
|
||||
|
||||
/**
|
||||
* APIProperty: preload
|
||||
* {Boolean} Load data before layer made visible. Enabling this may result
|
||||
* in considerable overhead if your application loads many data layers
|
||||
* that are not visible by default. Default is true.
|
||||
*/
|
||||
preload: false,
|
||||
|
||||
/**
|
||||
* Constructor: OpenLayers.Strategy.Fixed
|
||||
@@ -37,8 +45,7 @@ OpenLayers.Strategy.Fixed = OpenLayers.Class(OpenLayers.Strategy, {
|
||||
|
||||
/**
|
||||
* Method: activate
|
||||
* Activate the strategy: reads all features from the protocol and add them
|
||||
* to the layer.
|
||||
* Activate the strategy: load data or add listener to load when visible
|
||||
*
|
||||
* Returns:
|
||||
* {Boolean} True if the strategy was successfully activated or false if
|
||||
@@ -46,14 +53,33 @@ OpenLayers.Strategy.Fixed = OpenLayers.Class(OpenLayers.Strategy, {
|
||||
*/
|
||||
activate: function() {
|
||||
if(OpenLayers.Strategy.prototype.activate.apply(this, arguments)) {
|
||||
this.layer.protocol.read({
|
||||
callback: this.merge,
|
||||
scope: this
|
||||
});
|
||||
if(this.layer.visibility == true || this.preload) {
|
||||
this.load();
|
||||
} else {
|
||||
this.layer.events.on({
|
||||
"visibilitychanged": this.load,
|
||||
scope: this
|
||||
});
|
||||
}
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: load
|
||||
* Tells protocol to load data and unhooks the visibilitychanged event
|
||||
*/
|
||||
load: function() {
|
||||
this.layer.protocol.read({
|
||||
callback: this.merge,
|
||||
scope: this
|
||||
});
|
||||
this.layer.events.un({
|
||||
"visibilitychanged": this.load,
|
||||
scope: this
|
||||
});
|
||||
},
|
||||
|
||||
/**
|
||||
* Method: merge
|
||||
|
||||
@@ -4,26 +4,55 @@
|
||||
<script type="text/javascript">
|
||||
|
||||
function test_activate(t) {
|
||||
t.plan(1);
|
||||
t.plan(5);
|
||||
|
||||
var featureList = ['foo', 'bar'];
|
||||
// a fake protocol
|
||||
var protocol = {
|
||||
read: function(options) {
|
||||
options.callback.call(options.scope, {features: featureList});
|
||||
}
|
||||
};
|
||||
|
||||
var layer = new OpenLayers.Layer.Vector("Vector Layer", {
|
||||
strategies: [new OpenLayers.Strategy.Fixed()],
|
||||
|
||||
// a fake protocol
|
||||
protocol: {
|
||||
read: function(options) {
|
||||
options.callback.call(options.scope, {features: featureList});
|
||||
}
|
||||
},
|
||||
|
||||
protocol: protocol,
|
||||
addFeatures: function(features) {
|
||||
t.eq(features, featureList, "Features added to the layer");
|
||||
}
|
||||
});
|
||||
|
||||
var layerp = new OpenLayers.Layer.Vector("Hidden preload Layer", {
|
||||
strategies: [new OpenLayers.Strategy.Fixed({preload:true})],
|
||||
protocol: protocol,
|
||||
visibility: false,
|
||||
addFeatures: function(features) {
|
||||
t.ok(!this.visibility, "Features preloaded before visible");
|
||||
}
|
||||
});
|
||||
|
||||
var s = new OpenLayers.Strategy.Fixed();
|
||||
var layer2 = new OpenLayers.Layer.Vector("Hidden lazyload Layer", {
|
||||
strategies: [s],
|
||||
protocol: protocol,
|
||||
visibility: false,
|
||||
addFeatures: function(features) {
|
||||
t.ok(this.visibility, "Layer visible when features added");
|
||||
}
|
||||
});
|
||||
|
||||
var map = new OpenLayers.Map('map');
|
||||
map.addLayer(layer);
|
||||
map.addLayers([layer, layerp, layer2]);
|
||||
|
||||
t.ok(layer2.events.listeners["visibilitychanged"][0].obj == s &&
|
||||
layer2.events.listeners["visibilitychanged"][0].func == s.load,
|
||||
"activate registers visibilitychanged listener if layer hidden"+
|
||||
" and is lazyloading");
|
||||
|
||||
layer2.setVisibility(true);
|
||||
|
||||
t.ok(layer2.events.listeners["visibilitychanged"] == false,
|
||||
"visibilitychanged listener unregistered");
|
||||
}
|
||||
|
||||
</script>
|
||||
|
||||
Reference in New Issue
Block a user