3f67f411d8
Bug: skia: Change-Id: I2ffd54cf81c974f3a80103e1726a06067cc90d82 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/200044 Reviewed-by: Mike Reed <reed@google.com> Reviewed-by: Florin Malita <fmalita@chromium.org> Commit-Queue: Kevin Lubick <kjlubick@google.com>
150 lines
5.1 KiB
JavaScript
150 lines
5.1 KiB
JavaScript
describe('CanvasKit\'s Animation', function() {
|
|
|
|
const LOTTIE_ANIMATIONS = ['lego_loader', 'drinks', 'confetti', 'onboarding'];
|
|
|
|
let container = document.createElement('div');
|
|
document.body.appendChild(container);
|
|
|
|
|
|
beforeEach(function() {
|
|
container.innerHTML = `
|
|
<canvas width=600 height=600 id=test></canvas>`;
|
|
});
|
|
|
|
afterEach(function() {
|
|
container.innerHTML = '';
|
|
});
|
|
|
|
function fetchAndText(url) {
|
|
return new Promise(function(resolve, reject) {
|
|
fetch(url).then((resp) => {
|
|
resp.text().then((str) => {
|
|
expect(str).toBeTruthy();
|
|
resolve(str);
|
|
});
|
|
}).catch(reject);
|
|
});
|
|
}
|
|
|
|
LOTTIE_ANIMATIONS.forEach((animStr) => {
|
|
let promises = [fetchAndText(`/assets/${animStr}.json`), LoadCanvasKit];
|
|
|
|
it(`animation loading for ${animStr}`, function(done) {
|
|
let jsonStr = '';
|
|
function setup(ctx) {
|
|
expect(jsonStr).toBeTruthy();
|
|
}
|
|
|
|
function test(ctx) {
|
|
const animation = CanvasKit.MakeAnimation(jsonStr);
|
|
animation.delete();
|
|
}
|
|
|
|
function teardown(ctx) {}
|
|
|
|
Promise.all(promises).then((responses) => {
|
|
// The result from the first promise, that is, the JSON string
|
|
// fetched by fetchAndText
|
|
jsonStr = responses[0];
|
|
benchmarkAndReport(`${animStr}_animation_load`, setup, test, teardown).then(() => {
|
|
done();
|
|
}).catch(reportError(done));
|
|
});
|
|
});
|
|
|
|
it(`animation frames in order for ${animStr}`, function(done) {
|
|
let jsonStr = '';
|
|
function setup(ctx) {
|
|
expect(jsonStr).toBeTruthy();
|
|
ctx.animation = CanvasKit.MakeAnimation(jsonStr);
|
|
expect(ctx.animation).toBeTruthy();
|
|
ctx.timer = 0;
|
|
}
|
|
|
|
function test(ctx) {
|
|
ctx.animation.seek(ctx.timer);
|
|
ctx.timer += 0.01;
|
|
if (ctx.timer > 1.0) {
|
|
ctx.timer = 0;
|
|
}
|
|
}
|
|
|
|
function teardown(ctx) {
|
|
ctx.animation.delete();
|
|
}
|
|
|
|
Promise.all(promises).then((responses) => {
|
|
// The result from the first promise, that is, the JSON string
|
|
// fetched by fetchAndText
|
|
jsonStr = responses[0];
|
|
benchmarkAndReport(`${animStr}_animation_in_order`, setup, test, teardown).then(() => {
|
|
done();
|
|
}).catch(reportError(done));
|
|
});
|
|
});
|
|
|
|
it(`animation frames in random order for ${animStr}`, function(done) {
|
|
let jsonStr = '';
|
|
function setup(ctx) {
|
|
expect(jsonStr).toBeTruthy();
|
|
ctx.animation = CanvasKit.MakeAnimation(jsonStr);
|
|
expect(ctx.animation).toBeTruthy();
|
|
}
|
|
|
|
function test(ctx) {
|
|
ctx.animation.seek(Math.random());
|
|
}
|
|
|
|
function teardown(ctx) {
|
|
ctx.animation.delete();
|
|
}
|
|
|
|
Promise.all(promises).then((responses) => {
|
|
// The result from the first promise, that is, the JSON string
|
|
// fetched by fetchAndText
|
|
jsonStr = responses[0];
|
|
benchmarkAndReport(`${animStr}_animation_random_order`, setup, test, teardown).then(() => {
|
|
done();
|
|
}).catch(reportError(done));
|
|
});
|
|
});
|
|
|
|
it(`renders to an HTML canvas ${animStr}`, function(done) {
|
|
let jsonStr = '';
|
|
function setup(ctx) {
|
|
expect(jsonStr).toBeTruthy();
|
|
ctx.animation = CanvasKit.MakeAnimation(jsonStr);
|
|
expect(ctx.animation).toBeTruthy();
|
|
ctx.animation.seek(0.5);
|
|
ctx.surface = CanvasKit.MakeCanvasSurface('test');
|
|
ctx.canvas = ctx.surface.getCanvas();
|
|
ctx.clear = CanvasKit.Color(255, 255, 255, 0.0); // transparent
|
|
}
|
|
|
|
function test(ctx) {
|
|
// This emulates what would need to be done do accurately
|
|
// draw one frame.
|
|
ctx.canvas.clear(ctx.clear);
|
|
ctx.animation.render(ctx.canvas);
|
|
ctx.surface.flush();
|
|
}
|
|
|
|
function teardown(ctx) {
|
|
ctx.animation.delete();
|
|
ctx.surface.dispose(); // ctx.canvas will also be cleaned up
|
|
}
|
|
|
|
Promise.all(promises).then((responses) => {
|
|
// The result from the first promise, that is, the JSON string
|
|
// fetched by fetchAndText
|
|
jsonStr = responses[0];
|
|
benchmarkAndReport(`${animStr}_animation_render_flush`, setup, test, teardown).then(() => {
|
|
done();
|
|
}).catch(reportError(done));
|
|
});
|
|
});
|
|
|
|
});
|
|
|
|
});
|