synced with upstream

This commit is contained in:
eugenesqr
2018-02-09 15:36:01 +03:00
5 changed files with 963 additions and 314 deletions

View File

@@ -1,187 +1,195 @@
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<title>KonvaJS Mocha Tests</title>
<link rel="stylesheet" href="../node_modules/mocha/mocha.css" />
<style>
#mocha {
margin-top: 20px;
}
#mocha .test {
overflow: auto;
}
h1 {
font-family: Calibri;
margin-left: 10px;
}
h2.konva-title {
font-family: Calibri;
font-size: 16px;
color: #555;
border-top: 2px solid #999;
padding-left: 10px;
}
</style>
</head>
<body>
<h1>KonvaJS Test</h1>
<div id="mocha"></div>
<div id="konva-container"></div>
<script src="../node_modules/mocha/mocha.js"></script>
<script src="../node_modules/chai/chai.js"></script>
<script src="lib/stats.js"></script>
<head>
<meta charset="utf-8">
<title>KonvaJS Mocha Tests</title>
<link rel="stylesheet" href="../node_modules/mocha/mocha.css" />
<style>
#mocha {
margin-top: 20px;
}
<!--<script src="lib/blanket.js"></script>-->
#mocha .test {
overflow: auto;
}
<!--CORE-->
<script src="../src/Global.js" data-cover></script>
<script src="../src/Util.js" data-cover></script>
<script src="../src/Canvas.js" data-cover></script>
<script src="../src/Context.js" data-cover></script>
<script src="../src/Factory.js" data-cover></script>
<script src="../src/Node.js" data-cover></script>
h1 {
font-family: Calibri;
margin-left: 10px;
}
<!--FILTERS-->
<script src="../src/filters/Grayscale.js" data-cover></script>
<script src="../src/filters/Brighten.js" data-cover></script>
<script src="../src/filters/Invert.js" data-cover></script>
<script src="../src/filters/Blur.js" data-cover></script>
<script src="../src/filters/Mask.js" data-cover></script>
<script src="../src/filters/RGB.js" data-cover></script>
<script src="../src/filters/RGBA.js" data-cover></script>
<script src="../src/filters/HSV.js" data-cover></script>
<script src="../src/filters/HSL.js" data-cover></script>
<script src="../src/filters/Emboss.js" data-cover></script>
<script src="../src/filters/Enhance.js" data-cover></script>
<script src="../src/filters/Posterize.js" data-cover></script>
<script src="../src/filters/Noise.js" data-cover></script>
<script src="../src/filters/Pixelate.js" data-cover></script>
<script src="../src/filters/Threshold.js" data-cover></script>
<script src="../src/filters/Sepia.js" data-cover></script>
<script src="../src/filters/Contrast.js" data-cover></script>
<script src="../src/filters/Solarize.js" data-cover></script>
<script src="../src/filters/Kaleidoscope.js" data-cover></script>
h2.konva-title {
font-family: Calibri;
font-size: 16px;
color: #555;
border-top: 2px solid #999;
padding-left: 10px;
}
</style>
</head>
<!--MAIN ELEMENTS-->
<body>
<h1>KonvaJS Test</h1>
<div id="mocha"></div>
<div id="konva-container"></div>
<script src="../src/Container.js" data-cover></script>
<script src="../src/Shape.js" data-cover></script>
<script src="../src/Stage.js" data-cover></script>
<script src="../src/BaseLayer.js" data-cover></script>
<script src="../src/Layer.js" data-cover></script>
<script src="../src/FastLayer.js" data-cover></script>
<script src="../src/Group.js" data-cover></script>
<script src="../src/Animation.js" data-cover></script>
<script src="../src/Tween.js" data-cover></script>
<script src="../src/DragAndDrop.js" data-cover></script>
<script src="../node_modules/mocha/mocha.js"></script>
<script src="../node_modules/chai/chai.js"></script>
<script src="lib/stats.js"></script>
<!--SHAPES-->
<script src="../src/shapes/Rect.js" data-cover></script>
<script src="../src/shapes/Circle.js" data-cover></script>
<script src="../src/shapes/Ellipse.js" data-cover></script>
<script src="../src/shapes/Ring.js" data-cover></script>
<script src="../src/shapes/Wedge.js" data-cover></script>
<script src="../src/shapes/Arc.js" data-cover></script>
<script src="../src/shapes/Image.js" data-cover></script>
<script src="../src/shapes/Text.js" data-cover></script>
<script src="../src/shapes/Line.js" data-cover></script>
<script src="../src/shapes/Sprite.js" data-cover></script>
<script src="../src/shapes/Path.js" data-cover></script>
<script src="../src/shapes/TextPath.js" data-cover></script>
<script src="../src/shapes/RegularPolygon.js" data-cover></script>
<script src="../src/shapes/Star.js" data-cover></script>
<script src="../src/shapes/Label.js" data-cover></script>
<script src="../src/shapes/Arrow.js" data-cover></script>
<!--<script src="lib/blanket.js"></script>-->
<!--<script src="../dist/konva-dev.js"></script>-->
<!--CORE-->
<script src="../src/Global.js" data-cover></script>
<script src="../src/Util.js" data-cover></script>
<script src="../src/Canvas.js" data-cover></script>
<script src="../src/Context.js" data-cover></script>
<script src="../src/Factory.js" data-cover></script>
<script src="../src/Node.js" data-cover></script>
<script src="lib/imagediff.js"></script>
<script src="runner.js"></script>
<!--FILTERS-->
<script src="../src/filters/Grayscale.js" data-cover></script>
<script src="../src/filters/Brighten.js" data-cover></script>
<script src="../src/filters/Invert.js" data-cover></script>
<script src="../src/filters/Blur.js" data-cover></script>
<script src="../src/filters/Mask.js" data-cover></script>
<script src="../src/filters/RGB.js" data-cover></script>
<script src="../src/filters/RGBA.js" data-cover></script>
<script src="../src/filters/HSV.js" data-cover></script>
<script src="../src/filters/HSL.js" data-cover></script>
<script src="../src/filters/Emboss.js" data-cover></script>
<script src="../src/filters/Enhance.js" data-cover></script>
<script src="../src/filters/Posterize.js" data-cover></script>
<script src="../src/filters/Noise.js" data-cover></script>
<script src="../src/filters/Pixelate.js" data-cover></script>
<script src="../src/filters/Threshold.js" data-cover></script>
<script src="../src/filters/Sepia.js" data-cover></script>
<script src="../src/filters/Contrast.js" data-cover></script>
<script src="../src/filters/Solarize.js" data-cover></script>
<script src="../src/filters/Kaleidoscope.js" data-cover></script>
<!-- assets -->
<script src="assets/tiger.js"></script>
<script src="assets/worldMap.js"></script>
<!--MAIN ELEMENTS-->
<!--=============== unit tests ================-->
<script src="../src/Container.js" data-cover></script>
<script src="../src/Shape.js" data-cover></script>
<script src="../src/Stage.js" data-cover></script>
<script src="../src/BaseLayer.js" data-cover></script>
<script src="../src/Layer.js" data-cover></script>
<script src="../src/FastLayer.js" data-cover></script>
<script src="../src/Group.js" data-cover></script>
<script src="../src/Animation.js" data-cover></script>
<script src="../src/Tween.js" data-cover></script>
<script src="../src/DragAndDrop.js" data-cover></script>
<!-- core -->
<script src="unit/Global-test.js"></script>
<script src="unit/Util-test.js"></script>
<script src="unit/Canvas-test.js"></script>
<script src="unit/Context-test.js"></script>
<script src="unit/Node-test.js"></script>
<script src="unit/Node-cache-test.js"></script>
<script src="unit/Container-test.js"></script>
<script src="unit/Stage-test.js"></script>
<script src="unit/BaseLayer-test.js"></script>
<script src="unit/Layer-test.js"></script>
<script src="unit/Group-test.js"></script>
<script src="unit/FastLayer-test.js"></script>
<script src="unit/Shape-test.js"></script>
<script src="unit/Collection-test.js"></script>
<!--SHAPES-->
<script src="../src/shapes/Rect.js" data-cover></script>
<script src="../src/shapes/Circle.js" data-cover></script>
<script src="../src/shapes/Ellipse.js" data-cover></script>
<script src="../src/shapes/Ring.js" data-cover></script>
<script src="../src/shapes/Wedge.js" data-cover></script>
<script src="../src/shapes/Arc.js" data-cover></script>
<script src="../src/shapes/Image.js" data-cover></script>
<script src="../src/shapes/Text.js" data-cover></script>
<script src="../src/shapes/Line.js" data-cover></script>
<script src="../src/shapes/Sprite.js" data-cover></script>
<script src="../src/shapes/Path.js" data-cover></script>
<script src="../src/shapes/TextPath.js" data-cover></script>
<script src="../src/shapes/RegularPolygon.js" data-cover></script>
<script src="../src/shapes/Star.js" data-cover></script>
<script src="../src/shapes/Label.js" data-cover></script>
<script src="../src/shapes/Arrow.js" data-cover></script>
<script src="../src/shapes/Transformer.js" data-cover></script>
<!-- shapes -->
<script src="unit/shapes/Rect-test.js"></script>
<script src="unit/shapes/Circle-test.js"></script>
<script src="unit/shapes/Image-test.js"></script>
<script src="unit/shapes/Line-test.js"></script>
<script src="unit/shapes/Text-test.js"></script>
<script src="unit/shapes/Blob-test.js"></script>
<script src="unit/shapes/Ellipse-test.js"></script>
<script src="unit/shapes/Polygon-test.js"></script>
<script src="unit/shapes/Spline-test.js"></script>
<script src="unit/shapes/Sprite-test.js"></script>
<script src="unit/shapes/Wedge-test.js"></script>
<script src="unit/shapes/Arc-test.js"></script>
<script src="unit/shapes/Ring-test.js"></script>
<script src="unit/shapes/Label-test.js"></script>
<script src="unit/shapes/Star-test.js"></script>
<script src="unit/shapes/RegularPolygon-test.js"></script>
<script src="unit/shapes/Path-test.js"></script>
<script src="unit/shapes/TextPath-test.js"></script>
<script src="unit/shapes/Arrow-test.js"></script>
<!--<script src="../dist/konva-dev.js"></script>-->
<!-- extensions -->
<script src="unit/Animation-test.js"></script>
<script src="unit/DragAndDrop-test.js"></script>
<script src="unit/Tween-test.js"></script>
<script src="lib/imagediff.js"></script>
<script src="runner.js"></script>
<!-- assets -->
<script src="assets/tiger.js"></script>
<script src="assets/worldMap.js"></script>
<!--=============== unit tests ================-->
<!-- core -->
<script src="unit/Global-test.js"></script>
<script src="unit/Util-test.js"></script>
<script src="unit/Canvas-test.js"></script>
<script src="unit/Context-test.js"></script>
<script src="unit/Node-test.js"></script>
<script src="unit/Node-cache-test.js"></script>
<script src="unit/Container-test.js"></script>
<script src="unit/Stage-test.js"></script>
<script src="unit/BaseLayer-test.js"></script>
<script src="unit/Layer-test.js"></script>
<script src="unit/Group-test.js"></script>
<script src="unit/FastLayer-test.js"></script>
<script src="unit/Shape-test.js"></script>
<script src="unit/Collection-test.js"></script>
<!-- shapes -->
<script src="unit/shapes/Rect-test.js"></script>
<script src="unit/shapes/Circle-test.js"></script>
<script src="unit/shapes/Image-test.js"></script>
<script src="unit/shapes/Line-test.js"></script>
<script src="unit/shapes/Text-test.js"></script>
<script src="unit/shapes/Blob-test.js"></script>
<script src="unit/shapes/Ellipse-test.js"></script>
<script src="unit/shapes/Polygon-test.js"></script>
<script src="unit/shapes/Spline-test.js"></script>
<script src="unit/shapes/Sprite-test.js"></script>
<script src="unit/shapes/Wedge-test.js"></script>
<script src="unit/shapes/Arc-test.js"></script>
<script src="unit/shapes/Ring-test.js"></script>
<script src="unit/shapes/Label-test.js"></script>
<script src="unit/shapes/Star-test.js"></script>
<script src="unit/shapes/RegularPolygon-test.js"></script>
<script src="unit/shapes/Path-test.js"></script>
<script src="unit/shapes/TextPath-test.js"></script>
<script src="unit/shapes/Arrow-test.js"></script>
<script src="unit/shapes/Transformer-test.js"></script>
<!-- extensions -->
<script src="unit/Animation-test.js"></script>
<script src="unit/DragAndDrop-test.js"></script>
<script src="unit/Tween-test.js"></script>
<!-- filters -->
<script src="unit/filters/Filter-test.js"></script>
<script src="unit/filters/Blur-test.js"></script>
<script src="unit/filters/Brighten-test.js"></script>
<script src="unit/filters/RGB-test.js"></script>
<script src="unit/filters/RGBA-test.js"></script>
<script src="unit/filters/HSV-test.js"></script>
<script src="unit/filters/HSL-test.js"></script>
<script src="unit/filters/Invert-test.js"></script>
<script src="unit/filters/Mask-test.js"></script>
<script src="unit/filters/Grayscale-test.js"></script>
<script src="unit/filters/Enhance-test.js"></script>
<script src="unit/filters/Pixelate-test.js"></script>
<script src="unit/filters/Noise-test.js"></script>
<script src="unit/filters/Threshold-test.js"></script>
<script src="unit/filters/Posterize-test.js"></script>
<script src="unit/filters/Sepia-test.js"></script>
<script src="unit/filters/Contrast-test.js"></script>
<script src="unit/filters/Emboss-test.js"></script>
<script src="unit/filters/Solarize-test.js"></script>
<script src="unit/filters/Kaleidoscope-test.js"></script>
<!-- filters -->
<script src="unit/filters/Filter-test.js"></script>
<script src="unit/filters/Blur-test.js"></script>
<script src="unit/filters/Brighten-test.js"></script>
<script src="unit/filters/RGB-test.js"></script>
<script src="unit/filters/RGBA-test.js"></script>
<script src="unit/filters/HSV-test.js"></script>
<script src="unit/filters/HSL-test.js"></script>
<script src="unit/filters/Invert-test.js"></script>
<script src="unit/filters/Mask-test.js"></script>
<script src="unit/filters/Grayscale-test.js"></script>
<script src="unit/filters/Enhance-test.js"></script>
<script src="unit/filters/Pixelate-test.js"></script>
<script src="unit/filters/Noise-test.js"></script>
<script src="unit/filters/Threshold-test.js"></script>
<script src="unit/filters/Posterize-test.js"></script>
<script src="unit/filters/Sepia-test.js"></script>
<script src="unit/filters/Contrast-test.js"></script>
<script src="unit/filters/Emboss-test.js"></script>
<script src="unit/filters/Solarize-test.js"></script>
<script src="unit/filters/Kaleidoscope-test.js"></script>
<!--=============== functional tests ================-->
<!--=============== functional tests ================-->
<script src="functional/MouseEvents-test.js"></script>
<script src="functional/TouchEvents-test.js"></script>
<script src="functional/DragAndDropEvents-test.js"></script>
<script src="functional/MouseEvents-test.js"></script>
<script src="functional/TouchEvents-test.js"></script>
<script src="functional/DragAndDropEvents-test.js"></script>
<!--=============== manual tests ================-->
<script src="manual/manual-test.js"></script>
<!--=============== manual tests ================-->
<script src="manual/manual-test.js"></script>
<script>
if (window.mochaPhantomJS) { mochaPhantomJS.run(); }
else { mocha.run(); }
</script>
</body>
</html>
<script>
if (window.mochaPhantomJS) { mochaPhantomJS.run(); }
else { mocha.run(); }
</script>
</body>
</html>

