2020-04-03 19:11:42 +00:00
|
|
|
describe('Skottie behavior', () => {
|
|
|
|
let container;
|
2019-09-16 17:23:26 +00:00
|
|
|
|
2020-04-03 19:11:42 +00:00
|
|
|
beforeEach(async () => {
|
|
|
|
await LoadCanvasKit;
|
|
|
|
container = document.createElement('div');
|
2019-09-16 17:23:26 +00:00
|
|
|
container.innerHTML = `
|
|
|
|
<canvas width=600 height=600 id=test></canvas>
|
|
|
|
<canvas width=600 height=600 id=report></canvas>`;
|
2020-04-03 19:11:42 +00:00
|
|
|
document.body.appendChild(container);
|
2019-09-16 17:23:26 +00:00
|
|
|
});
|
|
|
|
|
2020-04-03 19:11:42 +00:00
|
|
|
afterEach(() => {
|
|
|
|
document.body.removeChild(container);
|
2019-09-16 17:23:26 +00:00
|
|
|
});
|
|
|
|
|
2020-09-02 19:25:45 +00:00
|
|
|
const expectArrayCloseTo = (a, b, precision) => {
|
|
|
|
precision = precision || 14 // digits of precision in base 10
|
|
|
|
expect(a.length).toEqual(b.length);
|
|
|
|
for (let i=0; i<a.length; i++) {
|
|
|
|
expect(a[i]).toBeCloseTo(b[i], precision);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-04-03 19:11:42 +00:00
|
|
|
const imgPromise = fetch('/assets/flightAnim.gif')
|
|
|
|
.then((response) => response.arrayBuffer());
|
|
|
|
const jsonPromise = fetch('/assets/animated_gif.json')
|
|
|
|
.then((response) => response.text());
|
2020-06-05 13:52:38 +00:00
|
|
|
const washPromise = fetch('/assets/map-shield.json')
|
|
|
|
.then((response) => response.text());
|
2020-04-03 19:11:42 +00:00
|
|
|
|
|
|
|
gm('skottie_animgif', (canvas, promises) => {
|
|
|
|
if (!CanvasKit.skottie || !CanvasKit.managed_skottie) {
|
|
|
|
console.warn('Skipping test because not compiled with skottie');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
const animation = CanvasKit.MakeManagedAnimation(promises[1], {
|
|
|
|
'flightAnim.gif': promises[0],
|
2019-09-16 17:23:26 +00:00
|
|
|
});
|
2020-04-03 19:11:42 +00:00
|
|
|
expect(animation).toBeTruthy();
|
2020-09-02 19:25:45 +00:00
|
|
|
const bounds = CanvasKit.LTRBRect(0, 0, 500, 500);
|
2020-04-03 19:11:42 +00:00
|
|
|
|
|
|
|
canvas.clear(CanvasKit.WHITE);
|
|
|
|
animation.render(canvas, bounds);
|
|
|
|
|
2020-09-02 19:25:45 +00:00
|
|
|
// We intentionally make the length of this array 5 and add a sentinel value
|
|
|
|
// of 999 so we can make sure the bounds are copied into this rect and a new
|
|
|
|
// one is not allocated.
|
|
|
|
const damageRect = Float32Array.of(0, 0, 0, 0, 999);
|
|
|
|
|
2020-04-03 19:11:42 +00:00
|
|
|
// There was a bug, fixed in https://skia-review.googlesource.com/c/skia/+/241757
|
|
|
|
// that seeking again and drawing again revealed.
|
2020-09-02 19:25:45 +00:00
|
|
|
animation.seek(0.5, damageRect);
|
|
|
|
expectArrayCloseTo(damageRect, Float32Array.of(0, 0, 800, 600, 999), 4);
|
|
|
|
|
2020-04-03 19:11:42 +00:00
|
|
|
canvas.clear(CanvasKit.WHITE);
|
|
|
|
animation.render(canvas, bounds);
|
|
|
|
animation.delete();
|
|
|
|
}, imgPromise, jsonPromise);
|
2020-06-05 13:52:38 +00:00
|
|
|
|
|
|
|
gm('skottie_setcolor', (canvas, promises) => {
|
|
|
|
if (!CanvasKit.skottie || !CanvasKit.managed_skottie) {
|
|
|
|
console.warn('Skipping test because not compiled with skottie');
|
|
|
|
return;
|
|
|
|
}
|
2020-09-02 19:25:45 +00:00
|
|
|
const bounds = CanvasKit.LTRBRect(0, 0, 500, 500);
|
2020-06-05 13:52:38 +00:00
|
|
|
canvas.clear(CanvasKit.WHITE);
|
|
|
|
|
|
|
|
const animation = CanvasKit.MakeManagedAnimation(promises[0]);
|
|
|
|
expect(animation).toBeTruthy();
|
2020-08-26 16:56:38 +00:00
|
|
|
animation.setColor('$Icon Fill', CanvasKit.RED);
|
2020-06-05 13:52:38 +00:00
|
|
|
animation.seek(0.5);
|
|
|
|
animation.render(canvas, bounds);
|
|
|
|
animation.delete();
|
|
|
|
}, washPromise);
|
2019-09-16 17:23:26 +00:00
|
|
|
});
|