slint/internal/compiler/tests/syntax/basic/rotation.slint
Simon Hausmann 7896e645b2 Permit rotation properties on Text elements without children
This works with Skia, Qt, and FemtoVG.

cc #1481
2024-07-03 09:08:23 +02:00

75 lines
1.9 KiB
Text

// Copyright © SixtyFPS GmbH <info@slint.dev>
// SPDX-License-Identifier: GPL-3.0-only OR LicenseRef-Slint-Royalty-free-2.0 OR LicenseRef-Slint-Software-3.0
export Ex1 := Rectangle {
Rectangle {
rotation-origin-x: width / 2;
rotation-angle: 45deg;
// ^error{rotation properties can only be applied to the Image or Text element}
rotation-origin-y: width / 2;
}
Rectangle {
// ^error{rotation properties can only be applied to the Image or Text element}
rotation-origin-x: width / 2;
rotation-origin-y: width / 2;
}
Text {
rotation-angle: 90deg;
}
}
RotImg := Image {
rotation-angle: 45deg;
}
JustAnImage := Image {}
ImageWithChild := Image {
Rectangle {}
}
export Ex2 := Rectangle {
Image {
// ^error{Elements with rotation properties cannot have children elements}
rotation-angle: 45deg;
Rectangle {}
}
RotImg {
// ^error{Elements with rotation properties cannot have children elements}
Rectangle {}
}
ImageWithChild {
// ^error{Elements with rotation properties cannot have children elements}
rotation-origin-x: 45px;
}
JustAnImage {
// ^error{Elements with rotation properties cannot have children elements}
rotation-angle: 45deg;
Rectangle {}
}
}
export Ex3 := Rectangle {
i1 := Image {
// ^error{Elements with rotation properties cannot have children elements}
Rectangle {}
}
i2 := Rectangle {}
// ^error{rotation properties can only be applied to the Image or Text element}
TouchArea {
clicked => {
i1.rotation-angle = 60deg;
i2.rotation-origin-x = 10px;
}
}
}
export component Ex4 {
in property rot <=> rect . rotation-angle;
rect := Rectangle {}
// ^error{rotation properties can only be applied to the Image or Text element}
}