HTML5 Canvas 强制更新教程

Konva.Transformer 会自动追踪附加节点的属性。
因此,它会自动采用自己的属性。

但在某些情况下,Konva.Transformer 无法做到这一点。目前,Konva.Transformer 不能追踪 Konva.Group 节点内部的深层变化。在这种情况下,您需要使用 forceUpdate 方法来重置变换工具。

说明:点击按钮。查看变换器如何变化。

Transformer Force Update Demoview raw
<!DOCTYPE html>
<html>
<head>
<!-- USE DEVELOPMENT VERSION -->
<script src="https://unpkg.com/konva@9.3.18/konva.min.js"></script>
<meta charset="utf-8" />
<title>Konva Transform Events Demo</title>
<style>
body {
margin: 0;
padding: 0;
overflow: hidden;
background-color: #f0f0f0;
}

#button {
position: absolute;
top: 5px;
left: 10px;
}
</style>
</head>

<body>
<div id="container"></div>
<input type="button" id="button" value="Add random shape" />
<script>
var width = window.innerWidth;
var height = window.innerHeight;

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

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

var group = new Konva.Group({
x: 50,
y: 50,
draggable: true,
});
layer.add(group);

// create new transformer
var tr = new Konva.Transformer();
layer.add(tr);
tr.nodes([group]);

document.getElementById('button').addEventListener('click', addShape);
addShape();

function addShape() {
group.add(
new Konva.Circle({
x: Math.random() * 100,
y: Math.random() * 100,
radius: Math.random() * 100,
fill: Konva.Util.getRandomColor(),
stroke: 'black',
strokeWidth: Math.random() * 10,
})
);
// force update manually
tr.forceUpdate();
}
</script>
</body>
</html>