mirror of
https://github.com/konvajs/konva.git
synced 2025-06-28 05:10:26 +08:00
66 lines
2.0 KiB
TypeScript
66 lines
2.0 KiB
TypeScript
import { addStage, Konva, loadImage } from '../unit/test-utils';
|
|
import { cloneAndCompareLayer } from '../unit/test-utils';
|
|
|
|
describe('Pixelate', function () {
|
|
// ======================================================
|
|
it('tween pixelate', function (done) {
|
|
var stage = addStage();
|
|
|
|
loadImage('darth-vader.jpg', (imageObj) => {
|
|
var layer = new Konva.Layer();
|
|
const lion = new Konva.Image({
|
|
x: 10,
|
|
y: 10,
|
|
image: imageObj,
|
|
draggable: true,
|
|
});
|
|
|
|
layer.add(lion);
|
|
stage.add(layer);
|
|
|
|
lion.cache();
|
|
lion.filters([Konva.Filters.Pixelate]);
|
|
lion.pixelSize(16);
|
|
layer.draw();
|
|
|
|
var tween = new Konva.Tween({
|
|
node: lion,
|
|
duration: 3.0,
|
|
pixelSize: 1,
|
|
easing: Konva.Easings.EaseInOut,
|
|
});
|
|
|
|
lion.on('mouseover', function () {
|
|
tween.play();
|
|
});
|
|
|
|
lion.on('mouseout', function () {
|
|
tween.reverse();
|
|
});
|
|
|
|
done();
|
|
});
|
|
});
|
|
|
|
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(
|
|
'',
|
|
function (image) {
|
|
layer.add(image);
|
|
|
|
image.cache();
|
|
image.filters([Konva.Filters.Pixelate]);
|
|
image.pixelSize(4);
|
|
layer.draw();
|
|
cloneAndCompareLayer(layer);
|
|
|
|
done();
|
|
}
|
|
);
|
|
});
|
|
});
|