我有两个类,TestA
和 TestB
。 TestA
扩展了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/