Make the immediate API work with a user projection
This commit is contained in:
14
examples/immediate-geographic.html
Normal file
14
examples/immediate-geographic.html
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
---
|
||||||
|
layout: example.html
|
||||||
|
title: Immediate Rendering (Geographic)
|
||||||
|
shortdesc: Using the immediate rendering API with geometries in geographic coordinates.
|
||||||
|
docs: >
|
||||||
|
This example uses the "immediate" rendering API with geometries in geographic coordinates.
|
||||||
|
The immediate rendering API lets you draw styled geometries without adding them to a layer first.
|
||||||
|
Use the `getVectorContext` function to create a rendering context from a render event. Using the
|
||||||
|
`context.drawGeometry()` and `context.setStyle()` methods on this rendering context, you can draw
|
||||||
|
any geometry on each render frame. The `useGeographic` function is used in this example so that
|
||||||
|
geometries can be in geographic coordinates.
|
||||||
|
tags: "immediate, geographic"
|
||||||
|
---
|
||||||
|
<div id="map" class="map"></div>
|
||||||
64
examples/immediate-geographic.js
Normal file
64
examples/immediate-geographic.js
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
import {Map, View} from '../src/ol/index.js';
|
||||||
|
import {Point} from '../src/ol/geom.js';
|
||||||
|
import TileLayer from '../src/ol/layer/Tile.js';
|
||||||
|
import Stamen from '../src/ol/source/Stamen.js';
|
||||||
|
import {Circle, Fill, Style} from '../src/ol/style.js';
|
||||||
|
import {getVectorContext} from '../src/ol/render.js';
|
||||||
|
import {useGeographic} from '../src/ol/proj.js';
|
||||||
|
import {upAndDown} from '../src/ol/easing.js';
|
||||||
|
|
||||||
|
useGeographic();
|
||||||
|
|
||||||
|
const layer = new TileLayer({
|
||||||
|
source: new Stamen({
|
||||||
|
layer: 'toner'
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
const map = new Map({
|
||||||
|
layers: [layer],
|
||||||
|
target: 'map',
|
||||||
|
view: new View({
|
||||||
|
center: [0, 0],
|
||||||
|
zoom: 2
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
const image = new Circle({
|
||||||
|
radius: 8,
|
||||||
|
fill: new Fill({color: 'rgb(255, 153, 0)'})
|
||||||
|
});
|
||||||
|
|
||||||
|
const style = new Style({
|
||||||
|
image: image
|
||||||
|
});
|
||||||
|
|
||||||
|
const n = 1000;
|
||||||
|
const geometries = new Array(n);
|
||||||
|
|
||||||
|
for (let i = 0; i < n; ++i) {
|
||||||
|
const lon = 360 * Math.random() - 180;
|
||||||
|
const lat = 180 * Math.random() - 90;
|
||||||
|
geometries[i] = new Point([lon, lat]);
|
||||||
|
}
|
||||||
|
|
||||||
|
layer.on('postrender', function(event) {
|
||||||
|
const vectorContext = getVectorContext(event);
|
||||||
|
|
||||||
|
for (let i = 0; i < n; ++i) {
|
||||||
|
const importance = upAndDown(Math.pow((n - i) / n, 0.15));
|
||||||
|
if (importance < 0.1) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
image.setOpacity(importance);
|
||||||
|
image.setScale(importance);
|
||||||
|
vectorContext.setStyle(style);
|
||||||
|
vectorContext.drawGeometry(geometries[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
const lon = 360 * Math.random() - 180;
|
||||||
|
const lat = 180 * Math.random() - 90;
|
||||||
|
geometries.push(new Point([lon, lat]));
|
||||||
|
geometries.shift();
|
||||||
|
map.render();
|
||||||
|
});
|
||||||
@@ -5,7 +5,7 @@ import {abstract} from '../util.js';
|
|||||||
import BaseObject from '../Object.js';
|
import BaseObject from '../Object.js';
|
||||||
import {createEmpty, getHeight, returnOrUpdate} from '../extent.js';
|
import {createEmpty, getHeight, returnOrUpdate} from '../extent.js';
|
||||||
import {transform2D} from './flat/transform.js';
|
import {transform2D} from './flat/transform.js';
|
||||||
import {get as getProjection, getTransform, getTransformFromProjections} from '../proj.js';
|
import {get as getProjection, getTransform} from '../proj.js';
|
||||||
import Units from '../proj/Units.js';
|
import Units from '../proj/Units.js';
|
||||||
import {create as createTransform, compose as composeTransform} from '../transform.js';
|
import {create as createTransform, compose as composeTransform} from '../transform.js';
|
||||||
import {memoizeOne} from '../functions.js';
|
import {memoizeOne} from '../functions.js';
|
||||||
@@ -62,17 +62,15 @@ class Geometry extends BaseObject {
|
|||||||
* @abstract
|
* @abstract
|
||||||
* @param {number} revision The geometry revision.
|
* @param {number} revision The geometry revision.
|
||||||
* @param {number} squaredTolerance Squared tolerance.
|
* @param {number} squaredTolerance Squared tolerance.
|
||||||
* @param {import("../proj/Projection.js").default} [sourceProjection] The source projection.
|
* @param {import("../proj.js").TransformFunction} [opt_transform] Optional transform function.
|
||||||
* @param {import("../proj/Projection.js").default} [destProjection] The destination projection.
|
|
||||||
* @return {Geometry} Simplified geometry.
|
* @return {Geometry} Simplified geometry.
|
||||||
*/
|
*/
|
||||||
this.simplifyTransformedInternal = memoizeOne(function(revision, squaredTolerance, sourceProjection, destProjection) {
|
this.simplifyTransformedInternal = memoizeOne(function(revision, squaredTolerance, opt_transform) {
|
||||||
if (!sourceProjection || !destProjection) {
|
if (!opt_transform) {
|
||||||
return this.getSimplifiedGeometry(squaredTolerance);
|
return this.getSimplifiedGeometry(squaredTolerance);
|
||||||
}
|
}
|
||||||
const transform = getTransformFromProjections(sourceProjection, destProjection);
|
|
||||||
const clone = this.clone();
|
const clone = this.clone();
|
||||||
clone.applyTransform(transform);
|
clone.applyTransform(opt_transform);
|
||||||
return clone.getSimplifiedGeometry(squaredTolerance);
|
return clone.getSimplifiedGeometry(squaredTolerance);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -82,12 +80,11 @@ class Geometry extends BaseObject {
|
|||||||
* Get a transformed and simplified version of the geometry.
|
* Get a transformed and simplified version of the geometry.
|
||||||
* @abstract
|
* @abstract
|
||||||
* @param {number} squaredTolerance Squared tolerance.
|
* @param {number} squaredTolerance Squared tolerance.
|
||||||
* @param {import("../proj/Projection.js").default} sourceProjection The source projection.
|
* @param {import("../proj.js").TransformFunction} [opt_transform] Optional transform function.
|
||||||
* @param {import("../proj/Projection.js").default} destProjection The destination projection.
|
|
||||||
* @return {Geometry} Simplified geometry.
|
* @return {Geometry} Simplified geometry.
|
||||||
*/
|
*/
|
||||||
simplifyTransformed(squaredTolerance, sourceProjection, destProjection) {
|
simplifyTransformed(squaredTolerance, opt_transform) {
|
||||||
return this.simplifyTransformedInternal(this.getRevision(), squaredTolerance, sourceProjection, destProjection);
|
return this.simplifyTransformedInternal(this.getRevision(), squaredTolerance, opt_transform);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -9,6 +9,8 @@ import {
|
|||||||
scale as scaleTransform
|
scale as scaleTransform
|
||||||
} from './transform.js';
|
} from './transform.js';
|
||||||
import CanvasImmediateRenderer from './render/canvas/Immediate.js';
|
import CanvasImmediateRenderer from './render/canvas/Immediate.js';
|
||||||
|
import {getSquaredTolerance} from './renderer/vector.js';
|
||||||
|
import {getUserProjection, getTransformFromProjections} from './proj.js';
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -92,9 +94,15 @@ export function toContext(context, opt_options) {
|
|||||||
export function getVectorContext(event) {
|
export function getVectorContext(event) {
|
||||||
const frameState = event.frameState;
|
const frameState = event.frameState;
|
||||||
const transform = multiplyTransform(event.inversePixelTransform.slice(), frameState.coordinateToPixelTransform);
|
const transform = multiplyTransform(event.inversePixelTransform.slice(), frameState.coordinateToPixelTransform);
|
||||||
|
const squaredTolerance = getSquaredTolerance(frameState.viewState.resolution, frameState.pixelRatio);
|
||||||
|
let userTransform;
|
||||||
|
const userProjection = getUserProjection();
|
||||||
|
if (userProjection) {
|
||||||
|
userTransform = getTransformFromProjections(userProjection, frameState.viewState.projection);
|
||||||
|
}
|
||||||
return new CanvasImmediateRenderer(
|
return new CanvasImmediateRenderer(
|
||||||
event.context, frameState.pixelRatio, frameState.extent, transform,
|
event.context, frameState.pixelRatio, frameState.extent, transform,
|
||||||
frameState.viewState.rotation);
|
frameState.viewState.rotation, squaredTolerance, userTransform);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -204,11 +204,10 @@ class RenderFeature {
|
|||||||
* Get a transformed and simplified version of the geometry.
|
* Get a transformed and simplified version of the geometry.
|
||||||
* @abstract
|
* @abstract
|
||||||
* @param {number} squaredTolerance Squared tolerance.
|
* @param {number} squaredTolerance Squared tolerance.
|
||||||
* @param {import("../proj/Projection.js").default} sourceProjection The source projection.
|
* @param {import("../proj.js").TransformFunction} [opt_transform] Optional transform function.
|
||||||
* @param {import("../proj/Projection.js").default} destProjection The destination projection.
|
|
||||||
* @return {RenderFeature} Simplified geometry.
|
* @return {RenderFeature} Simplified geometry.
|
||||||
*/
|
*/
|
||||||
simplifyTransformed(squaredTolerance, sourceProjection, destProjection) {
|
simplifyTransformed(squaredTolerance, opt_transform) {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -31,8 +31,10 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @param {import("../../extent.js").Extent} extent Extent.
|
* @param {import("../../extent.js").Extent} extent Extent.
|
||||||
* @param {import("../../transform.js").Transform} transform Transform.
|
* @param {import("../../transform.js").Transform} transform Transform.
|
||||||
* @param {number} viewRotation View rotation.
|
* @param {number} viewRotation View rotation.
|
||||||
|
* @param {number=} opt_squaredTolerance Optional squared tolerance for simplification.
|
||||||
|
* @param {import("../../proj.js").TransformFunction=} opt_userTransform Transform from user to view projection.
|
||||||
*/
|
*/
|
||||||
constructor(context, pixelRatio, extent, transform, viewRotation) {
|
constructor(context, pixelRatio, extent, transform, viewRotation, opt_squaredTolerance, opt_userTransform) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -65,6 +67,18 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
*/
|
*/
|
||||||
this.viewRotation_ = viewRotation;
|
this.viewRotation_ = viewRotation;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @private
|
||||||
|
* @type {number}
|
||||||
|
*/
|
||||||
|
this.squaredTolerance_ = opt_squaredTolerance;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @private
|
||||||
|
* @type {import("../../proj.js").TransformFunction}
|
||||||
|
*/
|
||||||
|
this.userTransform_ = opt_userTransform;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @private
|
* @private
|
||||||
* @type {?import("../canvas.js").FillState}
|
* @type {?import("../canvas.js").FillState}
|
||||||
@@ -505,6 +519,9 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @override
|
* @override
|
||||||
*/
|
*/
|
||||||
drawPoint(geometry) {
|
drawPoint(geometry) {
|
||||||
|
if (this.squaredTolerance_) {
|
||||||
|
geometry = /** @type {import("../../geom/Point.js").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));
|
||||||
|
}
|
||||||
const flatCoordinates = geometry.getFlatCoordinates();
|
const flatCoordinates = geometry.getFlatCoordinates();
|
||||||
const stride = geometry.getStride();
|
const stride = geometry.getStride();
|
||||||
if (this.image_) {
|
if (this.image_) {
|
||||||
@@ -523,6 +540,9 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @override
|
* @override
|
||||||
*/
|
*/
|
||||||
drawMultiPoint(geometry) {
|
drawMultiPoint(geometry) {
|
||||||
|
if (this.squaredTolerance_) {
|
||||||
|
geometry = /** @type {import("../../geom/MultiPoint.js").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));
|
||||||
|
}
|
||||||
const flatCoordinates = geometry.getFlatCoordinates();
|
const flatCoordinates = geometry.getFlatCoordinates();
|
||||||
const stride = geometry.getStride();
|
const stride = geometry.getStride();
|
||||||
if (this.image_) {
|
if (this.image_) {
|
||||||
@@ -541,6 +561,9 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @override
|
* @override
|
||||||
*/
|
*/
|
||||||
drawLineString(geometry) {
|
drawLineString(geometry) {
|
||||||
|
if (this.squaredTolerance_) {
|
||||||
|
geometry = /** @type {import("../../geom/LineString.js").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));
|
||||||
|
}
|
||||||
if (!intersects(this.extent_, geometry.getExtent())) {
|
if (!intersects(this.extent_, geometry.getExtent())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -567,6 +590,9 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @override
|
* @override
|
||||||
*/
|
*/
|
||||||
drawMultiLineString(geometry) {
|
drawMultiLineString(geometry) {
|
||||||
|
if (this.squaredTolerance_) {
|
||||||
|
geometry = /** @type {import("../../geom/MultiLineString.js").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));
|
||||||
|
}
|
||||||
const geometryExtent = geometry.getExtent();
|
const geometryExtent = geometry.getExtent();
|
||||||
if (!intersects(this.extent_, geometryExtent)) {
|
if (!intersects(this.extent_, geometryExtent)) {
|
||||||
return;
|
return;
|
||||||
@@ -598,6 +624,9 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @override
|
* @override
|
||||||
*/
|
*/
|
||||||
drawPolygon(geometry) {
|
drawPolygon(geometry) {
|
||||||
|
if (this.squaredTolerance_) {
|
||||||
|
geometry = /** @type {import("../../geom/Polygon.js").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));
|
||||||
|
}
|
||||||
if (!intersects(this.extent_, geometry.getExtent())) {
|
if (!intersects(this.extent_, geometry.getExtent())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -632,6 +661,9 @@ class CanvasImmediateRenderer extends VectorContext {
|
|||||||
* @override
|
* @override
|
||||||
*/
|
*/
|
||||||
drawMultiPolygon(geometry) {
|
drawMultiPolygon(geometry) {
|
||||||
|
if (this.squaredTolerance_) {
|
||||||
|
geometry = /** @type {import("../../geom/MultiPolygon.js").default} */ (geometry.simplifyTransformed(this.squaredTolerance_, this.userTransform_));
|
||||||
|
}
|
||||||
if (!intersects(this.extent_, geometry.getExtent())) {
|
if (!intersects(this.extent_, geometry.getExtent())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
import {getUid} from '../../util.js';
|
import {getUid} from '../../util.js';
|
||||||
import ViewHint from '../../ViewHint.js';
|
import ViewHint from '../../ViewHint.js';
|
||||||
import {buffer, createEmpty, containsExtent, getWidth, intersects as intersectsExtent} from '../../extent.js';
|
import {buffer, createEmpty, containsExtent, getWidth, intersects as intersectsExtent} from '../../extent.js';
|
||||||
import {fromUserExtent, toUserExtent, getUserProjection} from '../../proj.js';
|
import {fromUserExtent, toUserExtent, getUserProjection, getTransformFromProjections} from '../../proj.js';
|
||||||
import CanvasBuilderGroup from '../../render/canvas/BuilderGroup.js';
|
import CanvasBuilderGroup from '../../render/canvas/BuilderGroup.js';
|
||||||
import ExecutorGroup, {replayDeclutter} from '../../render/canvas/ExecutorGroup.js';
|
import ExecutorGroup, {replayDeclutter} from '../../render/canvas/ExecutorGroup.js';
|
||||||
import CanvasLayerRenderer from './Layer.js';
|
import CanvasLayerRenderer from './Layer.js';
|
||||||
@@ -307,8 +307,10 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
pixelRatio, vectorLayer.getDeclutter());
|
pixelRatio, vectorLayer.getDeclutter());
|
||||||
|
|
||||||
const userProjection = getUserProjection();
|
const userProjection = getUserProjection();
|
||||||
|
let userTransform;
|
||||||
if (userProjection) {
|
if (userProjection) {
|
||||||
vectorSource.loadFeatures(toUserExtent(extent, projection), resolution, userProjection);
|
vectorSource.loadFeatures(toUserExtent(extent, projection), resolution, userProjection);
|
||||||
|
userTransform = getTransformFromProjections(userProjection, projection);
|
||||||
} else {
|
} else {
|
||||||
vectorSource.loadFeatures(extent, resolution, projection);
|
vectorSource.loadFeatures(extent, resolution, projection);
|
||||||
}
|
}
|
||||||
@@ -326,7 +328,7 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
styles = styleFunction(feature, resolution);
|
styles = styleFunction(feature, resolution);
|
||||||
}
|
}
|
||||||
if (styles) {
|
if (styles) {
|
||||||
const dirty = this.renderFeature(feature, squaredTolerance, styles, replayGroup, projection);
|
const dirty = this.renderFeature(feature, squaredTolerance, styles, replayGroup, userTransform);
|
||||||
this.dirty_ = this.dirty_ || dirty;
|
this.dirty_ = this.dirty_ || dirty;
|
||||||
}
|
}
|
||||||
}.bind(this);
|
}.bind(this);
|
||||||
@@ -370,10 +372,10 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
* @param {number} squaredTolerance Squared render tolerance.
|
* @param {number} squaredTolerance Squared render tolerance.
|
||||||
* @param {import("../../style/Style.js").default|Array<import("../../style/Style.js").default>} styles The style or array of styles.
|
* @param {import("../../style/Style.js").default|Array<import("../../style/Style.js").default>} styles The style or array of styles.
|
||||||
* @param {import("../../render/canvas/BuilderGroup.js").default} builderGroup Builder group.
|
* @param {import("../../render/canvas/BuilderGroup.js").default} builderGroup Builder group.
|
||||||
* @param {import("../../proj/Projection.js").default} projection The view projection.
|
* @param {import("../../proj.js").TransformFunction} opt_transform Transform from user to view projection.
|
||||||
* @return {boolean} `true` if an image is loading.
|
* @return {boolean} `true` if an image is loading.
|
||||||
*/
|
*/
|
||||||
renderFeature(feature, squaredTolerance, styles, builderGroup, projection) {
|
renderFeature(feature, squaredTolerance, styles, builderGroup, opt_transform) {
|
||||||
if (!styles) {
|
if (!styles) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -382,12 +384,12 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
for (let i = 0, ii = styles.length; i < ii; ++i) {
|
for (let i = 0, ii = styles.length; i < ii; ++i) {
|
||||||
loading = renderFeature(
|
loading = renderFeature(
|
||||||
builderGroup, feature, styles[i], squaredTolerance,
|
builderGroup, feature, styles[i], squaredTolerance,
|
||||||
this.boundHandleStyleImageChange_, projection) || loading;
|
this.boundHandleStyleImageChange_, opt_transform) || loading;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
loading = renderFeature(
|
loading = renderFeature(
|
||||||
builderGroup, feature, styles, squaredTolerance,
|
builderGroup, feature, styles, squaredTolerance,
|
||||||
this.boundHandleStyleImageChange_, projection);
|
this.boundHandleStyleImageChange_, opt_transform);
|
||||||
}
|
}
|
||||||
return loading;
|
return loading;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ import {getUid} from '../util.js';
|
|||||||
import ImageState from '../ImageState.js';
|
import ImageState from '../ImageState.js';
|
||||||
import GeometryType from '../geom/GeometryType.js';
|
import GeometryType from '../geom/GeometryType.js';
|
||||||
import BuilderType from '../render/canvas/BuilderType.js';
|
import BuilderType from '../render/canvas/BuilderType.js';
|
||||||
import {getUserProjection} from '../proj.js';
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -93,11 +92,11 @@ function renderCircleGeometry(builderGroup, geometry, style, feature) {
|
|||||||
* @param {import("../style/Style.js").default} style Style.
|
* @param {import("../style/Style.js").default} style Style.
|
||||||
* @param {number} squaredTolerance Squared tolerance.
|
* @param {number} squaredTolerance Squared tolerance.
|
||||||
* @param {function(import("../events/Event.js").default): void} listener Listener function.
|
* @param {function(import("../events/Event.js").default): void} listener Listener function.
|
||||||
* @param {import("../proj/Projection.js").default} [projection] The view projection.
|
* @param {import("../proj.js").TransformFunction} [opt_transform] Transform from user to view projection.
|
||||||
* @return {boolean} `true` if style is loading.
|
* @return {boolean} `true` if style is loading.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
export function renderFeature(replayGroup, feature, style, squaredTolerance, listener, projection) {
|
export function renderFeature(replayGroup, feature, style, squaredTolerance, listener, opt_transform) {
|
||||||
let loading = false;
|
let loading = false;
|
||||||
const imageStyle = style.getImage();
|
const imageStyle = style.getImage();
|
||||||
if (imageStyle) {
|
if (imageStyle) {
|
||||||
@@ -113,7 +112,7 @@ export function renderFeature(replayGroup, feature, style, squaredTolerance, lis
|
|||||||
loading = true;
|
loading = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
renderFeatureInternal(replayGroup, feature, style, squaredTolerance, projection);
|
renderFeatureInternal(replayGroup, feature, style, squaredTolerance, opt_transform);
|
||||||
|
|
||||||
return loading;
|
return loading;
|
||||||
}
|
}
|
||||||
@@ -124,14 +123,14 @@ export function renderFeature(replayGroup, feature, style, squaredTolerance, lis
|
|||||||
* @param {import("../Feature.js").FeatureLike} feature Feature.
|
* @param {import("../Feature.js").FeatureLike} feature Feature.
|
||||||
* @param {import("../style/Style.js").default} style Style.
|
* @param {import("../style/Style.js").default} style Style.
|
||||||
* @param {number} squaredTolerance Squared tolerance.
|
* @param {number} squaredTolerance Squared tolerance.
|
||||||
* @param {import("../proj/Projection.js").default} [projection] The view projection.
|
* @param {import("../proj.js").TransformFunction} [opt_transform] Optional transform function.
|
||||||
*/
|
*/
|
||||||
function renderFeatureInternal(replayGroup, feature, style, squaredTolerance, projection) {
|
function renderFeatureInternal(replayGroup, feature, style, squaredTolerance, opt_transform) {
|
||||||
const geometry = style.getGeometryFunction()(feature);
|
const geometry = style.getGeometryFunction()(feature);
|
||||||
if (!geometry) {
|
if (!geometry) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const simplifiedGeometry = geometry.simplifyTransformed(squaredTolerance, getUserProjection(), projection);
|
const simplifiedGeometry = geometry.simplifyTransformed(squaredTolerance, opt_transform);
|
||||||
const renderer = style.getRenderer();
|
const renderer = style.getRenderer();
|
||||||
if (renderer) {
|
if (renderer) {
|
||||||
renderGeometry(replayGroup, simplifiedGeometry, style, feature);
|
renderGeometry(replayGroup, simplifiedGeometry, style, feature);
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import Point from '../../../../src/ol/geom/Point.js';
|
import Point from '../../../../src/ol/geom/Point.js';
|
||||||
import {get as getProjection} from '../../../../src/ol/proj.js';
|
import {get as getProjection, getTransformFromProjections} from '../../../../src/ol/proj.js';
|
||||||
|
|
||||||
|
|
||||||
describe('ol.geom.Point', function() {
|
describe('ol.geom.Point', function() {
|
||||||
@@ -161,9 +161,10 @@ describe('ol.geom.Point', function() {
|
|||||||
const geom = new Point([1, 2]);
|
const geom = new Point([1, 2]);
|
||||||
const source = getProjection('EPSG:4326');
|
const source = getProjection('EPSG:4326');
|
||||||
const dest = getProjection('EPSG:3857');
|
const dest = getProjection('EPSG:3857');
|
||||||
|
const transform = getTransformFromProjections(source, dest);
|
||||||
const squaredTolerance = 0.5;
|
const squaredTolerance = 0.5;
|
||||||
const first = geom.simplifyTransformed(squaredTolerance, source, dest);
|
const first = geom.simplifyTransformed(squaredTolerance, transform);
|
||||||
const second = geom.simplifyTransformed(squaredTolerance, source, dest);
|
const second = geom.simplifyTransformed(squaredTolerance, transform);
|
||||||
expect(second).to.be(first);
|
expect(second).to.be(first);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -171,9 +172,10 @@ describe('ol.geom.Point', function() {
|
|||||||
const geom = new Point([1, 2]);
|
const geom = new Point([1, 2]);
|
||||||
const source = getProjection('EPSG:4326');
|
const source = getProjection('EPSG:4326');
|
||||||
const dest = getProjection('EPSG:3857');
|
const dest = getProjection('EPSG:3857');
|
||||||
|
const transform = getTransformFromProjections(source, dest);
|
||||||
const squaredTolerance = 0.5;
|
const squaredTolerance = 0.5;
|
||||||
const first = geom.simplifyTransformed(squaredTolerance, source, dest);
|
const first = geom.simplifyTransformed(squaredTolerance, transform);
|
||||||
const second = geom.simplifyTransformed(squaredTolerance * 2, source, dest);
|
const second = geom.simplifyTransformed(squaredTolerance * 2, transform);
|
||||||
expect(second).not.to.be(first);
|
expect(second).not.to.be(first);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -181,11 +183,12 @@ describe('ol.geom.Point', function() {
|
|||||||
const geom = new Point([1, 2]);
|
const geom = new Point([1, 2]);
|
||||||
const source = getProjection('EPSG:4326');
|
const source = getProjection('EPSG:4326');
|
||||||
const dest = getProjection('EPSG:3857');
|
const dest = getProjection('EPSG:3857');
|
||||||
|
const transform = getTransformFromProjections(source, dest);
|
||||||
const squaredTolerance = 0.5;
|
const squaredTolerance = 0.5;
|
||||||
const first = geom.simplifyTransformed(squaredTolerance, source, dest);
|
const first = geom.simplifyTransformed(squaredTolerance, transform);
|
||||||
|
|
||||||
geom.setCoordinates([3, 4]);
|
geom.setCoordinates([3, 4]);
|
||||||
const second = geom.simplifyTransformed(squaredTolerance * 2, source, dest);
|
const second = geom.simplifyTransformed(squaredTolerance * 2, transform);
|
||||||
expect(second).not.to.be(first);
|
expect(second).not.to.be(first);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ import Feature from '../../../../src/ol/Feature.js';
|
|||||||
describe('ol.renderer.vector', function() {
|
describe('ol.renderer.vector', function() {
|
||||||
describe('#renderFeature', function() {
|
describe('#renderFeature', function() {
|
||||||
let builderGroup;
|
let builderGroup;
|
||||||
let feature, iconStyle, style, squaredTolerance, listener, listenerThis;
|
let feature, iconStyle, style, squaredTolerance, listener;
|
||||||
let iconStyleLoadSpy;
|
let iconStyleLoadSpy;
|
||||||
|
|
||||||
beforeEach(function() {
|
beforeEach(function() {
|
||||||
@@ -33,7 +33,6 @@ describe('ol.renderer.vector', function() {
|
|||||||
});
|
});
|
||||||
squaredTolerance = 1;
|
squaredTolerance = 1;
|
||||||
listener = function() {};
|
listener = function() {};
|
||||||
listenerThis = {};
|
|
||||||
iconStyleLoadSpy = sinon.stub(iconStyle, 'load').callsFake(function() {
|
iconStyleLoadSpy = sinon.stub(iconStyle, 'load').callsFake(function() {
|
||||||
iconStyle.iconImage_.imageState_ = 1; // LOADING
|
iconStyle.iconImage_.imageState_ = 1; // LOADING
|
||||||
});
|
});
|
||||||
@@ -49,16 +48,14 @@ describe('ol.renderer.vector', function() {
|
|||||||
let listeners;
|
let listeners;
|
||||||
|
|
||||||
// call #1
|
// call #1
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
|
|
||||||
expect(iconStyleLoadSpy.calledOnce).to.be.ok();
|
expect(iconStyleLoadSpy.calledOnce).to.be.ok();
|
||||||
listeners = iconStyle.iconImage_.listeners_['change'];
|
listeners = iconStyle.iconImage_.listeners_['change'];
|
||||||
expect(listeners.length).to.eql(1);
|
expect(listeners.length).to.eql(1);
|
||||||
|
|
||||||
// call #2
|
// call #2
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
|
|
||||||
expect(iconStyleLoadSpy.calledOnce).to.be.ok();
|
expect(iconStyleLoadSpy.calledOnce).to.be.ok();
|
||||||
listeners = iconStyle.iconImage_.listeners_['change'];
|
listeners = iconStyle.iconImage_.listeners_['change'];
|
||||||
@@ -75,8 +72,7 @@ describe('ol.renderer.vector', function() {
|
|||||||
style.getZIndex(), 'Image');
|
style.getZIndex(), 'Image');
|
||||||
const setImageStyleSpy = sinon.spy(imageReplay, 'setImageStyle');
|
const setImageStyleSpy = sinon.spy(imageReplay, 'setImageStyle');
|
||||||
const drawPointSpy = sinon.stub(imageReplay, 'drawPoint').callsFake(VOID);
|
const drawPointSpy = sinon.stub(imageReplay, 'drawPoint').callsFake(VOID);
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
expect(setImageStyleSpy.called).to.be(false);
|
expect(setImageStyleSpy.called).to.be(false);
|
||||||
setImageStyleSpy.restore();
|
setImageStyleSpy.restore();
|
||||||
drawPointSpy.restore();
|
drawPointSpy.restore();
|
||||||
@@ -88,8 +84,7 @@ describe('ol.renderer.vector', function() {
|
|||||||
style.getZIndex(), 'Image');
|
style.getZIndex(), 'Image');
|
||||||
const setImageStyleSpy = sinon.spy(imageReplay, 'setImageStyle');
|
const setImageStyleSpy = sinon.spy(imageReplay, 'setImageStyle');
|
||||||
const drawMultiPointSpy = sinon.stub(imageReplay, 'drawMultiPoint').callsFake(VOID);
|
const drawMultiPointSpy = sinon.stub(imageReplay, 'drawMultiPoint').callsFake(VOID);
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
expect(setImageStyleSpy.called).to.be(false);
|
expect(setImageStyleSpy.called).to.be(false);
|
||||||
setImageStyleSpy.restore();
|
setImageStyleSpy.restore();
|
||||||
drawMultiPointSpy.restore();
|
drawMultiPointSpy.restore();
|
||||||
@@ -102,8 +97,7 @@ describe('ol.renderer.vector', function() {
|
|||||||
const setFillStrokeStyleSpy = sinon.spy(lineStringReplay,
|
const setFillStrokeStyleSpy = sinon.spy(lineStringReplay,
|
||||||
'setFillStrokeStyle');
|
'setFillStrokeStyle');
|
||||||
const drawLineStringSpy = sinon.stub(lineStringReplay, 'drawLineString').callsFake(VOID);
|
const drawLineStringSpy = sinon.stub(lineStringReplay, 'drawLineString').callsFake(VOID);
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
expect(setFillStrokeStyleSpy.called).to.be(true);
|
expect(setFillStrokeStyleSpy.called).to.be(true);
|
||||||
expect(drawLineStringSpy.called).to.be(true);
|
expect(drawLineStringSpy.called).to.be(true);
|
||||||
setFillStrokeStyleSpy.restore();
|
setFillStrokeStyleSpy.restore();
|
||||||
@@ -117,8 +111,7 @@ describe('ol.renderer.vector', function() {
|
|||||||
const setFillStrokeStyleSpy = sinon.spy(lineStringReplay,
|
const setFillStrokeStyleSpy = sinon.spy(lineStringReplay,
|
||||||
'setFillStrokeStyle');
|
'setFillStrokeStyle');
|
||||||
const drawMultiLineStringSpy = sinon.stub(lineStringReplay, 'drawMultiLineString').callsFake(VOID);
|
const drawMultiLineStringSpy = sinon.stub(lineStringReplay, 'drawMultiLineString').callsFake(VOID);
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
expect(setFillStrokeStyleSpy.called).to.be(true);
|
expect(setFillStrokeStyleSpy.called).to.be(true);
|
||||||
expect(drawMultiLineStringSpy.called).to.be(true);
|
expect(drawMultiLineStringSpy.called).to.be(true);
|
||||||
setFillStrokeStyleSpy.restore();
|
setFillStrokeStyleSpy.restore();
|
||||||
@@ -133,8 +126,7 @@ describe('ol.renderer.vector', function() {
|
|||||||
const setFillStrokeStyleSpy = sinon.spy(polygonReplay,
|
const setFillStrokeStyleSpy = sinon.spy(polygonReplay,
|
||||||
'setFillStrokeStyle');
|
'setFillStrokeStyle');
|
||||||
const drawPolygonSpy = sinon.stub(polygonReplay, 'drawPolygon').callsFake(VOID);
|
const drawPolygonSpy = sinon.stub(polygonReplay, 'drawPolygon').callsFake(VOID);
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
expect(setFillStrokeStyleSpy.called).to.be(true);
|
expect(setFillStrokeStyleSpy.called).to.be(true);
|
||||||
expect(drawPolygonSpy.called).to.be(true);
|
expect(drawPolygonSpy.called).to.be(true);
|
||||||
setFillStrokeStyleSpy.restore();
|
setFillStrokeStyleSpy.restore();
|
||||||
@@ -149,8 +141,7 @@ describe('ol.renderer.vector', function() {
|
|||||||
const setFillStrokeStyleSpy = sinon.spy(polygonReplay,
|
const setFillStrokeStyleSpy = sinon.spy(polygonReplay,
|
||||||
'setFillStrokeStyle');
|
'setFillStrokeStyle');
|
||||||
const drawMultiPolygonSpy = sinon.stub(polygonReplay, 'drawMultiPolygon').callsFake(VOID);
|
const drawMultiPolygonSpy = sinon.stub(polygonReplay, 'drawMultiPolygon').callsFake(VOID);
|
||||||
renderFeature(builderGroup, feature,
|
renderFeature(builderGroup, feature, style, squaredTolerance, listener);
|
||||||
style, squaredTolerance, listener, listenerThis);
|
|
||||||
expect(setFillStrokeStyleSpy.called).to.be(true);
|
expect(setFillStrokeStyleSpy.called).to.be(true);
|
||||||
expect(drawMultiPolygonSpy.called).to.be(true);
|
expect(drawMultiPolygonSpy.called).to.be(true);
|
||||||
setFillStrokeStyleSpy.restore();
|
setFillStrokeStyleSpy.restore();
|
||||||
|
|||||||
Reference in New Issue
Block a user