ボタンのonClick()内から要素アクション(タイマーのonTriggered()など)をオーバーライドすることは可能ですか?
のようなもの->
Button {
id: centerBtn
objectName: "button"
onClicked: {
delaytimer.running = true;
delayTimer.onTriggered {}; // override here
}
Timer {
id: delaytimer
interval: 1000
running: false
repeat: false
onTriggered: //something implemented here
}
}
シグナルハンドラーのコードを格納するプロパティを定義し、必要に応じて再割り当てできます。
次のコードスニペットを見てください。
import QtQuick 2.0
import Ubuntu.Components 0.1
Rectangle {
width: 200
height: 150
Button {
id: foo
text: "Foo"
onClicked: {
delaytimer.a = function () { console.log("Foo!") };
delaytimer.running = true;
}
}
Button {
id: bar
text: "Bar"
anchors.left: foo.right
onClicked: {
delaytimer.a = function () { console.log("Bar!") };
delaytimer.running = true;
}
}
Timer {
id: delaytimer
interval: 1000
running: false
repeat: false
property var a: function () { console.log("will be overridden!") };
onTriggered: a()
}
}