Merge pull request #9712 from tschaub/mvt-id

Allow an arbitrary tag to be used as feature id
This commit is contained in:
Tim Schaub
2019-06-24 16:42:06 -06:00
committed by GitHub
2 changed files with 54 additions and 1 deletions

View File

@@ -31,6 +31,7 @@ import {get} from '../proj.js';
* @property {string} [geometryName='geometry'] Geometry name to use when creating features. * @property {string} [geometryName='geometry'] Geometry name to use when creating features.
* @property {string} [layerName='layer'] Name of the feature attribute that holds the layer name. * @property {string} [layerName='layer'] Name of the feature attribute that holds the layer name.
* @property {Array<string>} [layers] Layers to read features from. If not provided, features will be read from all * @property {Array<string>} [layers] Layers to read features from. If not provided, features will be read from all
* @property {string} [idProperty] Optional property that will be assigned as the feature id and removed from the properties.
* layers. * layers.
*/ */
@@ -84,6 +85,12 @@ class MVT extends FeatureFormat {
*/ */
this.layers_ = options.layers ? options.layers : null; this.layers_ = options.layers ? options.layers : null;
/**
* @private
* @type {string}
*/
this.idProperty_ = options.idProperty;
} }
/** /**
@@ -164,8 +171,16 @@ class MVT extends FeatureFormat {
} }
let feature; let feature;
const id = rawFeature.id;
const values = rawFeature.properties; const values = rawFeature.properties;
let id;
if (!this.idProperty_) {
id = rawFeature.id;
} else {
id = values[this.idProperty_];
delete values[this.idProperty_];
}
values[this.layerName_] = rawFeature.layer.name; values[this.layerName_] = rawFeature.layer.name;
const flatCoordinates = []; const flatCoordinates = [];

View File

@@ -78,6 +78,44 @@ where('ArrayBuffer.isView').describe('ol.format.MVT', function() {
expect(features[0].getId()).to.be(2); expect(features[0].getId()).to.be(2);
}); });
it('accepts custom idProperty', function() {
const format = new MVT({
featureClass: Feature,
layers: ['poi_label'],
idProperty: 'osm_id'
});
const features = format.readFeatures(data, options);
const first = features[0];
expect(first.getId()).to.be(1000000057590683);
expect(first.get('osm_id')).to.be(undefined);
});
it('accepts custom idProperty (render features)', function() {
const format = new MVT({
layers: ['poi_label'],
idProperty: 'osm_id'
});
const features = format.readFeatures(data, options);
const first = features[0];
expect(first.getId()).to.be(1000000057590683);
expect(first.get('osm_id')).to.be(undefined);
});
it('works if you provide a bogus idProperty', function() {
const format = new MVT({
layers: ['poi_label'],
idProperty: 'bogus'
});
const features = format.readFeatures(data, options);
const first = features[0];
expect(first.getId()).to.be(undefined);
});
}); });
}); });