Adjust resolution for user extent
This commit is contained in:
@@ -631,6 +631,44 @@ export function fromUserExtent(extent, destProjection) {
|
|||||||
return transformExtent(extent, userProjection, destProjection);
|
return transformExtent(extent, userProjection, destProjection);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the resolution in user projection units per pixel. If no user projection
|
||||||
|
* is set, or source or user projection are missing units, the original resolution
|
||||||
|
* is returned.
|
||||||
|
* @param {number} resolution Resolution in input projection units per pixel.
|
||||||
|
* @param {ProjectionLike} sourceProjection The input projection.
|
||||||
|
* @return {number} Resolution in user projection units per pixel.
|
||||||
|
*/
|
||||||
|
export function toUserResolution(resolution, sourceProjection) {
|
||||||
|
if (!userProjection) {
|
||||||
|
return resolution;
|
||||||
|
}
|
||||||
|
const sourceUnits = get(sourceProjection).getUnits();
|
||||||
|
const userUnits = userProjection.getUnits();
|
||||||
|
return sourceUnits && userUnits
|
||||||
|
? (resolution * METERS_PER_UNIT[sourceUnits]) / METERS_PER_UNIT[userUnits]
|
||||||
|
: resolution;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the resolution in user projection units per pixel. If no user projection
|
||||||
|
* is set, or source or user projection are missing units, the original resolution
|
||||||
|
* is returned.
|
||||||
|
* @param {number} resolution Resolution in user projection units per pixel.
|
||||||
|
* @param {ProjectionLike} destProjection The destination projection.
|
||||||
|
* @return {number} Resolution in destination projection units per pixel.
|
||||||
|
*/
|
||||||
|
export function fromUserResolution(resolution, destProjection) {
|
||||||
|
if (!userProjection) {
|
||||||
|
return resolution;
|
||||||
|
}
|
||||||
|
const sourceUnits = get(destProjection).getUnits();
|
||||||
|
const userUnits = userProjection.getUnits();
|
||||||
|
return sourceUnits && userUnits
|
||||||
|
? (resolution * METERS_PER_UNIT[userUnits]) / METERS_PER_UNIT[sourceUnits]
|
||||||
|
: resolution;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a safe coordinate transform function from a coordinate transform function.
|
* Creates a safe coordinate transform function from a coordinate transform function.
|
||||||
* "Safe" means that it can handle wrapping of x-coordinates for global projections,
|
* "Safe" means that it can handle wrapping of x-coordinates for global projections,
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ import {
|
|||||||
getTransformFromProjections,
|
getTransformFromProjections,
|
||||||
getUserProjection,
|
getUserProjection,
|
||||||
toUserExtent,
|
toUserExtent,
|
||||||
|
toUserResolution,
|
||||||
} from '../../proj.js';
|
} from '../../proj.js';
|
||||||
import {getUid} from '../../util.js';
|
import {getUid} from '../../util.js';
|
||||||
import {wrapX as wrapCoordinateX} from '../../coordinate.js';
|
import {wrapX as wrapCoordinateX} from '../../coordinate.js';
|
||||||
@@ -642,9 +643,11 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
let userTransform;
|
let userTransform;
|
||||||
if (userProjection) {
|
if (userProjection) {
|
||||||
for (let i = 0, ii = loadExtents.length; i < ii; ++i) {
|
for (let i = 0, ii = loadExtents.length; i < ii; ++i) {
|
||||||
|
const extent = loadExtents[i];
|
||||||
|
const userExtent = toUserExtent(extent, projection);
|
||||||
vectorSource.loadFeatures(
|
vectorSource.loadFeatures(
|
||||||
toUserExtent(loadExtents[i], projection),
|
userExtent,
|
||||||
resolution,
|
toUserResolution(resolution, projection),
|
||||||
userProjection
|
userProjection
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ import {xhr} from '../featureloader.js';
|
|||||||
* returns an array of {@link module:ol/extent~Extent} with the extents to load. Usually this
|
* returns an array of {@link module:ol/extent~Extent} with the extents to load. Usually this
|
||||||
* is one of the standard {@link module:ol/loadingstrategy} strategies.
|
* is one of the standard {@link module:ol/loadingstrategy} strategies.
|
||||||
*
|
*
|
||||||
* @typedef {function(import("../extent.js").Extent, number): Array<import("../extent.js").Extent>} LoadingStrategy
|
* @typedef {function(import("../extent.js").Extent, number, import("../proj/Projection.js").default): Array<import("../extent.js").Extent>} LoadingStrategy
|
||||||
* @api
|
* @api
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -939,7 +939,7 @@ class VectorSource extends Source {
|
|||||||
*/
|
*/
|
||||||
loadFeatures(extent, resolution, projection) {
|
loadFeatures(extent, resolution, projection) {
|
||||||
const loadedExtentsRtree = this.loadedExtentsRtree_;
|
const loadedExtentsRtree = this.loadedExtentsRtree_;
|
||||||
const extentsToLoad = this.strategy_(extent, resolution);
|
const extentsToLoad = this.strategy_(extent, resolution, projection);
|
||||||
for (let i = 0, ii = extentsToLoad.length; i < ii; ++i) {
|
for (let i = 0, ii = extentsToLoad.length; i < ii; ++i) {
|
||||||
const extentToLoad = extentsToLoad[i];
|
const extentToLoad = extentsToLoad[i];
|
||||||
const alreadyLoaded = loadedExtentsRtree.forEachInExtent(
|
const alreadyLoaded = loadedExtentsRtree.forEachInExtent(
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ import {
|
|||||||
fromLonLat,
|
fromLonLat,
|
||||||
fromUserCoordinate,
|
fromUserCoordinate,
|
||||||
fromUserExtent,
|
fromUserExtent,
|
||||||
|
fromUserResolution,
|
||||||
getPointResolution,
|
getPointResolution,
|
||||||
get as getProjection,
|
get as getProjection,
|
||||||
getTransform,
|
getTransform,
|
||||||
@@ -21,6 +22,7 @@ import {
|
|||||||
toLonLat,
|
toLonLat,
|
||||||
toUserCoordinate,
|
toUserCoordinate,
|
||||||
toUserExtent,
|
toUserExtent,
|
||||||
|
toUserResolution,
|
||||||
transform,
|
transform,
|
||||||
transformExtent,
|
transformExtent,
|
||||||
useGeographic,
|
useGeographic,
|
||||||
@@ -151,6 +153,36 @@ describe('ol/proj.js', function () {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('fromUserResolution()', function () {
|
||||||
|
it("adjusts a resolution for the user projection's units", function () {
|
||||||
|
useGeographic();
|
||||||
|
const user = 1 / METERS_PER_UNIT['degrees'];
|
||||||
|
const resolution = fromUserResolution(user, 'EPSG:3857');
|
||||||
|
expect(resolution).to.roughlyEqual(1, 1e-9);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns the original if no user projection is set', function () {
|
||||||
|
const user = METERS_PER_UNIT['meters'];
|
||||||
|
const resolution = fromUserResolution(user, 'EPSG:3857');
|
||||||
|
expect(resolution).to.eql(user);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('toUserResolution()', function () {
|
||||||
|
it("adjusts a resolution for the user projection's units", function () {
|
||||||
|
useGeographic();
|
||||||
|
const dest = 1;
|
||||||
|
const resolution = toUserResolution(dest, 'EPSG:3857');
|
||||||
|
expect(resolution).to.eql(1 / METERS_PER_UNIT['degrees']);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns the original if no user projection is set', function () {
|
||||||
|
const dest = METERS_PER_UNIT['degrees'];
|
||||||
|
const resolution = toUserResolution(dest, 'EPSG:3857');
|
||||||
|
expect(resolution).to.eql(dest);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('toLonLat()', function () {
|
describe('toLonLat()', function () {
|
||||||
const cases = [
|
const cases = [
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user