Pass view rotation to replay
This commit is contained in:
@@ -159,6 +159,7 @@ ol.render.canvas.Replay.prototype.beginGeometry = function(geometry) {
|
|||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {number} pixelRatio Pixel ratio.
|
* @param {number} pixelRatio Pixel ratio.
|
||||||
* @param {goog.vec.Mat4.Number} transform Transform.
|
* @param {goog.vec.Mat4.Number} transform Transform.
|
||||||
|
* @param {number} viewRotation View rotation.
|
||||||
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
||||||
* geometry function.
|
* geometry function.
|
||||||
* @param {Array.<*>} instructions Instructions array.
|
* @param {Array.<*>} instructions Instructions array.
|
||||||
@@ -167,9 +168,9 @@ ol.render.canvas.Replay.prototype.beginGeometry = function(geometry) {
|
|||||||
* @return {T|undefined} Callback result.
|
* @return {T|undefined} Callback result.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
ol.render.canvas.Replay.prototype.replay_ =
|
ol.render.canvas.Replay.prototype.replay_ = function(
|
||||||
function(context, pixelRatio, transform, renderGeometryFunction,
|
context, pixelRatio, transform, viewRotation, renderGeometryFunction,
|
||||||
instructions, geometryCallback) {
|
instructions, geometryCallback) {
|
||||||
/** @type {Array.<number>} */
|
/** @type {Array.<number>} */
|
||||||
var pixelCoordinates;
|
var pixelCoordinates;
|
||||||
if (ol.vec.Mat4.equals2D(transform, this.renderedTransform_)) {
|
if (ol.vec.Mat4.equals2D(transform, this.renderedTransform_)) {
|
||||||
@@ -389,22 +390,24 @@ ol.render.canvas.Replay.prototype.replay_ =
|
|||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {number} pixelRatio Pixel ratio.
|
* @param {number} pixelRatio Pixel ratio.
|
||||||
* @param {goog.vec.Mat4.Number} transform Transform.
|
* @param {goog.vec.Mat4.Number} transform Transform.
|
||||||
|
* @param {number} viewRotation View rotation.
|
||||||
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
||||||
* geometry function.
|
* geometry function.
|
||||||
* @return {T|undefined} Callback result.
|
* @return {T|undefined} Callback result.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
ol.render.canvas.Replay.prototype.replay =
|
ol.render.canvas.Replay.prototype.replay = function(
|
||||||
function(context, pixelRatio, transform, renderGeometryFunction) {
|
context, pixelRatio, transform, viewRotation, renderGeometryFunction) {
|
||||||
var instructions = this.instructions;
|
var instructions = this.instructions;
|
||||||
return this.replay_(context, pixelRatio, transform, renderGeometryFunction,
|
return this.replay_(context, pixelRatio, transform, viewRotation,
|
||||||
instructions, undefined);
|
renderGeometryFunction, instructions, undefined);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {goog.vec.Mat4.Number} transform Transform.
|
* @param {goog.vec.Mat4.Number} transform Transform.
|
||||||
|
* @param {number} viewRotation View rotation.
|
||||||
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
||||||
* geometry function.
|
* geometry function.
|
||||||
* @param {function(ol.geom.Geometry, Object): T=} opt_geometryCallback
|
* @param {function(ol.geom.Geometry, Object): T=} opt_geometryCallback
|
||||||
@@ -412,11 +415,12 @@ ol.render.canvas.Replay.prototype.replay =
|
|||||||
* @return {T|undefined} Callback result.
|
* @return {T|undefined} Callback result.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
ol.render.canvas.Replay.prototype.replayHitDetection =
|
ol.render.canvas.Replay.prototype.replayHitDetection = function(
|
||||||
function(context, transform, renderGeometryFunction, opt_geometryCallback) {
|
context, transform, viewRotation, renderGeometryFunction,
|
||||||
|
opt_geometryCallback) {
|
||||||
var instructions = this.hitDetectionInstructions;
|
var instructions = this.hitDetectionInstructions;
|
||||||
return this.replay_(context, 1, transform, renderGeometryFunction,
|
return this.replay_(context, 1, transform, viewRotation,
|
||||||
instructions, opt_geometryCallback);
|
renderGeometryFunction, instructions, opt_geometryCallback);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -1683,18 +1687,19 @@ ol.render.canvas.ReplayGroup = function(tolerance) {
|
|||||||
* @param {ol.Extent} extent Extent.
|
* @param {ol.Extent} extent Extent.
|
||||||
* @param {number} pixelRatio Pixel ratio.
|
* @param {number} pixelRatio Pixel ratio.
|
||||||
* @param {goog.vec.Mat4.Number} transform Transform.
|
* @param {goog.vec.Mat4.Number} transform Transform.
|
||||||
|
* @param {number} viewRotation View rotation.
|
||||||
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
||||||
* geometry function.
|
* geometry function.
|
||||||
* @return {T|undefined} Callback result.
|
* @return {T|undefined} Callback result.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
ol.render.canvas.ReplayGroup.prototype.replay = function(context, extent,
|
ol.render.canvas.ReplayGroup.prototype.replay = function(context, extent,
|
||||||
pixelRatio, transform, renderGeometryFunction) {
|
pixelRatio, transform, viewRotation, renderGeometryFunction) {
|
||||||
/** @type {Array.<number>} */
|
/** @type {Array.<number>} */
|
||||||
var zs = goog.array.map(goog.object.getKeys(this.replaysByZIndex_), Number);
|
var zs = goog.array.map(goog.object.getKeys(this.replaysByZIndex_), Number);
|
||||||
goog.array.sort(zs);
|
goog.array.sort(zs);
|
||||||
return this.replay_(
|
return this.replay_(zs, context, extent, pixelRatio, transform,
|
||||||
zs, context, extent, pixelRatio, transform, renderGeometryFunction);
|
viewRotation, renderGeometryFunction);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -1704,6 +1709,7 @@ ol.render.canvas.ReplayGroup.prototype.replay = function(context, extent,
|
|||||||
* @param {CanvasRenderingContext2D} context Context.
|
* @param {CanvasRenderingContext2D} context Context.
|
||||||
* @param {ol.Extent} extent Extent.
|
* @param {ol.Extent} extent Extent.
|
||||||
* @param {goog.vec.Mat4.Number} transform Transform.
|
* @param {goog.vec.Mat4.Number} transform Transform.
|
||||||
|
* @param {number} viewRotation View rotation.
|
||||||
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
||||||
* geometry function.
|
* geometry function.
|
||||||
* @param {function(ol.geom.Geometry, Object): T} geometryCallback Geometry
|
* @param {function(ol.geom.Geometry, Object): T} geometryCallback Geometry
|
||||||
@@ -1711,17 +1717,17 @@ ol.render.canvas.ReplayGroup.prototype.replay = function(context, extent,
|
|||||||
* @return {T|undefined} Callback result.
|
* @return {T|undefined} Callback result.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
ol.render.canvas.ReplayGroup.prototype.replayHitDetection_ =
|
ol.render.canvas.ReplayGroup.prototype.replayHitDetection_ = function(
|
||||||
function(zs, context, extent, transform, renderGeometryFunction,
|
zs, context, extent, transform, viewRotation, renderGeometryFunction,
|
||||||
geometryCallback) {
|
geometryCallback) {
|
||||||
var i, ii, replays, replayType, replay, result;
|
var i, ii, replays, replayType, replay, result;
|
||||||
for (i = 0, ii = zs.length; i < ii; ++i) {
|
for (i = 0, ii = zs.length; i < ii; ++i) {
|
||||||
replays = this.replaysByZIndex_[zs[i].toString()];
|
replays = this.replaysByZIndex_[zs[i].toString()];
|
||||||
for (replayType in replays) {
|
for (replayType in replays) {
|
||||||
replay = replays[replayType];
|
replay = replays[replayType];
|
||||||
if (ol.extent.intersects(extent, replay.getExtent())) {
|
if (ol.extent.intersects(extent, replay.getExtent())) {
|
||||||
result = replay.replayHitDetection(
|
result = replay.replayHitDetection(context, transform, viewRotation,
|
||||||
context, transform, renderGeometryFunction, geometryCallback);
|
renderGeometryFunction, geometryCallback);
|
||||||
if (result) {
|
if (result) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -1739,14 +1745,15 @@ ol.render.canvas.ReplayGroup.prototype.replayHitDetection_ =
|
|||||||
* @param {ol.Extent} extent Extent.
|
* @param {ol.Extent} extent Extent.
|
||||||
* @param {number} pixelRatio Pixel ratio.
|
* @param {number} pixelRatio Pixel ratio.
|
||||||
* @param {goog.vec.Mat4.Number} transform Transform.
|
* @param {goog.vec.Mat4.Number} transform Transform.
|
||||||
|
* @param {number} viewRotation View rotation.
|
||||||
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
* @param {function(ol.geom.Geometry): boolean} renderGeometryFunction Render
|
||||||
* geometry function.
|
* geometry function.
|
||||||
* @return {T|undefined} Callback result.
|
* @return {T|undefined} Callback result.
|
||||||
* @template T
|
* @template T
|
||||||
*/
|
*/
|
||||||
ol.render.canvas.ReplayGroup.prototype.replay_ =
|
ol.render.canvas.ReplayGroup.prototype.replay_ = function(
|
||||||
function(zs, context, extent, pixelRatio, transform,
|
zs, context, extent, pixelRatio, transform, viewRotation,
|
||||||
renderGeometryFunction) {
|
renderGeometryFunction) {
|
||||||
var i, ii, j, jj, replays, replayType, replay, result;
|
var i, ii, j, jj, replays, replayType, replay, result;
|
||||||
for (i = 0, ii = zs.length; i < ii; ++i) {
|
for (i = 0, ii = zs.length; i < ii; ++i) {
|
||||||
replays = this.replaysByZIndex_[zs[i].toString()];
|
replays = this.replaysByZIndex_[zs[i].toString()];
|
||||||
@@ -1754,8 +1761,8 @@ ol.render.canvas.ReplayGroup.prototype.replay_ =
|
|||||||
replay = replays[ol.render.REPLAY_ORDER[j]];
|
replay = replays[ol.render.REPLAY_ORDER[j]];
|
||||||
if (goog.isDef(replay) &&
|
if (goog.isDef(replay) &&
|
||||||
ol.extent.intersects(extent, replay.getExtent())) {
|
ol.extent.intersects(extent, replay.getExtent())) {
|
||||||
result = replay.replay(
|
result = replay.replay(context, pixelRatio, transform, viewRotation,
|
||||||
context, pixelRatio, transform, renderGeometryFunction);
|
renderGeometryFunction);
|
||||||
if (result) {
|
if (result) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -1794,7 +1801,7 @@ ol.render.canvas.ReplayGroup.prototype.forEachGeometryAtPixel = function(
|
|||||||
context.clearRect(0, 0, 1, 1);
|
context.clearRect(0, 0, 1, 1);
|
||||||
|
|
||||||
return this.replayHitDetection_(zs, context, extent, transform,
|
return this.replayHitDetection_(zs, context, extent, transform,
|
||||||
renderGeometryFunction,
|
rotation, renderGeometryFunction,
|
||||||
/**
|
/**
|
||||||
* @param {ol.geom.Geometry} geometry Geometry.
|
* @param {ol.geom.Geometry} geometry Geometry.
|
||||||
* @param {Object} data Opaque data object.
|
* @param {Object} data Opaque data object.
|
||||||
|
|||||||
@@ -75,7 +75,7 @@ ol.renderer.canvas.VectorLayer.prototype.composeFrame =
|
|||||||
context.globalAlpha = layerState.opacity;
|
context.globalAlpha = layerState.opacity;
|
||||||
replayGroup.replay(
|
replayGroup.replay(
|
||||||
context, frameState.extent, frameState.pixelRatio, transform,
|
context, frameState.extent, frameState.pixelRatio, transform,
|
||||||
renderGeometryFunction);
|
frameState.view2DState.rotation, renderGeometryFunction);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.dispatchPostComposeEvent(context, frameState, transform);
|
this.dispatchPostComposeEvent(context, frameState, transform);
|
||||||
|
|||||||
@@ -139,7 +139,7 @@ ol.source.ImageVector.prototype.canvasFunctionInternal_ =
|
|||||||
|
|
||||||
var transform = this.getTransform_(ol.extent.getCenter(extent),
|
var transform = this.getTransform_(ol.extent.getCenter(extent),
|
||||||
resolution, pixelRatio, size);
|
resolution, pixelRatio, size);
|
||||||
replayGroup.replay(this.canvasContext_, extent, pixelRatio, transform,
|
replayGroup.replay(this.canvasContext_, extent, pixelRatio, transform, 0,
|
||||||
goog.functions.TRUE);
|
goog.functions.TRUE);
|
||||||
|
|
||||||
this.replayGroup_ = replayGroup;
|
this.replayGroup_ = replayGroup;
|
||||||
|
|||||||
Reference in New Issue
Block a user