describe('PathKit\'s Path Behavior', function() { // Note, don't try to print the PathKit object - it can cause Karma/Jasmine to lock up. var PathKit = null; const LoadPathKit = new Promise(function(resolve, reject) { if (PathKit) { resolve(); } else { PathKitInit({ locateFile: (file) => '/pathkit/'+file, }).then((_PathKit) => { PathKit = _PathKit; resolve(); }); } }); // see https://fiddle.skia.org/c/@discrete_path function drawStar() { let path = PathKit.NewPath(); let R = 115.2, C = 128.0; path.moveTo(C + R + 22, C); for (let i = 1; i < 8; i++) { let a = 2.6927937 * i; path.lineTo(C + R * Math.cos(a) + 22, C + R * Math.sin(a)); } path.closePath(); return path; } describe('Dash Path Effect', function() { it('performs dash in-place with start, stop, phase', function(done) { LoadPathKit.then(() => { let orig = drawStar(); let dashed = drawStar(); let notACopy = dashed.dash(10, 3, 0); let phased = drawStar().dash(10, 3, 2); expect(dashed === notACopy).toBe(true); expect(dashed.equals(phased)).toBe(false); expect(dashed.equals(orig)).toBe(false); reportPath(dashed, 'dashed_no_phase', () => { reportPath(phased, 'dashed_with_phase', done); orig.delete(); dashed.delete(); phased.delete(); }); }); }); }); describe('Trim Path Effect', function() { it('performs trim in-place with start, stop, phase', function(done) { LoadPathKit.then(() => { let orig = drawStar(); let trimmed = drawStar(); let notACopy = trimmed.trim(0.25, .8); let complement = drawStar().trim(.1, .9, true); expect(trimmed === notACopy).toBe(true); expect(trimmed.equals(complement)).toBe(false); expect(trimmed.equals(orig)).toBe(false); expect(complement.equals(orig)).toBe(false); reportPath(trimmed, 'trimmed_non_complement', () => { reportPath(complement, 'trimmed_complement', done); orig.delete(); trimmed.delete(); complement.delete(); }); }); }); }); describe('Transform Path Effect', function() { it('performs matrix transform in-place', function(done) { LoadPathKit.then(() => { let orig = drawStar(); let scaled = drawStar(); let notACopy = scaled.transform(3, 0, 0, 0, 3, 0, 0, 0, 1); let scaled2 = drawStar().transform([3, 0, 0, 0, 3, 0, 0, 0, 1]); expect(scaled === notACopy).toBe(true); expect(scaled.equals(scaled2)).toBe(true); expect(scaled.equals(orig)).toBe(false); reportPath(scaled, 'transformed_scale', () => { reportPath(scaled2, 'transformed_scale2', done); orig.delete(); scaled.delete(); scaled2.delete(); }); }); }); }); describe('Stroke Path Effect', function() { it('creates a stroked path in-place', function(done) { LoadPathKit.then(() => { let orig = drawStar(); let stroked = drawStar(); let notACopy = stroked.stroke({ width: 15, join: PathKit.StrokeJoin.BEVEL, cap: PathKit.StrokeCap.BUTT, miter_limit: 2, }); // Don't have to specify all of the fields, defaults will // be used instead. let rounded = drawStar().stroke({ width: 10, join: PathKit.StrokeJoin.ROUND, cap:PathKit.StrokeCap.SQUARE, }); expect(stroked === notACopy).toBe(true); expect(stroked.equals(rounded)).toBe(false); expect(stroked.equals(orig)).toBe(false); reportPath(stroked, 'stroke_bevel_butt', () => { reportPath(rounded, 'stroke_round_square', done); orig.delete(); stroked.delete(); rounded.delete(); }); }); }); }); });