describe('Skottie behavior', function() {
let container = document.createElement('div');
document.body.appendChild(container);
const CANVAS_WIDTH = 600;
const CANVAS_HEIGHT = 600;
beforeEach(function() {
container.innerHTML = `
`;
});
afterEach(function() {
container.innerHTML = '';
});
it('can draw one with an animated gif', function(done) {
const imgPromise = fetch('/assets/flightAnim.gif')
.then((response) => response.arrayBuffer());
const jsonPromise = fetch('/assets/animated_gif.json')
.then((response) => response.text());
Promise.all([imgPromise, jsonPromise, LoadCanvasKit]).then((values) => {
if (!CanvasKit.skottie || !CanvasKit.managed_skottie) {
console.warn('Skipping test because not compiled with skottie');
done();
return;
}
catchException(done, () => {
const imgBuffer = values[0];
expect(imgBuffer).toBeTruthy();
expect(imgBuffer.byteLength).toBeTruthy();
const jsonStr = values[1];
expect(jsonStr).toBeTruthy();
const c = document.getElementById('test');
expect(c).toBeTruthy();
let surface = CanvasKit.MakeCanvasSurface(c);
expect(surface).toBeTruthy('Could not make surface');
if (CanvasKit.gpu) {
// If we are on GPU, make sure we didn't fallback
expect(c).not.toHaveClass('ck-replaced');
}
const animation = CanvasKit.MakeManagedAnimation(jsonStr, {
'flightAnim.gif': imgBuffer,
});
expect(animation).toBeTruthy();
const bounds = {fLeft: 0, fTop: 0, fRight: 500, fBottom: 500};
const canvas = surface.getCanvas();
canvas.clear(CanvasKit.WHITE);
animation.render(canvas, bounds);
surface.flush();
// There was a bug, fixed in https://skia-review.googlesource.com/c/skia/+/241757
// that seeking again and drawing again revealed.
animation.seek(0.5);
canvas.clear(CanvasKit.WHITE);
animation.render(canvas, bounds);
surface.flush();
animation.delete();
reportSurface(surface, 'skottie_animgif', done);
})();
});
});
});