slint/examples/7guis/timer.slint
Olivier Goffart 29debabaec 7guis: modernier the timer example
- Use the new Timer element
 - Use the ProgressIndicator instead of a home-made one.
 - Fixup the paddings.
2024-08-16 17:27:51 +02:00

52 lines
1.5 KiB
Text

// Copyright © SixtyFPS GmbH <info@slint.dev>
// SPDX-License-Identifier: MIT
import { LineEdit, Button, Slider, HorizontalBox, VerticalBox, ProgressIndicator } from "std-widgets.slint";
export component MainWindow inherits Window {
in-out property <duration> total-time: slider.value * 1s;
in-out property <duration> elapsed-time;
Timer {
interval: 10ms;
triggered => {
root.elapsed-time += self.interval;
root.elapsed-time = min(root.elapsed-time, root.total-time);
}
}
VerticalBox {
HorizontalBox {
padding: 0;
Text { text: "Elapsed Time:"; }
ProgressIndicator {
preferred-width: 100px;
progress: elapsed-time / total-time;
}
}
Text{
text: (root.total-time / 1s) + "s";
}
HorizontalBox {
padding: 0;
Text {
text: "Duration:";
vertical-alignment: center;
}
slider := Slider {
maximum: 30s / 1s;
value: 10s / 1s;
changed(new-duration) => {
root.total-time = new-duration * 1s;
root.elapsed-time = min(root.elapsed-time, root.total-time);
}
}
}
Button {
text: "Reset";
clicked => {
root.elapsed-time = 0
}
}
}
}