- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一堆嵌套列表,链中最深的列表高度为 0。因此,当用户单击按钮时,列表应该展开。
我的问题是,我无法向列表的委托(delegate)发送信号,以便它知道何时展开。我已经尝试了很多东西。
我已经成功使用的一种方法失败了,因为它找不到正确的对象
view->setSource(QUrl(QStringLiteral("qrc:/content/CommentNumberDelegate.qml")));
QObject *obj3 = view->rootObject()->findChild<QObject*>("commentNumberDelegate");
QObject::connect(&gather, SIGNAL(showCommentsButtonClicked()), obj3, SIGNAL(showCommentsButtonClicked()));
这给了我错误:
QObject::connect: Cannot connect DataGather::showCommentsButtonClicked() to (null)::showCommentsButtonClicked()
是的,我已经正确设置了我正在访问的文件的 ObjectName 属性 (CommentNumberDelegate.qml)。
CommentNumberDelegate.qml: 小版本
Rectangle {
id: root
objectName: "commentNumberDelegate"
//width: parent.width + 20
height: 0 //col1.childrenRect.height //Screen.height * 0.1 //300 //col1.childrenRect.height
clip: true
property alias delegateState: root.state
signal showCommentsButtonClicked()
}
尽管我之前已经成功连接过这样的信号,但我无法让它工作。此代码有效:
view->setSource(QUrl(QStringLiteral("qrc:/LoginPage.qml")));
QObject *obj = view->rootObject()->findChild<QObject*>("loginRectID");
QObject::connect(&gather, SIGNAL(loginSequenceFinished(QString)), obj, SIGNAL(loginSequenceFinished(QString)));
QObject *obj2 = view->rootObject()->findChild<QObject*>("mainRectID");
QObject::connect(&gather, SIGNAL(xmlFileCreationFinished()), obj, SIGNAL(xmlFileCreationFinished()));
当我使用调试器时,我可以看到 QObject *obj3 没有被正确分配,因为我无法访问它。在 obj 和 ob2(工作代码)上使用调试器时,我可以清楚地看到对象已正确分配,因为分配给它后我可以使用调试器访问它。
我的问题是:我在这里做错了什么?
最佳答案
我尝试获取对象的任何方式都失败了,它仍然是空的。
所以我试着看看在 QML 本身中,每次委托(delegate)完成时对象是否可用。所以我做了:
delegate: CommentNumberDelegate {
objectName: "commentNumberDelegateID"
id: commentNumberDelegateID
Component.onCompleted: {
console.log("delegate completed = ", commentNumberDelegateID)
gatherer.test123(commentNumberDelegateID) // this function passes the address to c++
}
输出:
qml: delegate completed = CommentNumberDelegate_QMLTYPE_2(0x2bfa5748, "commentNumberDelegateID")
qml: delegate completed = CommentNumberDelegate_QMLTYPE_2(0x2bf78d38, "commentNumberDelegateID")
正如您所看到的,当组件完成时,该对象确实可用。所以我所做的就是将地址传递给名为 test123 的函数,该函数将 QObject 指针作为参数。
我用来将委托(delegate)内的信号连接到 C++ 中的信号的指针
收集器.h
class DataGather : public QObject
{
....
Q_INVOKABLE void showCommentsButton() { emit showCommentsButtonClicked(); }
Q_INVOKABLE void test123(QObject *obj);
....
signals:
void showCommentsButtonClicked();
}
收集器.cpp
void DataGather::test123(QObject* obj)
{
QObject::connect(this, SIGNAL(showCommentsButtonClicked()), obj, SIGNAL(showCommentsButtonClicked()));
}
所以基本上,您需要做的就是:
从 QML 调用 showcomments 按钮。这将发出信号。从 QML 中,您可以像这样捕获它:
commentNumberDelegate.qml:
Rectangle {
id: commentNumberDelegate
objectName: "commentNumberDelegate"
width: parent.width + 20
height: col1.childrenRect.height
clip: true
signal showCommentsButtonClicked()
onShowCommentsButtonClicked: console.log("showCommentsButtonClicked signal has been caught")
现在,我不确定这是否正确,但它对我有用。
关于c++ - QML - 将信号从 C++ 连接到 qml,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29535722/
如果下一个元素的宽度超过指定布局的宽度,是否有 QML 布局或某些配置会自动将 QML 项目包装到下一行? 当我使用 QML GridLayout ,项目刚好离开窗口的边缘并被剪裁: GridLayo
如果下一个元素的宽度超过指定布局的宽度,是否有 QML 布局或某些配置会自动将 QML 项目包装到下一行? 当我使用 QML GridLayout ,项目刚好离开窗口的边缘并被剪裁: GridLayo
如何在 qml 文件之间发送变量或信号? http://i.stack.imgur.com/MChCG.png Mainwindow -> 创建组件Item2.qml MainWindow -> 创建
我正在做一些事情,我有一个名为“FloatingMenu”的类(它应该在 C++ 中管理菜单)及其在文件 FloatingMenu.qml 中用于 GUI 的 QML alter-ego。我有一个文件
我正在尝试做一些看似简单的事情,但失败了:定义一个简单的内联文本格式组件,然后用不同的文本多次实例化它。这是代码 Item { . . . Component { id: favButtonL
我可以在页面中使用 InvokeActionItem 轻松共享项目,但我需要能够在 ListView 项目中调用它。我设法触发了一个调用,但我不知道如何在触发它时添加数据。我不断收到错误消息 Invo
我如何在 QML 中检测 Window {} 之外的点击? Rectangle { id: topLevel height: 400; width: 400 Window {
我试过 : var child = grid.children[slot1]; grid.children[slot1] = grid.children[slot2]; grid.children[s
例如,我希望创建一个包含 100 个文本编辑器的 qml 窗口,如何在循环中创建它?那可能吗? 最佳答案 循环是命令式代码,所以它不是 QML,而是 Javascript 或 C++。所以当然,你可以
这是我的 QML 文件,其中包含一个文本组件: import QtQuick 2.0 Item { id: idItmWrapText Text { id: idTxt
我正在寻找一种方法来显示一个文本提示,说明预期的输入作为对用户的建议。以谷歌搜索栏为例: 是否有我缺少的属性,或者这是必须通过脚本来实现的? 最佳答案 Qt Quick 输入项上不存在该属性。您可以为
为 qml 项设置背景的最简单方法是让子矩形的 anchor 完全填满父项: Item { width: 320 height: 240 Rectangle {
我想将属性动态添加到 QML 元素: Item { id: dynamicProperty; property int first; Component.onCompleted: { /*
我用 PySide 和 QML 编写了某种安装程序。按照设计,它必须是多页的。而且我想将要从 QML 表单调用的插槽划分为不同的对象(理想情况下,划分为模块,但据我了解,带有插槽的对象必须继承 QOb
QML 中有没有办法用 opacity: 0 创建一个矩形?仍然有可见的边界?如果没有,有关如何解决它的任何建议? 谢谢 最佳答案 不,不透明度适用于项目的完整视觉方面(并且不透明度:0 使项目完全不
属性变体 a:{}似乎不起作用。 a 最终未定义,而不是一个空字典。 我对 Javascript 不是很有经验...初始化属性以保存空字典的正确方法是什么? 以下 qml 在控制台上打印“qrc:/m
我在 SO 上查看了大量关于 QML 内容边距的问题,但所有答案都指向缺少 spacing: 0 属性。我已经完成了所有这些,但仍然有一些我无法消除的奇怪空间。任何人都可以解释为什么这个 QML 代码
我有一个用于样式定义的 QML 单例,定义如下: pragma Singleton import QtQuick 2.2 import QtQuick.Controls 1.1 import QtQu
这是以下代码的结果: 主.qml import QtQuick 2.8 Item { Reusable { index: 1234 // reusable with
属性变体 a:{}似乎不起作用。 a 最终未定义,而不是一个空字典。 我对 Javascript 不是很有经验...初始化属性以保存空字典的正确方法是什么? 以下 qml 在控制台上打印“qrc:/m
我是一名优秀的程序员,十分优秀!