Support anchor for rotation animations
This commit is contained in:
@@ -72,7 +72,7 @@ document.getElementById('rotate-right').addEventListener('click', function() {
|
||||
document.getElementById('rotate-around-rome').addEventListener('click', function() {
|
||||
view.animate({
|
||||
rotation: view.getRotation() + 2 * Math.PI,
|
||||
rotationAnchor: rome
|
||||
anchor: rome
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
@@ -313,15 +313,13 @@ ol.View.prototype.updateAnimations_ = function() {
|
||||
this.set(ol.View.Property.RESOLUTION, resolution);
|
||||
}
|
||||
if (animation.sourceRotation !== undefined) {
|
||||
var rotationDelta = progress * (animation.targetRotation - animation.sourceRotation);
|
||||
this.set(ol.View.Property.ROTATION, animation.sourceRotation + rotationDelta);
|
||||
var rotation = animation.sourceRotation +
|
||||
progress * (animation.targetRotation - animation.sourceRotation);
|
||||
if (animation.anchor) {
|
||||
var center = this.getCenter().slice();
|
||||
ol.coordinate.sub(center, animation.anchor);
|
||||
ol.coordinate.rotate(center, rotationDelta);
|
||||
ol.coordinate.add(center, animation.anchor);
|
||||
this.set(ol.View.Property.CENTER, center);
|
||||
this.set(ol.View.Property.CENTER,
|
||||
this.calculateCenterRotate(rotation, animation.anchor));
|
||||
}
|
||||
this.set(ol.View.Property.ROTATION, rotation);
|
||||
}
|
||||
more = true;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user