2012-06-24 231 views
1

我有两个类,TestATestBTestA延伸QObject。我建立了几个Q_PROPERTY就是这样。使用自定义类作为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&) 

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

回答

1

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

我想你可以通过改变getTestA的原型 TestA getTestA();

,并声明它,如下所示解决问题: TestA TestB::getTestA() {return mTestA;}

+4

你可以添加到你的答案是,如果一个人想返回类型为TestA,还可以将属性的类型更改为指针类型:'Q_PROPERTY(TestA * testa READ getTestA)' – leemes

+0

使用@lemes建议,我的编译错误消失了。我可以发誓我已经试过了。 :} –