302 lines
8.8 KiB
JavaScript
302 lines
8.8 KiB
JavaScript
describe('Polygon', function () {
|
|
|
|
var c = document.createElement('div');
|
|
c.style.width = '400px';
|
|
c.style.height = '400px';
|
|
var map = new L.Map(c);
|
|
map.setView(new L.LatLng(55.8, 37.6), 6);
|
|
|
|
describe("#initialize", function () {
|
|
it("should never be flat", function () {
|
|
var latLngs = [[1, 2], [3, 4]];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
expect(polygon._flat(polygon._latlngs)).to.be(false);
|
|
});
|
|
|
|
it("doesn't overwrite the given latlng array", function () {
|
|
var originalLatLngs = [
|
|
[1, 2],
|
|
[3, 4]
|
|
];
|
|
var sourceLatLngs = originalLatLngs.slice();
|
|
|
|
var polygon = new L.Polygon(sourceLatLngs);
|
|
|
|
expect(sourceLatLngs).to.eql(originalLatLngs);
|
|
expect(polygon._latlngs).to.not.eql(sourceLatLngs);
|
|
});
|
|
|
|
it("can be called with an empty array", function () {
|
|
var polygon = new L.Polygon([]);
|
|
expect(polygon.getLatLngs()).to.eql([[]]);
|
|
});
|
|
|
|
it("can be initialized with holes", function () {
|
|
var originalLatLngs = [
|
|
[ //external rink
|
|
[0, 10], [10, 10], [10, 0]
|
|
], [ //hole
|
|
[2, 3], [2, 4], [3, 4]
|
|
]
|
|
];
|
|
|
|
var polygon = new L.Polygon(originalLatLngs);
|
|
|
|
// getLatLngs() returns both rings
|
|
expect(polygon.getLatLngs()).to.eql([
|
|
[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])],
|
|
[L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]
|
|
]);
|
|
});
|
|
|
|
it("can be initialized with multi including hole", function () {
|
|
var latLngs = [
|
|
[[[10, 20], [30, 40], [50, 60]]],
|
|
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
expect(polygon.getLatLngs()).to.eql([
|
|
[[L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]],
|
|
[[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])], [L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]]
|
|
]);
|
|
});
|
|
});
|
|
|
|
describe("#setLatLngs", function () {
|
|
it("doesn't overwrite the given latlng array", function () {
|
|
var originalLatLngs = [
|
|
[1, 2],
|
|
[3, 4]
|
|
];
|
|
var sourceLatLngs = originalLatLngs.slice();
|
|
|
|
var polygon = new L.Polygon(sourceLatLngs);
|
|
|
|
polygon.setLatLngs(sourceLatLngs);
|
|
|
|
expect(sourceLatLngs).to.eql(originalLatLngs);
|
|
});
|
|
|
|
it("can be set external ring and holes", function () {
|
|
var latLngs = [
|
|
[ //external rink
|
|
[0, 10], [10, 10], [10, 0]
|
|
], [ //hole
|
|
[2, 3], [2, 4], [3, 4]
|
|
]
|
|
];
|
|
|
|
var polygon = new L.Polygon([]);
|
|
polygon.setLatLngs(latLngs);
|
|
|
|
expect(polygon.getLatLngs()).to.eql([
|
|
[L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])],
|
|
[L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]
|
|
]);
|
|
});
|
|
});
|
|
|
|
describe("#spliceLatLngs", function () {
|
|
|
|
it("splices the internal latLngs", function () {
|
|
var latLngs = [
|
|
[1, 2],
|
|
[3, 4],
|
|
[5, 6]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
var removed = polygon.spliceLatLngs(1, 1, [7, 8]);
|
|
|
|
expect(polygon._latlngs).to.eql([[L.latLng([1, 2]), L.latLng([7, 8]), L.latLng([5, 6])]]);
|
|
expect(removed).to.eql([L.latLng([3, 4])]);
|
|
});
|
|
|
|
it("splices on the first shape by default on a polygon with hole", function () {
|
|
var latLngs = [
|
|
[ //external rink
|
|
[0, 10], [10, 10], [10, 0]
|
|
], [ //hole
|
|
[2, 3], [2, 4], [3, 4]
|
|
]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.spliceLatLngs(1, 1, [11, 11]);
|
|
|
|
expect(polygon._latlngs[0]).to.eql([L.latLng([0, 10]), L.latLng([11, 11]), L.latLng([10, 0])]);
|
|
expect(polygon._latlngs[1]).to.eql([L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]);
|
|
});
|
|
|
|
it("splices on the hole by reference", function () {
|
|
var latLngs = [
|
|
[ //external rink
|
|
[0, 10], [10, 10], [10, 0]
|
|
], [ //hole
|
|
[2, 3], [2, 4], [3, 4]
|
|
]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.spliceLatLngs(1, 1, [3, 3], polygon._latlngs[1]);
|
|
|
|
expect(polygon._latlngs[0]).to.eql([L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])]);
|
|
expect(polygon._latlngs[1]).to.eql([L.latLng([2, 3]), L.latLng([3, 3]), L.latLng([3, 4])]);
|
|
});
|
|
|
|
it("splices on the first shape by default on a multipolygon", function () {
|
|
var latLngs = [
|
|
[[[11, 12], [13, 14], [15, 16]]],
|
|
[[[1, 2], [3, 4], [5, 6]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.spliceLatLngs(1, 1, [11, 11]);
|
|
|
|
expect(polygon._latlngs[0][0]).to.eql([L.latLng([11, 12]), L.latLng([11, 11]), L.latLng([15, 16])]);
|
|
expect(polygon._latlngs[1][0]).to.eql([L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]);
|
|
});
|
|
|
|
it("splices by reference on a multipolygon", function () {
|
|
var latLngs = [
|
|
[[[11, 12], [13, 14], [15, 16]]],
|
|
[[[1, 2], [3, 4], [5, 6]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.spliceLatLngs(1, 1, [7, 8], polygon._latlngs[1][0]);
|
|
|
|
expect(polygon._latlngs[0][0]).to.eql([L.latLng([11, 12]), L.latLng([13, 14]), L.latLng([15, 16])]);
|
|
expect(polygon._latlngs[1][0]).to.eql([L.latLng([1, 2]), L.latLng([7, 8]), L.latLng([5, 6])]);
|
|
});
|
|
|
|
it("splices hole by reference on a multipolygon with hole", function () {
|
|
var latLngs = [
|
|
[[[10, 20], [30, 40], [50, 60]]],
|
|
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.spliceLatLngs(1, 1, [3, 3], polygon._latlngs[1][1]);
|
|
|
|
expect(polygon._latlngs[0][0]).to.eql([L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]);
|
|
expect(polygon._latlngs[1][0]).to.eql([L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])]);
|
|
expect(polygon._latlngs[1][1]).to.eql([L.latLng([2, 3]), L.latLng([3, 3]), L.latLng([3, 4])]);
|
|
});
|
|
|
|
});
|
|
|
|
describe("#addLatLng", function () {
|
|
it("should add latlng to latlngs", function () {
|
|
var latLngs = [
|
|
[1, 2],
|
|
[3, 4]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([5, 6]);
|
|
|
|
expect(polygon._latlngs).to.eql([[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]]);
|
|
});
|
|
|
|
it("should add latlng to first latlngs on a polygon with hole", function () {
|
|
var latLngs = [
|
|
[[0, 12], [13, 14], [15, 16]],
|
|
[[1, 2], [3, 4], [5, 6]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([17, 0]);
|
|
|
|
expect(polygon._latlngs[0]).to.eql([L.latLng([0, 12]), L.latLng([13, 14]), L.latLng([15, 16]), L.latLng([17, 0])]);
|
|
expect(polygon._latlngs[1]).to.eql([L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]);
|
|
});
|
|
|
|
it("should add latlng by reference on a polygon with hole", function () {
|
|
var latLngs = [
|
|
[[0, 12], [13, 14], [15, 16]],
|
|
[[1, 2], [3, 4], [5, 6]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([7, 8], polygon._latlngs[1]);
|
|
|
|
expect(polygon._latlngs[0]).to.eql([L.latLng([0, 12]), L.latLng([13, 14]), L.latLng([15, 16])]);
|
|
expect(polygon._latlngs[1]).to.eql([L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6]), L.latLng([7, 8])]);
|
|
});
|
|
|
|
it("should add latlng to first latlngs on a multi", function () {
|
|
var latLngs = [
|
|
[[[1, 2], [3, 4]]],
|
|
[[[11, 12], [13, 14], [15, 16]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([5, 6]);
|
|
|
|
expect(polygon._latlngs[0]).to.eql([[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]]);
|
|
expect(polygon._latlngs[1]).to.eql([[L.latLng([11, 12]), L.latLng([13, 14]), L.latLng([15, 16])]]);
|
|
});
|
|
|
|
it("should add latlng to latlngs by reference on a multi", function () {
|
|
var latLngs = [
|
|
[[[11, 12], [13, 14], [15, 16]]],
|
|
[[[1, 2], [3, 4]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([5, 6], polygon._latlngs[1][0]);
|
|
|
|
expect(polygon._latlngs[1]).to.eql([[L.latLng([1, 2]), L.latLng([3, 4]), L.latLng([5, 6])]]);
|
|
expect(polygon._latlngs[0]).to.eql([[L.latLng([11, 12]), L.latLng([13, 14]), L.latLng([15, 16])]]);
|
|
});
|
|
|
|
it("should add latlng on first latlngs by default on a multipolygon with hole", function () {
|
|
var latLngs = [
|
|
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]],
|
|
[[[10, 20], [30, 40], [50, 60]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([-10, -10]);
|
|
|
|
expect(polygon._latlngs[0][0]).to.eql([L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0]), L.latLng([-10, -10])]);
|
|
expect(polygon._latlngs[0][1]).to.eql([L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4])]);
|
|
expect(polygon._latlngs[1][0]).to.eql([L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]);
|
|
});
|
|
|
|
it("should add latlng by reference on a multipolygon with hole", function () {
|
|
var latLngs = [
|
|
[[[10, 20], [30, 40], [50, 60]]],
|
|
[[[0, 10], [10, 10], [10, 0]], [[2, 3], [2, 4], [3, 4]]]
|
|
];
|
|
|
|
var polygon = new L.Polygon(latLngs);
|
|
|
|
polygon.addLatLng([2, 2], polygon._latlngs[1][1]);
|
|
|
|
expect(polygon._latlngs[0][0]).to.eql([L.latLng([10, 20]), L.latLng([30, 40]), L.latLng([50, 60])]);
|
|
expect(polygon._latlngs[1][0]).to.eql([L.latLng([0, 10]), L.latLng([10, 10]), L.latLng([10, 0])]);
|
|
expect(polygon._latlngs[1][1]).to.eql([L.latLng([2, 3]), L.latLng([2, 4]), L.latLng([3, 4]), L.latLng([2, 2])]);
|
|
});
|
|
|
|
});
|
|
|
|
});
|