如何在QML中捕获信号?

时间:2012-02-29 01:34:05

标签: qt qml

如何将s信号从一个qml组件发送到另一个qml组件?

以下是一个例子:

Rectangle {
    id: main
    width: 360; height: 360
    signal clicked()

    Text {
        id: testStr
        anchors.centerIn: parent
        text: "Hello World"
    }
    MouseArea {
        id: mouseArea
        anchors.fill: parent
        onClicked: { Qt.quit(); }
    }

    Component.onCompleted: clicked()
    onClicked:  testStr.text = "Demo"
}

如何捕获其他组件中的信号?

4 个答案:

答案 0 :(得分:13)

您应该使用组件信号的connect()方法(信号本身就是对象)。

function clickHandler() {
    console.log('main clicked')
}
Component.onCompleted: {
    main.clicked.connect(clickHandler)
}

请参阅http://developer.qt.nokia.com/doc/qt-4.8/qmlevents.html

答案 1 :(得分:9)

在另一个对象中,您只需添加一个on字,后跟信号名称。 EG:

Rectangle {
  YourQmlObject {
    onClicked: { ... }
  }
}

(点击有点令人困惑的信号名称因为它很常见。但是如果你调用了你的信号orange,你就会进行绑定onOrange:

答案 2 :(得分:5)

您可以使用QML连接元素

 Connections {
 target: yourQmlObject 
 onClicked: foo(...)
 }

答案 3 :(得分:0)

QML

Button{
  id: btn_add_pq
  text: "Add"
  onClicked: {
    var component = Qt.createComponent("add_pq.qml")
    var dialog    = component.createObject(root)
    dialog.open()

    dialog.accepted.connect(function(){
      console.log("ID     :" + window.in_id)
      console.log("Name   :" + window.in_name)
      console.log("Comment:" + window.in_comment)
    })
  }
}

add_pq.qml

Dialog {
  id:dialog
  ...
  property alias in_id: txtID.text
  property alias in_comment: txtComment.text
  property alias in_name: txtName.text
  ...
  contentItem: GridLayout{
    ...
    TextField{
      id: txtComment
      Layout.alignment: Qt.AlignRight
    }
    Button{
      Layout.columnSpan: 2
      text: "Add"
      Layout.alignment: Qt.AlignRight
      onClicked: {
        dialog.click(StandardButton.Save)
      }
    }
  }