QVariantMap 和 QVariant


typedef QVariantMap

Synonym for(同義詞) QMap<QString, 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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM