polyline.test.js 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624
  1. import { Line, Point, Polyline } from '..';
  2. describe('Polyline', () => {
  3. describe('#constructor', () => {
  4. it('should create a new Polyline object', () => {
  5. const polyline = new Polyline();
  6. expect(polyline).toBeInstanceOf(Polyline);
  7. expect(Array.isArray(polyline.points)).toEqual(true);
  8. expect(polyline.points.length).toEqual(0);
  9. });
  10. it('should create a new Polyline object with empty array', () => {
  11. const polyline = new Polyline([]);
  12. expect(polyline).toBeInstanceOf(Polyline);
  13. expect(Array.isArray(polyline.points)).toEqual(true);
  14. expect(polyline.points.length).toEqual(0);
  15. });
  16. it('should create a new Polyline object with points array', () => {
  17. const polyline = new Polyline([new Point(1, 1), new Point(2, 2)]);
  18. expect(polyline).toBeInstanceOf(Polyline);
  19. expect(Array.isArray(polyline.points)).toEqual(true);
  20. expect(polyline.points.length).toEqual(2);
  21. expect(polyline.points[0].serialize()).toEqual('1 1');
  22. expect(polyline.points[1].serialize()).toEqual('2 2');
  23. });
  24. it('should create a new Polyline object with points data array', () => {
  25. const polyline = new Polyline([
  26. [1, 1],
  27. [2, 2],
  28. ]);
  29. expect(polyline).toBeInstanceOf(Polyline);
  30. expect(Array.isArray(polyline.points)).toEqual(true);
  31. expect(polyline.points.length).toEqual(2);
  32. expect(polyline.points[0].serialize()).toEqual('1 1');
  33. expect(polyline.points[1].serialize()).toEqual('2 2');
  34. });
  35. it('should create a new Polyline object with empty string', () => {
  36. const polyline = new Polyline('');
  37. expect(polyline).toBeInstanceOf(Polyline);
  38. expect(Array.isArray(polyline.points)).toEqual(true);
  39. expect(polyline.points.length).toEqual(0);
  40. });
  41. it('should create a new Polyline object with points string', () => {
  42. const polyline = new Polyline('1,1 2,2');
  43. expect(polyline).toBeInstanceOf(Polyline);
  44. expect(Array.isArray(polyline.points)).toEqual(true);
  45. expect(polyline.points.length).toEqual(2);
  46. expect(polyline.points[0].serialize()).toEqual('1 1');
  47. expect(polyline.points[1].serialize()).toEqual('2 2');
  48. });
  49. });
  50. describe('Polyline.parse()', () => {
  51. it('should create a new Polyline object from empty string', () => {
  52. const polyline = Polyline.parse('');
  53. expect(polyline).toBeInstanceOf(Polyline);
  54. expect(Array.isArray(polyline.points)).toEqual(true);
  55. expect(polyline.points.length).toEqual(0);
  56. });
  57. it('should create a new Polyline object from empty string with whitespaces', () => {
  58. const polyline = Polyline.parse(' ');
  59. expect(polyline).toBeInstanceOf(Polyline);
  60. expect(Array.isArray(polyline.points)).toEqual(true);
  61. expect(polyline.points.length).toEqual(0);
  62. });
  63. it('should create a new Polyline object from svg points string', () => {
  64. const polyline = Polyline.parse('1,1 2,2');
  65. expect(polyline).toBeInstanceOf(Polyline);
  66. expect(Array.isArray(polyline.points)).toEqual(true);
  67. expect(polyline.points.length).toEqual(2);
  68. expect(polyline.points[0].serialize()).toEqual('1 1');
  69. expect(polyline.points[1].serialize()).toEqual('2 2');
  70. });
  71. it('should create a new Polyline object from points string', () => {
  72. const polyline = Polyline.parse('1 1 2 2');
  73. expect(polyline).toBeInstanceOf(Polyline);
  74. expect(Array.isArray(polyline.points)).toEqual(true);
  75. expect(polyline.points.length).toEqual(2);
  76. expect(polyline.points[0].serialize()).toEqual('1 1');
  77. expect(polyline.points[1].serialize()).toEqual('2 2');
  78. });
  79. });
  80. describe('Polyline.isPolyline()', () => {
  81. it('should return true when the given instance is a ployline', () => {
  82. expect(Polyline.isPolyline(new Polyline())).toEqual(true);
  83. });
  84. it('should return false when the given instance is not a ployline', () => {
  85. expect(Polyline.isPolyline(null)).toEqual(false);
  86. expect(Polyline.isPolyline(new Point())).toEqual(false);
  87. });
  88. });
  89. describe('#start', () => {
  90. it('should return null when polyline do not have any points', () => {
  91. const polyline = new Polyline();
  92. expect(polyline.start).toBeNull();
  93. });
  94. it('should return the first point of the polyline', () => {
  95. var _a;
  96. const polyline = new Polyline('1,1 2,2');
  97. expect((_a = polyline.start) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('1 1');
  98. });
  99. });
  100. describe('#end', () => {
  101. it('should return null when polyline do not have any points', () => {
  102. const polyline = new Polyline();
  103. expect(polyline.end).toBeNull();
  104. });
  105. it('should return the last point of the polyline', () => {
  106. var _a;
  107. const polyline = new Polyline('1,1 2,2');
  108. expect((_a = polyline.end) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('2 2');
  109. });
  110. });
  111. describe('#scale()', () => {
  112. it('should scale the polyline', () => {
  113. const polyline1 = new Polyline();
  114. const polyline2 = new Polyline([
  115. [10, 0],
  116. [10, 10],
  117. [20, 10],
  118. [20, 0],
  119. [10, 0],
  120. ]);
  121. expect(polyline1.clone().scale(10, 10).serialize()).toEqual('');
  122. expect(polyline1.clone().scale(10, 10, new Point(10, 10)).serialize()).toEqual('');
  123. expect(polyline2.clone().scale(10, 10).serialize()).toEqual('100 0 100 100 200 100 200 0 100 0');
  124. expect(polyline2.clone().scale(10, 10, new Point(10, 10)).serialize()).toEqual('10 -90 10 10 110 10 110 -90 10 -90');
  125. });
  126. });
  127. describe('#rotate()', () => {
  128. it('should rotate the polyline', () => {
  129. const polyline1 = new Polyline();
  130. const polyline2 = new Polyline([
  131. [0, 0],
  132. [5, 5],
  133. ]);
  134. expect(polyline1.clone().rotate(90).serialize()).toEqual('');
  135. expect(polyline2.clone().rotate(90).round(3).serialize()).toEqual('0 0 5 -5');
  136. expect(polyline2.clone().rotate(90, new Point(10, 10)).round(3).serialize()).toEqual('0 20 5 15');
  137. });
  138. });
  139. describe('#translate()', () => {
  140. it('should translate the polyline', () => {
  141. const polyline1 = new Polyline();
  142. const polyline2 = new Polyline([
  143. [10, 0],
  144. [10, 10],
  145. [20, 10],
  146. [20, 0],
  147. [10, 0],
  148. ]);
  149. expect(polyline1.clone().translate(10, 10).serialize()).toEqual('');
  150. expect(polyline2.clone().translate(10, 10).serialize()).toEqual('20 10 20 20 30 20 30 10 20 10');
  151. });
  152. });
  153. describe('#bbox()', () => {
  154. it('should return an empty box when polyline do not have any points', () => {
  155. const polyline = new Polyline();
  156. const bbox = polyline.bbox();
  157. expect(bbox.serialize()).toEqual('0 0 0 0');
  158. });
  159. it('should return the tight bounding box of the polyline', () => {
  160. const polyline = new Polyline([
  161. [10, 10],
  162. [10, 40],
  163. [50, 40],
  164. [50, 10],
  165. ]);
  166. const bbox = polyline.bbox();
  167. expect(bbox.serialize()).toEqual('10 10 40 30');
  168. });
  169. });
  170. describe('#clone()', () => {
  171. it('should return the cloned ellipse', () => {
  172. const polyline1 = new Polyline([
  173. [10, 10],
  174. [10, 40],
  175. [50, 40],
  176. [50, 10],
  177. ]);
  178. const polyline2 = polyline1.clone();
  179. expect(polyline2).toBeInstanceOf(Polyline);
  180. expect(polyline1 === polyline2).toEqual(false);
  181. expect(polyline1.equals(polyline2)).toEqual(true);
  182. expect(polyline1.toString()).toEqual(polyline2.toString());
  183. });
  184. });
  185. describe('#closestPoint()', () => {
  186. it('should return a point closest to the given point', () => {
  187. var _a, _b, _c, _d, _e;
  188. const point = new Point(150, 150);
  189. const polyline1 = new Polyline('100 100');
  190. expect((_a = polyline1.closestPoint(point)) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('100 100');
  191. const polyline2 = new Polyline('100 100 100 100 100 100');
  192. expect((_b = polyline2.closestPoint(point)) === null || _b === void 0 ? void 0 : _b.serialize()).toEqual('100 100');
  193. const polyline3 = new Polyline('100 100 200 100');
  194. expect((_c = polyline3.closestPoint(point)) === null || _c === void 0 ? void 0 : _c.serialize()).toEqual('150 100');
  195. const polyline4 = new Polyline('100 100 200 200 300 100');
  196. expect((_d = polyline4.closestPoint(point)) === null || _d === void 0 ? void 0 : _d.serialize()).toEqual('150 150');
  197. const polyline5 = new Polyline('100 100 200 110 300 100');
  198. expect((_e = polyline5.closestPoint(point)) === null || _e === void 0 ? void 0 : _e.serialize()).toEqual('154.45544554455446 105.44554455445544');
  199. });
  200. });
  201. describe('#closestPointNormalizedLength()', () => {
  202. it('should return normalized length closest to a given point', () => {
  203. const point = new Point(150, 150);
  204. let polyline = new Polyline();
  205. expect(polyline.closestPointNormalizedLength(point)).toEqual(0);
  206. polyline = new Polyline([[100, 100]]);
  207. expect(polyline.closestPointNormalizedLength(point)).toEqual(0);
  208. polyline = new Polyline([
  209. [100, 100],
  210. [100, 100],
  211. [100, 100],
  212. ]);
  213. expect(polyline.closestPointNormalizedLength(point)).toEqual(0);
  214. polyline = new Polyline([
  215. [100, 100],
  216. [200, 100],
  217. ]);
  218. expect(polyline.closestPointNormalizedLength(point)).toEqual(0.5);
  219. polyline = new Polyline([
  220. [100, 100],
  221. [200, 200],
  222. [300, 100],
  223. ]);
  224. expect(polyline.closestPointNormalizedLength(point)).toEqual(0.25);
  225. polyline = new Polyline([
  226. [100, 100],
  227. [200, 110],
  228. [300, 100],
  229. ]);
  230. expect(polyline.closestPointNormalizedLength(point)).toEqual(0.2722772277227723);
  231. });
  232. });
  233. describe('#closestPointTangent()', () => {
  234. it('should return tangent at point closest to a given point', () => {
  235. const check = (points, d) => {
  236. var _a;
  237. expect((_a = new Polyline(points)
  238. .closestPointTangent([150, 150])) === null || _a === void 0 ? void 0 : _a.round(3).serialize()).toEqual(d);
  239. };
  240. check([
  241. [100, 100],
  242. [200, 100],
  243. ], '150 100 250 100');
  244. check([
  245. [100, 100],
  246. [200, 200],
  247. [300, 100],
  248. ], '150 150 250 250');
  249. check([
  250. [100, 100],
  251. [200, 110],
  252. [300, 100],
  253. ], '154.455 105.446 254.455 115.446');
  254. });
  255. });
  256. describe('#containsPoint()', () => {
  257. const polyline = new Polyline([
  258. [10, 0],
  259. [10, 30],
  260. [30, 10],
  261. [0, 10],
  262. [20, 30],
  263. [30, 20],
  264. ]);
  265. it('should return true when the point lies on the vertex', () => {
  266. expect(polyline.containsPoint([10, 0])).toEqual(true);
  267. expect(polyline.containsPoint([10, 30])).toEqual(true);
  268. expect(polyline.containsPoint([30, 10])).toEqual(true);
  269. expect(polyline.containsPoint([0, 10])).toEqual(true);
  270. expect(polyline.containsPoint([20, 30])).toEqual(true);
  271. expect(polyline.containsPoint([30, 20])).toEqual(true);
  272. });
  273. it('should return true when the point lies on the line', () => {
  274. expect(polyline.containsPoint([15, 5])).toEqual(true);
  275. });
  276. it('should return true when the point lies on the line intersection', () => {
  277. expect(polyline.containsPoint([10, 10])).toEqual(true);
  278. });
  279. it('should return true when the point lies within polyline according to even-odd rule', () => {
  280. expect(polyline.containsPoint([13, 7])).toEqual(true);
  281. });
  282. it('should return false when the point lies outside', () => {
  283. expect(polyline.containsPoint([5, 5])).toEqual(false);
  284. });
  285. it('should return false when the point is self-intersection', () => {
  286. expect(polyline.containsPoint([15, 15])).toEqual(false);
  287. });
  288. it('should return false when the polyline has zero length', () => {
  289. expect(new Polyline().containsPoint([10, 10])).toEqual(false);
  290. });
  291. });
  292. describe('#intersectsWithLine()', () => {
  293. const polyline = new Polyline([
  294. [0, 0],
  295. [0, 10],
  296. [10, 10],
  297. ]);
  298. it('should return null when the polyline do not intersect with the given line', () => {
  299. expect(polyline.intersectsWithLine(new Line([0, 20], [20, 20]))).toBeNull();
  300. });
  301. it('should return all intersections', () => {
  302. const ret = polyline.intersectsWithLine(new Line([-5, 0], [15, 20]));
  303. expect(ret.length).toEqual(2);
  304. expect(ret[0].serialize()).toEqual('0 5');
  305. expect(ret[1].serialize()).toEqual('5 10');
  306. });
  307. });
  308. describe('#isDifferentiable()', () => {
  309. it('should return true when the polyline is differentiable (can have tangents)', () => {
  310. expect(new Polyline([
  311. [100, 100],
  312. [200, 100],
  313. ]).isDifferentiable()).toEqual(true);
  314. expect(new Polyline([
  315. [100, 100],
  316. [200, 200],
  317. [300, 100],
  318. ]).isDifferentiable()).toEqual(true);
  319. });
  320. it('should return false when the polyline is undifferentiable (can have tangents)', () => {
  321. expect(new Polyline().isDifferentiable()).toEqual(false);
  322. expect(new Polyline([[100, 100]]).isDifferentiable()).toEqual(false);
  323. expect(new Polyline([
  324. [100, 100],
  325. [100, 100],
  326. [100, 100],
  327. ]).isDifferentiable()).toEqual(false);
  328. });
  329. });
  330. describe('#pointAt()', () => {
  331. it('should return null when the polyline the empty', () => {
  332. expect(new Polyline().pointAt(0.5)).toBeNull();
  333. });
  334. it('should return the only point when the polyline has only one point', () => {
  335. var _a, _b, _c, _d, _e;
  336. const polyline = new Polyline([[10, 10]]);
  337. expect((_a = polyline.pointAt(0.5)) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('10 10');
  338. expect((_b = polyline.pointAt(0)) === null || _b === void 0 ? void 0 : _b.serialize()).toEqual('10 10');
  339. expect((_c = polyline.pointAt(1)) === null || _c === void 0 ? void 0 : _c.serialize()).toEqual('10 10');
  340. expect((_d = polyline.pointAt(10)) === null || _d === void 0 ? void 0 : _d.serialize()).toEqual('10 10');
  341. expect((_e = polyline.pointAt(-1)) === null || _e === void 0 ? void 0 : _e.serialize()).toEqual('10 10');
  342. });
  343. it('should return a point at given length ratio', () => {
  344. var _a, _b, _c;
  345. const polyline = new Polyline([
  346. [10, 0],
  347. [10, 10],
  348. [20, 10],
  349. [20, 0],
  350. [40, 0],
  351. ]);
  352. expect((_a = polyline.pointAt(0.4)) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('20 10');
  353. expect((_b = polyline.pointAt(-1)) === null || _b === void 0 ? void 0 : _b.serialize()).toEqual('10 0');
  354. expect((_c = polyline.pointAt(10)) === null || _c === void 0 ? void 0 : _c.serialize()).toEqual('40 0');
  355. });
  356. });
  357. describe('#pointAtLength()', () => {
  358. it('should return null when the polyline the empty', () => {
  359. expect(new Polyline().pointAtLength(5)).toBeNull();
  360. });
  361. it('should return a point at given length', () => {
  362. var _a, _b, _c, _d;
  363. const polyline = new Polyline([
  364. [10, 0],
  365. [10, 10],
  366. [20, 10],
  367. [20, 0],
  368. [40, 0],
  369. ]);
  370. expect((_a = polyline.pointAtLength(14)) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('14 10');
  371. expect((_b = polyline.pointAtLength(1000)) === null || _b === void 0 ? void 0 : _b.serialize()).toEqual('40 0');
  372. expect((_c = polyline.pointAtLength(-14)) === null || _c === void 0 ? void 0 : _c.serialize()).toEqual('26 0');
  373. expect((_d = polyline.pointAtLength(-1000)) === null || _d === void 0 ? void 0 : _d.serialize()).toEqual('10 0');
  374. });
  375. });
  376. describe('#tangentAt()', () => {
  377. it('should return null when the polyline is empty', () => {
  378. expect(new Polyline().tangentAt(0)).toBeNull();
  379. expect(new Polyline().tangentAt(0.5)).toBeNull();
  380. expect(new Polyline().tangentAt(1)).toBeNull();
  381. expect(new Polyline().tangentAt(100)).toBeNull();
  382. });
  383. it('should return null when the polyline has only one point', () => {
  384. expect(new Polyline([[10, 10]]).tangentAt(0)).toBeNull();
  385. expect(new Polyline([[10, 10]]).tangentAt(0.5)).toBeNull();
  386. expect(new Polyline([[10, 10]]).tangentAt(1)).toBeNull();
  387. expect(new Polyline([[10, 10]]).tangentAt(100)).toBeNull();
  388. });
  389. it('should return line tangent to point at given length ratio', () => {
  390. var _a, _b, _c, _d;
  391. const polyline = new Polyline([
  392. [10, 0],
  393. [10, 10],
  394. [20, 10],
  395. [20, 0],
  396. [10, 0],
  397. ]);
  398. expect((_a = polyline.tangentAt(0.4)) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('16 10 26 10');
  399. expect((_b = polyline.tangentAt(0.5)) === null || _b === void 0 ? void 0 : _b.serialize()).toEqual('20 10 30 10');
  400. expect((_c = polyline.tangentAt(-1)) === null || _c === void 0 ? void 0 : _c.serialize()).toEqual('10 0 10 10');
  401. expect((_d = polyline.tangentAt(10)) === null || _d === void 0 ? void 0 : _d.serialize()).toEqual('10 0 0 0');
  402. });
  403. });
  404. describe('#tangentAtLength()', () => {
  405. it('should return null when the polyline is empty', () => {
  406. expect(new Polyline().tangentAtLength(5)).toBeNull();
  407. expect(new Polyline().tangentAtLength(-5)).toBeNull();
  408. });
  409. it('should return null when the polyline has only one point', () => {
  410. expect(new Polyline([[10, 10]]).tangentAtLength(5)).toBeNull();
  411. expect(new Polyline([[10, 10]]).tangentAtLength(-5)).toBeNull();
  412. });
  413. it('should return null when the polyline is undifferentiable', () => {
  414. expect(new Polyline([
  415. [100, 100],
  416. [100, 100],
  417. ]).tangentAtLength(100)).toBeNull();
  418. });
  419. it('should return line tangent to point at given length', () => {
  420. var _a, _b, _c, _d, _e, _f;
  421. const polyline = new Polyline([
  422. [10, 0],
  423. [10, 10],
  424. [20, 10],
  425. [20, 0],
  426. [10, 0],
  427. ]);
  428. expect((_a = polyline.tangentAtLength(14)) === null || _a === void 0 ? void 0 : _a.serialize()).toEqual('14 10 24 10');
  429. expect((_b = polyline.tangentAtLength(20)) === null || _b === void 0 ? void 0 : _b.serialize()).toEqual('20 10 30 10');
  430. expect((_c = polyline.tangentAtLength(1000)) === null || _c === void 0 ? void 0 : _c.serialize()).toEqual('10 0 0 0');
  431. expect((_d = polyline.tangentAtLength(-14)) === null || _d === void 0 ? void 0 : _d.serialize()).toEqual('20 4 20 -6');
  432. expect((_e = polyline.tangentAtLength(-20)) === null || _e === void 0 ? void 0 : _e.serialize()).toEqual('20 10 20 0');
  433. expect((_f = polyline.tangentAtLength(-1000)) === null || _f === void 0 ? void 0 : _f.serialize()).toEqual('10 0 10 10');
  434. });
  435. });
  436. describe('#simplify()', () => {
  437. const check = (points, d, threshold) => {
  438. expect(new Polyline(points).simplify({ threshold }).serialize()).toEqual(d);
  439. };
  440. it('should simplify the polyline', () => {
  441. check([
  442. [10, 0],
  443. [10, 0],
  444. [10, 10],
  445. [20, 10],
  446. [20, 10],
  447. ], '10 0 10 10 20 10');
  448. check([
  449. [10, 0],
  450. [10, 0],
  451. [10, 0],
  452. ], '10 0 10 0');
  453. check([[10, 0]], '10 0');
  454. check([], '');
  455. });
  456. it('should simplify the polyline with precision', () => {
  457. check([
  458. [10, 0],
  459. [10.1, 0],
  460. [10, 10],
  461. [9.9, 10],
  462. [20, 10.1],
  463. [20, 10],
  464. ], '10 0 9.9 10 20 10', 0.1);
  465. check([
  466. [10, 0],
  467. [10.1, 0],
  468. [10, 0],
  469. ], '10 0 10 0', 0.1);
  470. check([[10, 0]], '10 0', 0.1);
  471. check([], '', 0.1);
  472. });
  473. });
  474. describe('#toHull()', () => {
  475. it('should return a convex hull', () => {
  476. expect(new Polyline().toHull().serialize()).toEqual('');
  477. expect(new Polyline('100 100').toHull().serialize()).toEqual('100 100');
  478. expect(new Polyline('100 100 200 100').toHull().serialize()).toEqual('100 100 200 100');
  479. expect(new Polyline('100 100 200 100 300 100').toHull().serialize()).toEqual('100 100 300 100');
  480. expect(new Polyline('200 100 100 100 300 100').toHull().serialize()).toEqual('100 100 300 100');
  481. expect(new Polyline('100 100 200 100 300 100 400 100').toHull().serialize()).toEqual('100 100 400 100');
  482. expect(new Polyline('200 100 100 100 300 100 400 100').toHull().serialize()).toEqual('100 100 400 100');
  483. expect(new Polyline('100 100 100 500').toHull().serialize()).toEqual('100 100 100 500');
  484. expect(new Polyline('100 100 100 500 500 500').toHull().serialize()).toEqual('100 100 500 500 100 500');
  485. expect(new Polyline('100 100 100 500 300 300 500 500 500 100')
  486. .toHull()
  487. .serialize()).toEqual('100 100 500 100 500 500 100 500');
  488. expect(new Polyline('100 100 200 100 300 200 300 200 300 300')
  489. .toHull()
  490. .serialize()).toEqual('100 100 200 100 300 200 300 300');
  491. expect(new Polyline('300 200 300 200 300 300 100 100 200 100')
  492. .toHull()
  493. .serialize()).toEqual('300 200 300 300 100 100 200 100');
  494. expect(new Polyline([
  495. [480, 80],
  496. [520, 80],
  497. [520, 120],
  498. [480, 120],
  499. [380, 80],
  500. [420, 80],
  501. [420, 120],
  502. [380, 120],
  503. [280, 80],
  504. [320, 80],
  505. [320, 120],
  506. [280, 120],
  507. [180, 80],
  508. [220, 80],
  509. [220, 120],
  510. [180, 120],
  511. [80, 80],
  512. [120, 80],
  513. [120, 120],
  514. [80, 120],
  515. ])
  516. .toHull()
  517. .serialize()).toEqual('520 80 520 120 80 120 80 80');
  518. expect(new Polyline([
  519. new Point(180, 80),
  520. new Point(220, 80),
  521. new Point(220, 120),
  522. new Point(180, 120),
  523. new Point(180, 280),
  524. new Point(220, 280),
  525. new Point(220, 320),
  526. new Point(180, 320),
  527. new Point(180, 380),
  528. new Point(220, 380),
  529. new Point(220, 420),
  530. new Point(180, 420),
  531. new Point(180, 180),
  532. new Point(220, 180),
  533. new Point(220, 220),
  534. new Point(180, 220),
  535. new Point(80, 380),
  536. new Point(120, 380),
  537. new Point(120, 420),
  538. new Point(80, 420),
  539. ])
  540. .toHull()
  541. .serialize()).toEqual('180 80 220 80 220 420 80 420 80 380');
  542. expect(new Polyline([
  543. new Point(80, 80),
  544. new Point(120, 80),
  545. new Point(120, 120),
  546. new Point(80, 120),
  547. new Point(180, 80),
  548. new Point(220, 80),
  549. new Point(220, 120),
  550. new Point(180, 120),
  551. new Point(180, 280),
  552. new Point(220, 280),
  553. new Point(220, 320),
  554. new Point(180, 320),
  555. new Point(180, 380),
  556. new Point(220, 380),
  557. new Point(220, 420),
  558. new Point(180, 420),
  559. new Point(180, 180),
  560. new Point(220, 180),
  561. new Point(220, 220),
  562. new Point(180, 220),
  563. new Point(80, 380),
  564. new Point(120, 380),
  565. new Point(120, 420),
  566. new Point(80, 420),
  567. ])
  568. .toHull()
  569. .serialize()).toEqual('80 80 220 80 220 420 80 420');
  570. expect(new Polyline([
  571. new Point(280, 280),
  572. new Point(320, 280),
  573. new Point(320, 320),
  574. new Point(280, 320),
  575. new Point(180, 280),
  576. new Point(220, 280),
  577. new Point(220, 320),
  578. new Point(180, 320),
  579. new Point(80, 180),
  580. new Point(120, 180),
  581. new Point(120, 220),
  582. new Point(80, 220),
  583. new Point(180, 80),
  584. new Point(220, 80),
  585. new Point(220, 120),
  586. new Point(180, 120),
  587. new Point(280, 80),
  588. new Point(320, 80),
  589. new Point(320, 120),
  590. new Point(280, 120),
  591. new Point(80, 80),
  592. new Point(120, 80),
  593. new Point(120, 120),
  594. new Point(80, 120),
  595. new Point(380, 80),
  596. new Point(420, 80),
  597. new Point(420, 120),
  598. new Point(380, 120),
  599. ])
  600. .toHull()
  601. .serialize()).toEqual('320 320 180 320 80 220 80 80 420 80 420 120');
  602. });
  603. });
  604. describe('#equals()', () => {
  605. it('should return true when the two polyline are the same', () => {
  606. expect(new Polyline([
  607. [1, 1],
  608. [2, 2],
  609. ]).equals(new Polyline('1 1 2 2'))).toEqual(true);
  610. expect(new Polyline().equals(new Polyline())).toEqual(true);
  611. expect(new Polyline([]).equals(new Polyline(''))).toEqual(true);
  612. });
  613. it('should return false when the given polyline is null ', () => {
  614. expect(new Polyline().equals(null)).toEqual(false);
  615. });
  616. it('should return false when the given polyline do not have the same points count', () => {
  617. expect(new Polyline([
  618. [1, 1],
  619. [2, 2],
  620. ]).equals(new Polyline())).toEqual(false);
  621. });
  622. });
  623. });
  624. //# sourceMappingURL=polyline.test.js.map