c++ - 使用自定义类作为 Q_PROPERTY

标签 c++ qt qobject

我有两个类,TestATestBTestA 扩展了QObject。我已经用一些 Q_PROPERTY 来设置它,就像这样。

Q_PROPERTY(QString a_string READ getString WRITE setString)
Q_PROPERTY(int a_int READ getInt WRITE setInt)

当然,我创建了适当的 getter 和 setter。这个类运行得很好。

在我的第二个类 TestB 中,我想创建一个 Q_PROPERTY ,它是一个 TestA,所以我在 中执行此操作testb.h.

Q_PROPERTY(TestA testa READ getTestA)
public:
TestA *getTestA();
private:
TestA mTestA;

这在 testb.cpp 中。

TestA *TestB::getTestA() {return &mTestA;}

当我尝试编译此文件时,收到以下错误消息。

moc_testb.cpp: In member function 'virtual int TestB::qt_metacall(QMetaObject::Call, int, void**)':
moc_testb.cpp:75: error: no match for 'operator=' in '*(TestA*)_v = TestB::getTestA()'
../qttest/testa.h:7: note: candidates are: TestA& TestA::operator=(const TestA&)

有人可以告诉我需要做什么来解决这个问题吗?

最佳答案

我认为该错误与 READ 操作有关。它导致引用的 QT 函数期望 testa 是 TestA 类型的对象,该对象由函数 getTestA 返回。但是,getTestA 返回一个指向 TestA 类型的对象的指针。

我认为你可以通过将 getTestA 的原型(prototype)更改为来解决该问题 TestA getTestA();

并声明如下: TestA TestB::getTestA() {return mTestA;}

关于c++ - 使用自定义类作为 Q_PROPERTY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11174307/

相关文章:

linux - 如何在 Ubuntu 中从终端运行 Qtcreator?

qt - 我应该使用哪个 qt 小部件来显示消息?

c++ - 将 lambda 函数作为第三个参数传递给 QObject::connect 时出错

c++ - QObject克隆

c++ - 关于 QThread、QObject、Thread Affinity 和 Event Loop 的困惑

c++ - TextureCache::addImageAsync 选择器类型转换问题

c++ - 如何使用结构 vector 作为参数从node-ffi调用c++中的方法?

C++:双边类转换

python - 如何从一个类发出 Qtsignal,从而导致在 pyqt 中从其父类发出 Qtsignal

c++ - 不能重载 "<<"运算符