blob: cf1e1d558e8d745c10a60e142bbce30a1299e277 [file] [log] [blame]
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(catchException(done, () => {
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(catchException(done, () => {
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(catchException(done, () => {
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(catchException(done, () => {
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();
});
}));
});
});
});