Use the inverse pixel transform in pre/post render events
This commit is contained in:
@@ -92,7 +92,7 @@ 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(invertTransform(event.pixelTransform.slice()), frameState.coordinateToPixelTransform);
|
const transform = multiplyTransform(event.inversePixelTransform.slice(), frameState.coordinateToPixelTransform);
|
||||||
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);
|
||||||
@@ -108,6 +108,6 @@ export function getVectorContext(event) {
|
|||||||
*/
|
*/
|
||||||
export function getPixelFromPixel(event, pixel) {
|
export function getPixelFromPixel(event, pixel) {
|
||||||
const result = pixel.slice(0);
|
const result = pixel.slice(0);
|
||||||
applyTransform(invertTransform(event.pixelTransform.slice()), result);
|
applyTransform(event.inversePixelTransform.slice(), result);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,22 +8,23 @@ class RenderEvent extends Event {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {import("./EventType.js").default} type Type.
|
* @param {import("./EventType.js").default} type Type.
|
||||||
* @param {import("../transform.js").Transform=} opt_pixelTransform Transform.
|
* @param {import("../transform.js").Transform=} opt_inversePixelTransform Transform for
|
||||||
|
* CSS pixels to rendered pixels.
|
||||||
* @param {import("../PluggableMap.js").FrameState=} opt_frameState Frame state.
|
* @param {import("../PluggableMap.js").FrameState=} opt_frameState Frame state.
|
||||||
* @param {?CanvasRenderingContext2D=} opt_context Context.
|
* @param {?CanvasRenderingContext2D=} opt_context Context.
|
||||||
* @param {?import("../webgl/Helper.js").default=} opt_glContext WebGL Context.
|
* @param {?import("../webgl/Helper.js").default=} opt_glContext WebGL Context.
|
||||||
*/
|
*/
|
||||||
constructor(type, opt_pixelTransform, opt_frameState, opt_context, opt_glContext) {
|
constructor(type, opt_inversePixelTransform, opt_frameState, opt_context, opt_glContext) {
|
||||||
|
|
||||||
super(type);
|
super(type);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transform from css pixels (relative to the top-left corner of the map viewport)
|
* Transform from CSS pixels (relative to the top-left corner of the map viewport)
|
||||||
* to render pixel on this event's `context`.
|
* to rendered pixels on this event's `context`.
|
||||||
* @type {import("../transform.js").Transform|undefined}
|
* @type {import("../transform.js").Transform|undefined}
|
||||||
* @api
|
* @api
|
||||||
*/
|
*/
|
||||||
this.pixelTransform = opt_pixelTransform;
|
this.inversePixelTransform = opt_inversePixelTransform;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An object representing the current render frame state.
|
* An object representing the current render frame state.
|
||||||
|
|||||||
@@ -132,46 +132,32 @@ class CanvasLayerRenderer extends LayerRenderer {
|
|||||||
* @param {import("../../render/EventType.js").default} type Event type.
|
* @param {import("../../render/EventType.js").default} type Event type.
|
||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
||||||
* @param {import("../../transform.js").Transform} pixelTransform Transform.
|
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
dispatchComposeEvent_(type, context, frameState, pixelTransform) {
|
dispatchRenderEvent_(type, context, frameState) {
|
||||||
const layer = this.getLayer();
|
const layer = this.getLayer();
|
||||||
if (layer.hasListener(type)) {
|
if (layer.hasListener(type)) {
|
||||||
const composeEvent = new RenderEvent(type, pixelTransform, frameState,
|
const event = new RenderEvent(type, this.inversePixelTransform_, frameState, context, null);
|
||||||
context, null);
|
layer.dispatchEvent(event);
|
||||||
layer.dispatchEvent(composeEvent);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
||||||
* @param {import("../../transform.js").Transform=} opt_transform Transform.
|
|
||||||
* @protected
|
* @protected
|
||||||
*/
|
*/
|
||||||
preRender(context, frameState, opt_transform) {
|
preRender(context, frameState) {
|
||||||
this.dispatchComposeEvent_(RenderEventType.PRERENDER, context, frameState, opt_transform);
|
this.dispatchRenderEvent_(RenderEventType.PRERENDER, context, frameState);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
||||||
* @param {import("../../transform.js").Transform=} opt_transform Transform.
|
|
||||||
* @protected
|
* @protected
|
||||||
*/
|
*/
|
||||||
postRender(context, frameState, opt_transform) {
|
postRender(context, frameState) {
|
||||||
this.dispatchComposeEvent_(RenderEventType.POSTRENDER, context, frameState, opt_transform);
|
this.dispatchRenderEvent_(RenderEventType.POSTRENDER, context, frameState);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {CanvasRenderingContext2D} context Context.
|
|
||||||
* @param {import("../../PluggableMap.js").FrameState} frameState Frame state.
|
|
||||||
* @param {import("../../transform.js").Transform=} opt_transform Transform.
|
|
||||||
* @protected
|
|
||||||
*/
|
|
||||||
dispatchRenderEvent(context, frameState, opt_transform) {
|
|
||||||
this.dispatchComposeEvent_(RenderEventType.RENDER, context, frameState, opt_transform);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -246,7 +246,7 @@ class CanvasTileLayerRenderer extends CanvasLayerRenderer {
|
|||||||
this.clipUnrotated(context, frameState, layerState.extent);
|
this.clipUnrotated(context, frameState, layerState.extent);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.preRender(context, frameState, pixelTransform);
|
this.preRender(context, frameState);
|
||||||
|
|
||||||
this.renderedTiles.length = 0;
|
this.renderedTiles.length = 0;
|
||||||
/** @type {Array<number>} */
|
/** @type {Array<number>} */
|
||||||
@@ -294,7 +294,7 @@ class CanvasTileLayerRenderer extends CanvasLayerRenderer {
|
|||||||
projection, extent, z, tileLayer.getPreload());
|
projection, extent, z, tileLayer.getPreload());
|
||||||
this.scheduleExpireCache(frameState, tileSource);
|
this.scheduleExpireCache(frameState, tileSource);
|
||||||
|
|
||||||
this.postRender(context, frameState, pixelTransform);
|
this.postRender(context, frameState);
|
||||||
|
|
||||||
if (layerState.extent) {
|
if (layerState.extent) {
|
||||||
context.restore();
|
context.restore();
|
||||||
|
|||||||
@@ -123,7 +123,7 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
context.clearRect(0, 0, width, height);
|
context.clearRect(0, 0, width, height);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.preRender(context, frameState, pixelTransform);
|
this.preRender(context, frameState);
|
||||||
|
|
||||||
const extent = frameState.extent;
|
const extent = frameState.extent;
|
||||||
const viewState = frameState.viewState;
|
const viewState = frameState.viewState;
|
||||||
@@ -174,15 +174,11 @@ class CanvasVectorLayerRenderer extends CanvasLayerRenderer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.getLayer().hasListener(RenderEventType.RENDER)) {
|
|
||||||
this.dispatchRenderEvent(context, frameState, pixelTransform);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (clipped) {
|
if (clipped) {
|
||||||
context.restore();
|
context.restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
this.postRender(context, frameState, pixelTransform);
|
this.postRender(context, frameState);
|
||||||
|
|
||||||
const opacity = layerState.opacity;
|
const opacity = layerState.opacity;
|
||||||
if (opacity !== canvas.style.opacity) {
|
if (opacity !== canvas.style.opacity) {
|
||||||
|
|||||||
Reference in New Issue
Block a user