View File

@@ -0,0 +1,599 @@
suite('Transformer', function() {
// ======================================================
test('init transformer on simple rectangle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
x: 100,
y: 60,
draggable: true,
width: 100,
height: 100,
fill: 'yellow'
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
layer.draw();
assert.equal(tr.getClassName(), 'Transformer');
assert.equal(tr.x(), rect.x());
assert.equal(tr.y(), rect.y());
assert.equal(tr.width(), rect.width());
assert.equal(tr.height(), rect.height());
});
test('try to fit simple rectangle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
x: 100,
y: 60,
draggable: true,
width: 100,
height: 100,
fill: 'yellow'
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
layer.draw();
tr._fitNodeInto({
x: 120,
y: 60,
width: 50,
height: 50,
rotation: 45
});
assert.equal(tr.x(), rect.x());
assert.equal(tr.y(), rect.y());
assert.equal(tr.width(), 50);
assert.equal(tr.height(), 50);
assert.equal(tr.rotation(), rect.rotation());
});
test('listen shape changes', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
draggable: true,
fill: 'yellow'
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
layer.draw();
assert.equal(tr.getClassName(), 'Transformer');
rect.setAttrs({
x: 50,
y: 50,
width: 100,
height: 100
});
layer.draw();
assert.equal(tr.x(), rect.x());
assert.equal(tr.y(), rect.y());
assert.equal(tr.width(), rect.width());
assert.equal(tr.height(), rect.height());
});
test('add transformer for transformed rect', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
x: 150,
y: 60,
draggable: true,
width: 100,
height: 100,
fill: 'yellow',
rotation: 90,
scaleY: 1.5
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
layer.draw();
assert.equal(tr.getClassName(), 'Transformer');
assert.equal(tr.x(), rect.x());
assert.equal(tr.y(), rect.y());
assert.equal(tr.width(), rect.width() * rect.scaleX());
assert.equal(tr.height(), rect.height() * rect.scaleY());
assert.equal(tr.rotation(), rect.rotation());
});
test('try to fit a transformed rect', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
x: 150,
y: 60,
draggable: true,
width: 150,
height: 100,
fill: 'yellow',
rotation: 90,
scaleY: 1.5
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
layer.draw();
tr._fitNodeInto({
x: 100,
y: 70,
width: 100,
height: 100
});
assert.equal(rect.x(), 100);
assert.equal(rect.y(), 70);
assert.equal(rect.width() * rect.scaleX(), 100);
assert.equal(rect.height() * rect.scaleY(), 100);
assert.equal(rect.rotation(), rect.rotation());
});
test('add transformer for transformed rect with offset', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
x: 50,
y: 50,
draggable: true,
width: 100,
height: 100,
fill: 'yellow',
offsetX: 50,
offsetY: 50
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
layer.draw();
assert.equal(tr.getClassName(), 'Transformer');
assert.equal(tr.x(), rect.x() - 50);
assert.equal(tr.y(), rect.y() - 50);
assert.equal(tr.width(), rect.width() * rect.scaleX());
assert.equal(tr.height(), rect.height() * rect.scaleY());
assert.equal(tr.rotation(), rect.rotation());
});
test.skip('fit rect with offset', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var rect = new Konva.Rect({
x: 50,
y: 50,
draggable: true,
width: 100,
height: 100,
fill: 'yellow',
offsetX: 50,
offsetY: 50
});
layer.add(rect);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(rect);
tr._fitNodeInto({
x: 50,
y: 50,
width: 120,
height: 120
});
assert.equal(rect.x(), 100);
assert.equal(rect.y(), 100);
assert.equal(rect.width() * rect.scaleX(), 120);
assert.equal(rect.height() * rect.scaleY(), 100);
assert.equal(rect.rotation(), rect.rotation());
layer.draw();
});
test('add transformer for circle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var circle = new Konva.Circle({
x: 40,
y: 40,
draggable: true,
radius: 40,
fill: 'yellow'
});
layer.add(circle);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(circle);
layer.draw();
assert.equal(tr.getClassName(), 'Transformer');
assert.equal(tr.x(), 0);
assert.equal(tr.y(), 0);
assert.equal(tr.width(), circle.width() * circle.scaleX());
assert.equal(tr.height(), circle.height() * circle.scaleY());
assert.equal(tr.rotation(), circle.rotation());
});
test('fit a circle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var circle = new Konva.Circle({
x: 40,
y: 40,
draggable: true,
radius: 40,
fill: 'yellow'
});
layer.add(circle);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(circle);
tr._fitNodeInto({
x: 40,
y: 40,
width: 160,
height: 80
});
layer.draw();
assert.equal(circle.x(), 120);
assert.equal(circle.y(), 80);
assert.equal(circle.width() * circle.scaleX(), 160);
assert.equal(circle.height() * circle.scaleY(), 80);
assert.equal(tr.x(), 40);
assert.equal(tr.y(), 40);
assert.equal(tr.width(), 160);
assert.equal(tr.height(), 80);
});
test('fit a rotated circle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var circle = new Konva.Circle({
x: 40,
y: 40,
draggable: true,
radius: 40,
fill: 'yellow'
});
layer.add(circle);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(circle);
tr._fitNodeInto({
x: 80,
y: 0,
width: 80,
height: 80,
rotation: 90
});
layer.draw();
assert.equal(circle.x(), 40);
assert.equal(circle.y(), 40);
assert.equal(circle.width() * circle.scaleX(), 80);
assert.equal(circle.height() * circle.scaleY(), 80);
assert.equal(circle.rotation(), 90);
assert.equal(tr.x(), 80);
assert.equal(tr.y(), 0);
assert.equal(tr.width(), 80);
assert.equal(tr.height(), 80);
});
test('add transformer for transformed circle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var circle = new Konva.Circle({
x: 100,
y: 100,
draggable: true,
radius: 40,
fill: 'yellow',
scaleX: 1.5
});
layer.add(circle);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(circle);
layer.draw();
assert.equal(tr.getClassName(), 'Transformer');
assert.equal(tr.x(), 40);
assert.equal(tr.y(), 60);
assert.equal(tr.width(), 120);
assert.equal(tr.height(), 80);
assert.equal(tr.rotation(), 0);
});
test('add transformer for rotated circle', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var circle = new Konva.Circle({
x: 100,
y: 100,
draggable: true,
radius: 40,
fill: 'yellow',
scaleX: 1.5,
rotation: 90
});
layer.add(circle);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(circle);
layer.draw();
assert.equal(tr.x(), 140);
assert.equal(tr.y(), 40);
assert.equal(tr.width(), 120);
assert.equal(tr.height(), 80);
assert.equal(tr.rotation(), circle.rotation());
});
test('add transformer to group', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var group = new Konva.Group({
x: 50,
y: 50,
draggable: true
});
layer.add(group);
var shape1 = new Konva.Rect({
radius: 100,
fill: 'red',
x: 0,
y: 0,
width: 100,
height: 100
});
group.add(shape1);
var shape2 = new Konva.Rect({
radius: 100,
fill: 'yellow',
x: 50,
y: 50,
width: 100,
height: 100
});
group.add(shape2);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(group);
layer.draw();
assert.equal(tr.x(), group.x());
assert.equal(tr.y(), group.y());
assert.equal(tr.width(), 150);
assert.equal(tr.height(), 150);
assert.equal(tr.rotation(), 0);
});
test('rotated fit group', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var group = new Konva.Group({
x: 100,
y: 100,
draggable: true
});
layer.add(group);
var shape1 = new Konva.Rect({
fill: 'red',
x: -50,
y: -50,
width: 50,
height: 50
});
group.add(shape1);
var shape2 = new Konva.Rect({
fill: 'yellow',
x: 0,
y: 0,
width: 50,
height: 50
});
group.add(shape2);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(group);
tr._fitNodeInto({
x: 100,
y: 0,
width: 100,
height: 100,
rotation: 90
});
layer.draw();
var rect = group.getClientRect();
assert.equal(group.x(), 50);
assert.equal(group.y(), 50);
assert.equal(rect.width, 100);
assert.equal(rect.height, 100);
assert.equal(group.rotation(), 90);
assert.equal(tr.x(), 100);
assert.equal(tr.y(), 0);
assert.equal(tr.width(), 100);
assert.equal(tr.height(), 100);
});
test('add transformer to another group', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var group = new Konva.Group({
x: 100,
y: 100,
draggable: true
});
layer.add(group);
var shape1 = new Konva.Rect({
fill: 'red',
x: -50,
y: -50,
width: 50,
height: 50
});
group.add(shape1);
var shape2 = new Konva.Rect({
fill: 'yellow',
x: 0,
y: 0,
width: 50,
height: 50
});
group.add(shape2);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(group);
layer.draw();
assert.equal(tr.x(), 50);
assert.equal(tr.y(), 50);
assert.equal(tr.width(), 100);
assert.equal(tr.height(), 100);
assert.equal(tr.rotation(), 0);
});
test('fit group', function() {
var stage = addStage();
var layer = new Konva.Layer();
stage.add(layer);
var group = new Konva.Group({
x: 100,
y: 100,
draggable: true
});
layer.add(group);
var shape1 = new Konva.Rect({
fill: 'red',
x: -50,
y: -50,
width: 50,
height: 50
});
group.add(shape1);
var shape2 = new Konva.Rect({
fill: 'yellow',
x: 0,
y: 0,
width: 50,
height: 50
});
group.add(shape2);
var tr = new Konva.Transformer();
layer.add(tr);
tr.attachTo(group);
tr._fitNodeInto({
x: 0,
y: 0,
width: 200,
height: 100
});
layer.draw();
var rect = group.getClientRect();
assert.equal(group.x(), 100);
assert.equal(group.y(), 50);
assert.equal(rect.width, 200);
assert.equal(rect.height, 100);
assert.equal(tr.x(), 0);
assert.equal(tr.y(), 0);
assert.equal(tr.width(), 200);
assert.equal(tr.height(), 100);
});
});