<template>
<v-stage ref="stage" :config="stageSize">
<v-layer ref="layer">
<v-rect
ref="rect"
@dragstart="changeSize"
@dragend="changeSize"
:config="{
width: 50,
height: 50,
fill: 'green',
draggable: true,
x: 100,
y: 100
}"
/>
<v-regular-polygon
ref="hexagon"
:config="{
x: 200,
y: 200,
sides: 6,
radius: 20,
fill: 'red',
stroke: 'black',
strokeWidth: 4
}"
/>
</v-layer>
</v-stage>
</template>
<script setup>
import { ref, onMounted } from 'vue';
import Konva from 'konva';
const stageSize = {
width: window.innerWidth,
height: window.innerHeight
};
const stage = ref(null);
const hexagon = ref(null);
const changeSize = (e) => {
e.target.to({
scaleX: Math.random() + 0.8,
scaleY: Math.random() + 0.8,
duration: 0.2
});
};
onMounted(() => {
const amplitude = 100;
const period = 5000;
const centerX = stage.value.getNode().getWidth() / 2;
const hexagonNode = hexagon.value.getNode();
const anim = new Konva.Animation((frame) => {
hexagonNode.setX(
amplitude * Math.sin((frame.time * 2 * Math.PI) / period) + centerX
);
}, hexagonNode.getLayer());
anim.start();
});
</script>