View / add adjust* methods to manipulate the view more easily
API changes: * (breaking) the `rotate` method is gone * the `adjustRotation`, `adjustResolution` and `adjustZoom` methods are now available and allow using an anchor. This means interactions do not have to do the anchor computation themselves and this also fix anchor computation when constraints must be applied.
This commit is contained in:
@@ -87,112 +87,4 @@ describe('ol.interaction.Interaction', function() {
|
||||
|
||||
});
|
||||
|
||||
describe('zoomByDelta()', function() {
|
||||
|
||||
it('changes view resolution', function() {
|
||||
const view = new View({
|
||||
resolution: 1,
|
||||
resolutions: [4, 2, 1, 0.5, 0.25]
|
||||
});
|
||||
|
||||
zoomByDelta(view, 1);
|
||||
expect(view.getResolution()).to.be(0.5);
|
||||
|
||||
zoomByDelta(view, -1);
|
||||
expect(view.getResolution()).to.be(1);
|
||||
|
||||
zoomByDelta(view, 2);
|
||||
expect(view.getResolution()).to.be(0.25);
|
||||
|
||||
zoomByDelta(view, -2);
|
||||
expect(view.getResolution()).to.be(1);
|
||||
});
|
||||
|
||||
it('changes view resolution and center relative to the anchor', function() {
|
||||
const view = new View({
|
||||
center: [0, 0],
|
||||
resolution: 1,
|
||||
resolutions: [4, 2, 1, 0.5, 0.25]
|
||||
});
|
||||
|
||||
zoomByDelta(view, 1, [10, 10]);
|
||||
expect(view.getCenter()).to.eql([5, 5]);
|
||||
|
||||
zoomByDelta(view, -1, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([10, 10]);
|
||||
|
||||
zoomByDelta(view, 2, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([2.5, 2.5]);
|
||||
|
||||
zoomByDelta(view, -2, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([10, 10]);
|
||||
});
|
||||
|
||||
it('changes view resolution and center relative to the anchor, while respecting the extent (center only)', function() {
|
||||
const view = new View({
|
||||
center: [0, 0],
|
||||
extent: [-2.5, -2.5, 2.5, 2.5],
|
||||
constrainOnlyCenter: true,
|
||||
resolution: 1,
|
||||
resolutions: [4, 2, 1, 0.5, 0.25]
|
||||
});
|
||||
|
||||
zoomByDelta(view, 1, [10, 10]);
|
||||
expect(view.getCenter()).to.eql([2.5, 2.5]);
|
||||
|
||||
zoomByDelta(view, -1, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([2.5, 2.5]);
|
||||
|
||||
zoomByDelta(view, 2, [10, 10]);
|
||||
expect(view.getCenter()).to.eql([2.5, 2.5]);
|
||||
|
||||
zoomByDelta(view, -2, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([2.5, 2.5]);
|
||||
});
|
||||
|
||||
it('changes view resolution and center relative to the anchor, while respecting the extent', function() {
|
||||
const map = new Map({});
|
||||
const view = new View({
|
||||
center: [50, 50],
|
||||
extent: [0, 0, 100, 100],
|
||||
resolution: 1,
|
||||
resolutions: [4, 2, 1, 0.5, 0.25, 0.125]
|
||||
});
|
||||
map.setView(view);
|
||||
|
||||
zoomByDelta(view, 1, [100, 100]);
|
||||
expect(view.getCenter()).to.eql([75, 75]);
|
||||
|
||||
zoomByDelta(view, -1, [75, 75]);
|
||||
expect(view.getCenter()).to.eql([50, 50]);
|
||||
|
||||
zoomByDelta(view, 2, [100, 100]);
|
||||
expect(view.getCenter()).to.eql([87.5, 87.5]);
|
||||
|
||||
zoomByDelta(view, -3, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([50, 50]);
|
||||
expect(view.getResolution()).to.eql(2);
|
||||
});
|
||||
|
||||
it('changes view resolution and center relative to the anchor, while respecting the extent (rotated)', function() {
|
||||
const map = new Map({});
|
||||
const view = new View({
|
||||
center: [50, 50],
|
||||
extent: [-100, -100, 100, 100],
|
||||
resolution: 1,
|
||||
resolutions: [2, 1, 0.5, 0.25, 0.125],
|
||||
rotation: Math.PI / 4
|
||||
});
|
||||
map.setView(view);
|
||||
const halfSize = 100 * Math.SQRT1_2;
|
||||
|
||||
zoomByDelta(view, 1, [100, 100]);
|
||||
expect(view.getCenter()).to.eql([100 - halfSize / 2, 100 - halfSize / 2]);
|
||||
|
||||
view.setCenter([0, 50]);
|
||||
zoomByDelta(view, -1, [0, 0]);
|
||||
expect(view.getCenter()).to.eql([0, 100 - halfSize]);
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user