我正在尝试将QVariantMap
转换为派生自QObject
的自定义类,但是在设置我的枚举类型的属性时,我从setProperty()获取了false
的返回值。代码如下:
MessageHeader.h 文件:
// deserialization class header
class MessageHeader : public QObject
{
Q_OBJECT
public:
MessageHeader(QObject *parent = 0);
~MessageHeader();
enum class MessageType
{
none = 0,
foo = 1,
baa = 2
};
Q_ENUM(MessageType)
Q_PROPERTY(MessageType type READ getType WRITE setType)
Q_PROPERTY(int ContentLength READ getContentLength WRITE setContentLength)
void setType(MessageType type);
void setContentLength(int ContentLength);
MessageType getType();
int getContentLength();
QString toString();
MessageType type = MessageType::none;
int ContentLength = 0;
};
MessageHeader.cpp 文件:
MessageHeader::MessageHeader(QObject *parent)
: QObject(parent)
{
}
MessageHeader::~MessageHeader()
{
}
MessageType MessageHeader::getType()
{
return type;
}
int MessageHeader::getContentLength()
{
return ContentLength;
}
void MessageHeader::setType(MessageType type)
{
this->type = type;
}
void MessageHeader::setContentLength(int ContentLength)
{
this->ContentLength = ContentLength;
}
QString MessageHeader::toString()
{
return QString("NOT IMPLEMENTED YET");
}
反序列化功能模板助手:
template<typename T>
T* Deserialize(const QString &json)
{
bool status = false;
QJson::Parser parser;
QVariantMap map = parser.parse(json.toUtf8(), &status).toMap();
if(!status)
return NULL;
T *obj = new T(); //don't worry about this, I'll rather take this from paramters once this is working
QObject *p = (QObject *) obj; // cast done so that I see setProperty() method
for(QVariantMap::const_iterator iter = map.begin(); iter != map.end(); ++iter)
{
const char *name = iter.key().toLatin1();
const QVariant value = iter.value();
qDebug() << "setting " << name << "=" << value;
// the issue goes below. Here setProperty() return false.
// At this point, name = 'type' and value = 2
assert(p->setProperty(name, value));
}
//QJson::QObjectHelper::qvariant2qobject(map, obj);
return obj;
}
上面函数的JSON输入字符串是这样的:
"{\"ContentLength\": 100, \"type\": 2}"
枚举类型先在
main
函数中注册:qRegisterMetaType<MessageType>("MessageType");
这是此示例中使用的QJson库。我使用此.pro文件在Windows上构建它
编辑:
我刚刚发现indexOfProperty()找不到type属性
qDebug() << "id = " << meta->indexOfProperty(name); // print -1, name = 'type'
最佳答案
仅当变体类型是here,QString
或QInt
时,才可以设置enum属性。因此,要成功设置enum属性,变体必须是这些类型之一,而别无其他。 QJson将任何无符号整数解析为QUInt
,就像here, line 84一样。因此,一种方法是派生QJson并修改代码,以便将整数值转换为QULongLong
和QInt
或将枚举值作为字符串读取/写入。
另外,将语句放在QUInt
中也不是一个好主意,但是我认为您只是编写该代码来解决问题。
正如Qt文档所述,
因此将 header 中的assert
替换为qRegisterMetaType<MessageHeader::MessageType>("MessageType")
将是一个合理的举动。