104 lines
2.5 KiB
QML
104 lines
2.5 KiB
QML
|
// Copyright (C) 2023 The Qt Company Ltd.
|
||
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
|
||
|
|
||
|
import QtQuick
|
||
|
import QtQuick.Shapes
|
||
|
|
||
|
ControlledShape {
|
||
|
id: shape
|
||
|
|
||
|
strokeWidth: 4
|
||
|
strokeColor: "black"
|
||
|
|
||
|
startX: 50
|
||
|
startY: 100
|
||
|
delegate: [
|
||
|
PathCubic {
|
||
|
x: 150
|
||
|
y: 100
|
||
|
control1X: cp1.x
|
||
|
control1Y: cp1.y
|
||
|
control2X: cp2.x
|
||
|
control2Y: cp2.y
|
||
|
}
|
||
|
]
|
||
|
Rectangle {
|
||
|
id: cp1
|
||
|
color: "red"
|
||
|
width: 10
|
||
|
height: 10
|
||
|
SequentialAnimation {
|
||
|
loops: Animation.Infinite
|
||
|
running: true
|
||
|
NumberAnimation {
|
||
|
target: cp1
|
||
|
property: "x"
|
||
|
from: 0
|
||
|
to: flickable.width - cp1.width
|
||
|
duration: 5000
|
||
|
}
|
||
|
NumberAnimation {
|
||
|
target: cp1
|
||
|
property: "x"
|
||
|
from: flickable.width - cp1.width
|
||
|
to: 0
|
||
|
duration: 5000
|
||
|
}
|
||
|
NumberAnimation {
|
||
|
target: cp1
|
||
|
property: "y"
|
||
|
from: 0
|
||
|
to: flickable.height - cp1.height
|
||
|
duration: 5000
|
||
|
}
|
||
|
NumberAnimation {
|
||
|
target: cp1
|
||
|
property: "y"
|
||
|
from: flickable.height - cp1.height
|
||
|
to: 0
|
||
|
duration: 5000
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
Rectangle {
|
||
|
id: cp2
|
||
|
color: "blue"
|
||
|
width: 10
|
||
|
height: 10
|
||
|
x: flickable.width - width
|
||
|
SequentialAnimation {
|
||
|
loops: Animation.Infinite
|
||
|
running: true
|
||
|
NumberAnimation {
|
||
|
target: cp2
|
||
|
property: "y"
|
||
|
from: 0
|
||
|
to: flickable.height - cp2.height
|
||
|
duration: 5000
|
||
|
}
|
||
|
NumberAnimation {
|
||
|
target: cp2
|
||
|
property: "y"
|
||
|
from: flickable.height - cp2.height
|
||
|
to: 0
|
||
|
duration: 5000
|
||
|
}
|
||
|
NumberAnimation {
|
||
|
target: cp2
|
||
|
property: "x"
|
||
|
from: flickable.width - cp2.width
|
||
|
to: 0
|
||
|
duration: 5000
|
||
|
}
|
||
|
NumberAnimation {
|
||
|
target: cp2
|
||
|
property: "x"
|
||
|
from: 0
|
||
|
to: flickable.width - cp2.width
|
||
|
duration: 5000
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|