Skip to main content

HTML5 Canvas Shape Resize and Transform Limits

To limit or change resize and transform behavior you can use boundBoxFunc property. It works a bit similar to dragBoundFunc.

Instructions: Try to resize a shape. You will see that its width is limited to 200.

Also you can control movement of every anchors individually. See Resize Snap Demo.

import Konva from 'konva';

const width = window.innerWidth;
const height = window.innerHeight;

const stage = new Konva.Stage({
container: 'container',
width: width,
height: height,
});

const layer = new Konva.Layer();
stage.add(layer);

const rect = new Konva.Rect({
x: 50,
y: 50,
width: 100,
height: 100,
fill: 'yellow',
stroke: 'black',
draggable: true,
});
layer.add(rect);

const tr = new Konva.Transformer({
nodes: [rect],
boundBoxFunc: (oldBox, newBox) => {
// limit resize

if (newBox.width > 200) {
return oldBox;
}
return newBox;
},
});
layer.add(tr);


</rewritten_file>