Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/qt/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
QT QML更改状态c++;_Qt_Qml - Fatal编程技术网

QT QML更改状态c++;

QT QML更改状态c++;,qt,qml,Qt,Qml,我有一只老鼠耳朵能发出信号, 我把这个信号插入一个时隙,它正在工作,我的C++代码正在运行。 但是C++代码里面有可能改变QML状态吗? 呼叫信号按钮的代码(OK): 我国法典: states: [ State { name: "start"; PropertyChanges { target: home; x: -master.width; } PropertyChanges { target: login; x:0; } },

我有一只老鼠耳朵能发出信号, 我把这个信号插入一个时隙,它正在工作,我的C++代码正在运行。 <>但是C++代码里面有可能改变QML状态吗? 呼叫信号按钮的代码(OK):

我国法典:

states: [
    State {
        name: "start";
        PropertyChanges { target: home; x: -master.width; }
        PropertyChanges { target: login; x:0; }
    },
    State {
        name: "loginOK";
        PropertyChanges { target: login; x: -master.width; }
        PropertyChanges { target: liste; x:0; }
    }
]
我想在我的插槽内(c++代码)将状态更改为“loginOK”,是否可能


谢谢

因为状态是一个项目属性,所以您应该可以这样修改它:

QDeclarativeEngine engine;
QDeclarativeComponent component(&engine, "MyItem.qml");
QObject *object = component.create();
object->setProperty("state", "loginOK");
参考:

或从C++插槽中,您可以发出一个信号,将状态字符串传递给QML时隙,然后再设置状态。例如:

C++文件:

...
signals:
     void stateChanged(const QString &newState);
...
QML文件:

...
MyItem {
     onStateChanged: {
         state: newState
     }
}
...

问题:我假设您确实
emit stateChanged(“loginOK”)
对象->设置属性(“state”、“loginOK”)之后。您没有提到如何将信号绑定到QML插槽。你能提供一下信息吗。我使用<代码>连接{{}},将C++信号连接到QML时隙,但在这种情况下,这不会触发UI的变化(因为在我的例子中,基于新的状态,该项会改变(例如<代码>颜色< /代码> <代码>矩形/<代码>项)。只有当使用<代码>连接{}时,才会触发时隙。。否则,什么都不会发生。没有主意。我设法修复它。实际上在最近的QT中,必须使用<代码>连接< /COD>项。但是,当从C++调用时,列表中所有可见项的状态都发生了变化。为了防止必须指定只有<代码> Curristist.Stase<代码>,需要将其设置为新S。泰特。
...
MyItem {
     onStateChanged: {
         state: newState
     }
}
...