2025-08-20 09:39:20 +12:00
|
|
|
import { addStage, Konva, loadImage } from '../unit/test-utils.ts';
|
|
|
|
import { cloneAndCompareLayer } from '../unit/test-utils.ts';
|
2021-04-30 09:24:27 -05:00
|
|
|
|
|
|
|
describe('Pixelate', function () {
|
2017-02-24 09:15:33 -05:00
|
|
|
// ======================================================
|
2021-04-30 09:24:27 -05:00
|
|
|
it('tween pixelate', function (done) {
|
2017-02-24 09:15:33 -05:00
|
|
|
var stage = addStage();
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2021-04-30 09:24:27 -05:00
|
|
|
loadImage('darth-vader.jpg', (imageObj) => {
|
2017-02-24 09:15:33 -05:00
|
|
|
var layer = new Konva.Layer();
|
2021-04-30 09:24:27 -05:00
|
|
|
const lion = new Konva.Image({
|
2017-02-24 09:15:33 -05:00
|
|
|
x: 10,
|
|
|
|
y: 10,
|
|
|
|
image: imageObj,
|
2020-05-08 09:59:35 -05:00
|
|
|
draggable: true,
|
2017-02-24 09:15:33 -05:00
|
|
|
});
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2017-02-24 09:15:33 -05:00
|
|
|
layer.add(lion);
|
|
|
|
stage.add(layer);
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2017-02-24 09:15:33 -05:00
|
|
|
lion.cache();
|
|
|
|
lion.filters([Konva.Filters.Pixelate]);
|
|
|
|
lion.pixelSize(16);
|
|
|
|
layer.draw();
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2017-02-24 09:15:33 -05:00
|
|
|
var tween = new Konva.Tween({
|
|
|
|
node: lion,
|
|
|
|
duration: 3.0,
|
|
|
|
pixelSize: 1,
|
2020-05-08 09:59:35 -05:00
|
|
|
easing: Konva.Easings.EaseInOut,
|
2017-02-24 09:15:33 -05:00
|
|
|
});
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2020-05-08 09:59:35 -05:00
|
|
|
lion.on('mouseover', function () {
|
2017-02-24 09:15:33 -05:00
|
|
|
tween.play();
|
|
|
|
});
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2020-05-08 09:59:35 -05:00
|
|
|
lion.on('mouseout', function () {
|
2017-02-24 09:15:33 -05:00
|
|
|
tween.reverse();
|
|
|
|
});
|
2013-12-01 22:37:17 -05:00
|
|
|
|
2017-02-24 09:15:33 -05:00
|
|
|
done();
|
2021-04-30 09:24:27 -05:00
|
|
|
});
|
2017-02-24 09:15:33 -05:00
|
|
|
});
|
2024-01-05 10:55:28 -05:00
|
|
|
|
|
|
|
it('make sure we have no extra transparent pixels', function (done) {
|
|
|
|
var stage = addStage();
|
|
|
|
var layer = new Konva.Layer();
|
|
|
|
stage.add(layer);
|
|
|
|
|
|
|
|
Konva.Image.fromURL(
|
|
|
|
'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGUAAABmCAYAAADS6F9hAAAAAXNSR0IArs4c6QAAAXJJREFUeF7t1cEJADAMw8B2/6Fd6BT3UCYQEiZ3205HGbhFoXp8mKJ4TYoCNilKUUQDIFM/pSigARCppRQFNAAitZSigAZApJZSFNAAiNRSigIaAJFaSlFAAyBSSykKaABEailFAQ2ASC2lKKABEKmlFAU0ACK1lKKABkCkllIU0ACI1FKKAhoAkVpKUUADIFJLKQpoAERqKUUBDYBILaUooAEQqaUUBTQAIrWUooAGQKSWUhTQAIjUUooCGgCRWkpRQAMgUkspCmgARGopRQENgEgtpSigARCppRQFNAAitZSigAZApJZSFNAAiNRSigIaAJFaSlFAAyBSSykKaABEailFAQ2ASC2lKKABEKmlFAU0ACK1lKKABkCkllIU0ACI1FKKAhoAkVpKUUADIFJLKQpoAERqKUUBDYBILaUooAEQqaUUBTQAIrWUooAGQKSWUhTQAIjUUooCGgCRWkpRQAMgUkspCmgARGopRQENgEgPgGOW3jCsp3sAAAAASUVORK5CYII=',
|
|
|
|
function (image) {
|
|
|
|
layer.add(image);
|
|
|
|
|
|
|
|
image.cache();
|
|
|
|
image.filters([Konva.Filters.Pixelate]);
|
|
|
|
image.pixelSize(4);
|
|
|
|
layer.draw();
|
|
|
|
cloneAndCompareLayer(layer);
|
|
|
|
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|
2013-11-26 17:21:53 -05:00
|
|
|
});
|