zoukankan      html  css  js  c++  java
  • 自定义数据类型使用QVariant转换的方法

      QVariant类型的放入和取出必须是相对应的,你放入一个int就必须按int取出,不能用toString(), Qt不会帮你自动转换。
    数据核心无非就是一个 union,和一个标记类型的type:传递的是整数 123,那么它union存储整数123,同时type标志Int;如果传递字符串,union存储字符串的指针,同时type标志QString
    QVariant 属于 Qt 的Core模块,属于Qt的底层核心之一,ActiveQt、QtScript、QtDeclarative等都严重依赖于QVariant。

      QVariant 可以保存很多Qt的数据类型,包括QBrush、QColor、QCursor、QDateTime、QFont、QKeySequence、 QPalette、QPen、QPixmap、QPoint、QRect、QRegion、QSize和QString,并且还有C++基本类型,如 int、float等。QVariant还能保存很多集合类型,如QMap<QSTRING, QVariant>, QStringList和QList。item view classes,数据库模块和QSettings都大量使用了QVariant类,,以方便我们读写数据。

    QVariant也可以进行嵌套存储,例如

    1 QMap<QString, QVariant> pearMap;   
    2 pearMap["Standard"] = 1.95;   
    3 pearMap["Organic"] = 2.25;   
    4 
    5 QMap<QString, QVariant> fruitMap;   
    6 fruitMap["Orange"] = 2.10;   
    7 fruitMap["Pineapple"] = 3.85;   
    8 fruitMap["Pear"] = pearMap;

    QVariant被用于构建Qt Meta-Object,因此是QtCore的一部分。当然,我们也可以在GUI模块中使用,例如

    QIcon icon("open.png");   
    QVariant variant = icon;   
    // other function   
    QIcon icon = variant.value<QIcon>();

    我们使用了value()模版函数,获取存储在QVariant中的数据。这种函数在非GUI数据中同样适用,但是,在非GUI模块中,我们通常使用toInt()这样的一系列to...()函数,如toString()等。

      如果你觉得QVariant提供的存储数据类型太少,也可以自定义QVariant的存储类型。被QVariant存储的数据类型需要有一个默认的构造函数和一个拷贝构造函数。为了实现这个功能,首先必须使用Q_DECLARE_METATYPE()宏。通常会将这个宏放在类的声明所在头文件的下面(Q_DECLARE_METATYPE(MyClass)宏的位置:头文件,类声明后):

     1 要使用一个自定义类型可用于QVariant中只需要在类声明的后面加上:Q_DECLARE_METATYPE(), 
     2 struct MyClass
     3 {
     4 QString name;
     5 int age;
     6 }
     7 Q_DECLARE_METATYPE(MyClass)
     8 
     9 
    10 这样我们的类就可以像QMetaType::Type类一样使用没什么不同,有点不同的是使用方法上面只能这样使用.
    11 MyClass myClass;
    12 QVariant v3 = QVairant::fromValue(myClass);
    13 //
    14 v2.canConvert<MyClass>();
    15 MyClass myClass2 = v2.value<MyClass>();

    例如:

    Q_DECLARE_METATYPE(BusinessCard)

    然后我们就可以使用:

    1 BusinessCard businessCard;   
    2 QVariant variant = QVariant::fromValue(businessCard);   
    3 // ...   
    4 if (variant.canConvert<BusinessCard>()) {   
    5      BusinessCard card = variant.value<BusinessCard>();   
    6      // ...   
    7 }

    由于VC 6的编译器限制,这些模板函数不能使用,如果你使用这个编译器,需要使用qVariantFromValue(), qVariantValue()和qVariantCanConvert()这三个宏。

      如果自定义数据类型重写了<<和>>运算符,那么就可以直接在QDataStream中使用。不过首先需要使用qRegisterMetaTypeStreamOperators().宏进行注册。这就能够让QSettings使用操作符对数据进行操作,例如qRegisterMetaTypeStreamOperators<BusinessCard>("BusinessCard");

    转自:http://blog.csdn.net/zhangbinsijifeng/article/details/50686753

    QVariant与自定义数据类型转换的方法

    在使用VC、Delphi编写用户界面程序的时候,经常会把对象与控件的data域进行绑定,便于程序运行中读写提高效率。然而在Qt编程中怎么实现这个功能呢?比如将一个用户自定义的结构体与QComboBox控件的data绑定?

        Qt的联机帮助做的实在是差强人意,示例代码太少了。调试了半天,看到这篇文章给了我提示。主要步骤如下:

        1、将自定义数据类型使用Q_DECLARE_METATYPE宏进行声明,便于编译器识别。

        2、在插入对象的时候,声明QVariant对象,使用其setValue方法添加自定义对象。

        3、在读取的时候,采用QVariant对象的value方法返回自定义对象。

        示例代码如下:

        1、自定义结构体及元类型声明:

    1 struct MyStruct  
    2 {  
    3     int a;  
    4     char b[10];  
    5 };  
    6 MyStruct stu;  
    7   
    8 Q_DECLARE_METATYPE(MyStruct)

    2、在程序初始化中,给结构体初始化并存储到QComboBox的data域中:

     1 bzero(&stu, sizeof(MyStruct)); //stu就是上面声明的全局变量  
     2 //赋初值  
     3 stu.a = 100;  
     4 strcpy(stu.b,"Hello./n");  
     5 //类型转换  
     6 QVariant v;  
     7 QString ss = QString("%1").arg(stu.b);  
     8 v.setValue(stu);  
     9 //保存到控件data中  
    10 ui->cboTest->addItem(ss, v);  
    11 ui->cboTest->addItem("aadkjf", 0);

    3、读取的时候反过来处理,如下:

    1 QVariant v;  
    2 //从控件data域取得variant对象  
    3 v = ui->cboTest->itemData(0);  
    4 //转换为自定义的结构体实例  
    5 MyStruct s = v.value<MyStruct>();  
    6 printf("value=%d:%s/n",s.a, s.b);  

     转自:http://blog.csdn.net/derryzhang/article/details/5114491

  • 相关阅读:
    nyoj256-C小加之级数求和
    nyoj254-编号统计
    nyoj286-动物统计
    最长回文子串——manacher
    动态规划:Codeforces Round #427 (Div. 2) C Star sky
    水题:51Nod1432-独木舟
    水题:HDU1716-排列2
    水题:CF16C-Monitor
    数学基础:HUD1124-Factorial(N!末尾0的个数)
    并查集:POJ1182-食物链(并查集比较高端的应用)
  • 原文地址:https://www.cnblogs.com/yuemw/p/7994091.html
Copyright © 2011-2022 走看看