为什么我不能拥有带有此签名的Q_PROPERTY?
Why can't I have a Q_PROPERTY with this signature?
我是QT属性系统的新手,并且试图理解为什么如果我以一种方式注册和使用属性,它可以工作,但在另一种方式中它会失败。
我有两个类(A
和B
)都继承自QObject
。类B
包含类A
的几个实例,我想向Q_PROPERTY
宏注册这些实例。
A类:
#include <QObject>
#include <QMetaType>
class A: public QObject {
Q_OBJECT
Q_PROPERTY(double X MEMBER X)
Q_PROPERTY(double Y MEMBER Y)
Q_PROPERTY(double Z MEMBER Z)
public:
A() {
X = 0;
Y = 0;
Z = 0;
}
A(const A& other) {
X = other.X;
Y = other.Y;
Z = other.Z;
}
A(double x, double y, double z) {
X = x;
Y= y;
Z = z;
}
double X;
double Y;
double Z;
void operator =(const A& a) {
X = a.X;
Y = a.Y;
Z = a.Z;
}
bool operator !=(const A& a) {
return X != a.X || Y != a.Y || Z != a.Z:
}
};
Q_DECLARE_METATYPE(A)
如果我按如下方式声明 B 类,它工作正常,尽管我没有为指针做Q_DECLARE_METATYPE
:
#include <QObject>
#include <QMetaType>
#include "a.h"
class B : public QObject {
Q_OBJECT
Q_PROPERTY(A* A1 READ getA1 WRITE setA1)
Q_PROPERTY(A* A2 READ getA2 WRITE setA2)
public:
static A A1;
static A A2;
B();
B(const B& other);
private:
A* getA1 (){
return &A1;
}
void setA1(A* other){
A1= *other;
}
A* getA2 (){
return &A2;
}
void setA2(A* other){
A2= *other;
}
};
Q_DECLARE_METATYPE(B)
但是,如果我像这样声明 B,当我尝试使用这些属性时它会失败,说 A 是未注册的类型:
#include <QObject>
#include <QMetaType>
#include "a.h"
class B : public QObject {
Q_OBJECT
Q_PROPERTY(A A1 MEMBER A1)
Q_PROPERTY(A A2 MEMBER A2)
public:
static A A1;
static A A2;
B();
B(const B& other);
};
Q_DECLARE_METATYPE(B)
此外,我在代码的顶部调用了qRegisterMetaType<A>()
和qRegisterMetaType<B>()
。
这就是我尝试使用 B 属性的方式:
//call this function with a B* as one parameter, a populated Json object as the other
bool FromJson(QObject *o, const QJsonObject &obj){
bool rtn = true;
auto mo = o->metaObject();
for (int i = mo->propertyOffset(); i < mo->propertyCount(); ++i){
if(!mo->property(i).isConstant()){
if(obj.contains(mo->property(i).name())){
if(mo->property(i).type() == QVariant::UserType) {
//property is an A, go deeper
QVariant qobj = o->property(mo->property(i).name());
QObject* obj_ptr = qvariant_cast<QObject*>(qobj);
rtn = FromJson(obj_ptr, obj[mo->property(i).name()].toObject());
}
else {
//property is A.X, A.Y, A.Z
rtn = o->setProperty(mo->property(i).name(), obj[mo->property(i).name()]);
}
}
}
}
return rtn;
}
我希望它在将 QVariant 转换为 QObject* 的行上失败,但它实际上在前一行失败,它试图将属性作为 QVariant 获取,说它"无法处理未注册的类型 A"。而如果 B 的属性为 A*,则它工作为桃色。
我觉得我错过了一些非常愚蠢的东西。为什么我不能找回有效的QVariant,除非B的属性是指针?
Q_DECLARE_METATYPE(A)
不能在 A 类的 cpp 文件中,它必须在这个 A 类的头文件中。 B类也一样。
相关文章:
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的for循环不能正确获取argv
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 为什么我不能在 FOR LOOP 中使用 i/10,C++?
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 为什么模板类中的对象不能返回值
- 为什么我不能在一个类的不同行中声明和定义成员变量?
- 为什么我不能在 C++ 中的特定函数重载中调用同一函数的任何其他重载?
- ld:bind_at_load和-bitcode_bundle(Xcode设置ENABLE_bitcode=YES)不能
- 数组长度,为什么从命令行获取时不能使用它?
- Windows/Cygwin - 不能使用 pybind11 - 犯错误
- 为什么我不能使用 EGL 创建无头 OpenGl 上下文?
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- 为什么我不能将 rand() 与数组的大小一起使用?
- 为什么虚函数不能是静态的和全局的?
- 为什么我不能在 while 循环中创建线程?
- 为什么这个音频包络不能通过开关的情况?
- 不能将复制初始化与隐式转换的多个步骤一起使用