Skip to main content

如何在画布上调整形状大小而不改变其描边大小?

请记住,Konva.Transformer 会更改节点的 scaleXscaleY 属性。 默认情况下,如果您变换一个形状,其描边也会被缩放。在某些情况下,这不是理想的行为。

有两种方法可以防止描边缩放:

  1. 重置形状的缩放
  2. 结合使用 shape.strokeScaleEnabled(false)transformer.ignoreStroke(false)

说明:有两个矩形可调整大小。绿色矩形将重置其缩放。红色矩形将仅禁用描边缩放。

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 rect1 = new Konva.Rect({
x: 50,
y: 50,
width: 100,
height: 100,
fill: '#00ff00',
stroke: 'black',
strokeWidth: 5,
draggable: true,
});
layer.add(rect1);

const tr1 = new Konva.Transformer({
nodes: [rect1],
});
layer.add(tr1);

rect1.on('transformend', () => {
// 变换后我们需要重置缩放
rect1.scaleX(1);
rect1.scaleY(1);
// 并手动增加宽度和高度
rect1.width(rect1.width() - rect1.scaleX());
rect1.height(rect1.height() - rect1.scaleY());
});

// 第二种方式 - 禁用描边缩放
const rect2 = new Konva.Rect({
x: 200,
y: 50,
width: 100,
height: 100,
fill: '#ff0000',
stroke: 'black',
strokeWidth: 5,
draggable: true,
strokeScaleEnabled: false,
});
layer.add(rect2);

const tr2 = new Konva.Transformer({
nodes: [rect2],
ignoreStroke: true,
});
layer.add(tr2);