成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

解析關于Qt Quick宏學習教程

移動開發
Qt Quick宏是本文要介紹的內容,主要是來Qt Quick中關于宏的內容進行學習,文章很詳細的講解了宏在Qt Quick的使用,來看詳細內容。

Qt Quick宏是本文要介紹的內容,主要是來Qt Quick中關于的內容進行學習。剛開始接觸Qt的朋友可能對Qt在使用當中需要聲明的各色各樣的感到神秘而又陌生,本文將介紹Qt中經常使用的幾個

  1. Q_OBJECT, SIGNAL與SLOT, Q_SIGNALS 與 Q_SLOTS, Q_EMIT ,Q_INVOKABLE, Q_PROPERTY: 

的頭文件出處:

  1. $QTDIR/src/corelib/kernel/qobjectdefs.h 
  1. Q_OBJECT  
  2. #define Q_OBJECT /   
  3. public: /   
  4.     Q_OBJECT_CHECK /   
  5.     static const QMetaObject staticMetaObject; /   
  6.     Q_OBJECT_GETSTATICMETAOBJECT /   
  7.     virtual const QMetaObject *metaObject() const; /   
  8.     virtual void *qt_metacast(const char *); /   
  9.     QT_TR_FUNCTIONS /   
  10.     virtual int qt_metacall(QMetaObject::Call, int, void **); / 

宏Q_OBJECT是Qt所有宏中最為重要的一個,Q_OBJECT是使用信號槽機制以及其他所有元對象系統提供的服務(內省、invokeMethod,元對象property系統等等)的前提條件。有關Q_OBJECT的討論請參考Qt源碼分析之QObject。

SIGNAL與SLOT

這兩個宏是調用connect方法時用到:

  1. QObject::connect(myButton, SIGNAL(clicked()),     
  2.                   label,  SLOT(showText()));    
  3. QObject::connect(myButton, SIGNAL(clicked()),   
  4.                   label,  SLOT(showText()));  

那么SIGNAL和SLOT為我們做了那些事情呢,看一下源代碼:

  1. $QTDIR/src/corelib/kernel/qobjectdefs.h    
  2. # define SLOT(a)     qFlagLocation("1"#a QLOCATION)      
  3. # define SIGNAL(a)   qFlagLocation("2"#a QLOCATION)     
  4. $QTDIR/src/corelib/kernel/qobject.cpp    
  5. const char *qFlagLocation(const char *method)     
  6. {     
  7.     static int idx = 0;     
  8.     flagged_locations[idx] = method;     
  9.     idx = (idx+1) % flagged_locations_count;     
  10.     return method;     
  11. }    
  12. $QTDIR/src/corelib/kernel/qobjectdefs.h  
  13. # define SLOT(a)     qFlagLocation("1"#a QLOCATION)   
  14. # define SIGNAL(a)   qFlagLocation("2"#a QLOCATION)  
  15. $QTDIR/src/corelib/kernel/qobject.cpp  
  16. const char *qFlagLocation(const char *method)   
  17. {   
  18.     static int idx = 0;   
  19.     flagged_locations[idx] = method;   
  20.     idx = (idx+1) % flagged_locations_count;   
  21.     return method;   
  22. }  

原來它會基于把我們定義的信號、槽的名稱返回一個字符串,比如SIGNAL(clicked()) 返回字符串 “2clicked()”, SLOT(showText())返回字符串“1showText()”

  1. Q_SIGNALS 與 Q_SLOTS    
  2. #  define slots      
  3. #  define signals protected      
  4. # define Q_SLOTS      
  5. # define Q_SIGNALS protected    
  6. Q_SIGNALS 與 Q_SLOTS  
  7. #  define slots   
  8. #  define signals protected   
  9. # define Q_SLOTS   
  10. # define Q_SIGNALS protected  

Q_SIGNALS 與 Q_SLOTS是Qt 4.1引入的,它們用來替換關鍵字signals和slots,原因是更好的與第三方信號槽機制兼容,比如boost庫。盡管Q_SIGNALS 與 Q_SLOTS看起來沒有做什么。其實不然,QT的元對象編譯器moc會識別聲明在頭文件中的宏Q_SIGNALS,Q_SLOTS。并做為依據,生成元對象模型數據,詳見文中***所示代碼實例

  1. Q_EMIT  
  2. #define Q_EMIT #define emit 

Q_EMIT用來替換關鍵字emit,原因也是更好的與第三方信號槽機制兼容,比如boost庫。

這里要注意,我們看到Q_EMIT看起來同樣的簡單, 但它們是有區別的!表面的區別在于Q_SIGNALS 與 Q_SLOTS用在頭文件中,而Q_EMIT用在代碼視線中。 本質的區別的在于,Q_SIGNALS 與 Q_SLOTS將被moc識別,是必須使用的。而Q_EMIT或者emit是可有可無的。它不會被moc識別,它存在的唯一理由是:增加代碼的可讀性。  也就是說如下代碼都能正常工作,但2)的寫法也許會惹怒你的同事。

  1. void method()    
  2. {    
  3.       1) emit signalA();    
  4.       2) signalA();      
  5. }    
  6. void method()  
  7. {  
  8.       1) emit signalA();  
  9.       2) signalA();    
  10. }   
  11.  
  12. Q_INVOKABLE  
  13. #define Q_INVOKABLE 

使用Q_INVOKABLE來修飾成員函數,目的在于被修飾的成員函數能夠被元對象系統所喚起。這一機制在Qt C++/QML混合編程,Qt service framework, 以及Qt/ HTML5混合編程里廣泛使用。我會隨后另撰寫一文做深入探討。

  1. Q_PROPERTY  
  2. #define Q_PROPERTY(text)    

使用Q_PROPERTY用以聲明屬性,屬性類似于成員變量,但它能夠被元對象系統所訪問。QML的屬性便是利用該機制得以實現的。 Q_PROPERTY的用法如下:

  1. Q_PROPERTY(QString title READ title WRITE setTitle USER true) 

接下來,讓我們結合代碼來看一下上述宏的使用以及元對象編譯器是如何利用這些宏的。

  1. #include <QDeclarativeItem >     
  2. class EllipseItem : public QDeclarativeItem     
  3. {     
  4.     Q_OBJECT     
  5.     Q_PROPERTY(QColor color READ color WRITE setColor NOTIFY colorChanged)    
  6. public:     
  7.     EllipseItem(QDeclarativeItem *parent = 0);     
  8.     void paint(QPainter *painter, const QStyleOptionGraphicsItem *option,     
  9.                QWidget *widget = 0);    
  10.     const QColor &color() const;     
  11.     void setColor(const QColor &newColor);    
  12.     Q_INVOKABLE QColor randomColor() const;    
  13. public Q_SLOTS:     
  14.     void try1();     
  15.     void try2() {}    
  16. Q_SIGNALS:     
  17.     void colorChanged();     
  18.     void ready();    
  19. private:     
  20.     QColor m_color;     
  21. };    
  22. #include <QDeclarativeItem > 
  23. class EllipseItem : public QDeclarativeItem   
  24. {   
  25.     Q_OBJECT   
  26.     Q_PROPERTY(QColor color READ color WRITE setColor NOTIFY colorChanged)  
  27. public:   
  28.     EllipseItem(QDeclarativeItem *parent = 0);   
  29.     void paint(QPainter *painter, const QStyleOptionGraphicsItem *option,   
  30.                QWidget *widget = 0);  
  31.     const QColor &color() const;   
  32.     void setColor(const QColor &newColor);  
  33.     Q_INVOKABLE QColor randomColor() const;  
  34. public Q_SLOTS:   
  35.     void try1();   
  36.     void try2() {}  
  37. Q_SIGNALS:   
  38.     void colorChanged();   
  39.     void ready();  
  40. private:   
  41.     QColor m_color;   
  42. }; 

以下代碼由元對象編譯器moc根據上述頭文件自動生成:

  1. static const uint qt_meta_data_EllipseItem[] = {    
  2. // content:      
  3.        5,       // revision      
  4.        0,       // classname      
  5.        0,    0, // classinfo      
  6.        5,   14, // methods      
  7.        1,   39, // properties      
  8.        0,    0, // enums/sets      
  9.        0,    0, // constructors      
  10.        0,       // flags      
  11.        2,       // signalCount     
  12. // signals: signature, parameters, type, tag, flags      
  13.       13,   12,   12,   12, 0x05,     
  14.       28,   12,   12,   12, 0x05,    
  15. // slots: signature, parameters, type, tag, flags      
  16.       36,   12,   12,   12, 0x0a,     
  17.       43,   12,   12,   12, 0x0a,    
  18. // methods: signature, parameters, type, tag, flags      
  19.       57,   12,   50,   12, 0x02,    
  20. // properties: name, type, flags      
  21.       71,   50, 0x43495103,    
  22. // properties: notify_signal_id      
  23.        0,    
  24.        0        // eod      
  25. };    
  26. static const char qt_meta_stringdata_EllipseItem[] = {     
  27.     "EllipseItem/0/0colorChanged()/0ready()/0"     
  28.     "try1()/0try2()/0QColor/0randomColor()/0"     
  29.     "color/0"     
  30. };    
  31. static const uint qt_meta_data_EllipseItem[] = {  
  32. // content:   
  33.        5,       // revision   
  34.        0,       // classname   
  35.        0,    0, // classinfo   
  36.        5,   14, // methods   
  37.        1,   39, // properties   
  38.        0,    0, // enums/sets   
  39.        0,    0, // constructors   
  40.        0,       // flags   
  41.        2,       // signalCount  
  42. // signals: signature, parameters, type, tag, flags   
  43.       13,   12,   12,   12, 0x05,   
  44.       28,   12,   12,   12, 0x05,  
  45. // slots: signature, parameters, type, tag, flags   
  46.       36,   12,   12,   12, 0x0a,   
  47.       43,   12,   12,   12, 0x0a,  
  48. // methods: signature, parameters, type, tag, flags   
  49.       57,   12,   50,   12, 0x02,  
  50. // properties: name, type, flags   
  51.       71,   50, 0x43495103,  
  52. // properties: notify_signal_id   
  53.        0,  
  54.        0        // eod   
  55. };  
  56. static const char qt_meta_stringdata_EllipseItem[] = {   
  57.     "EllipseItem/0/0colorChanged()/0ready()/0"   
  58.     "try1()/0try2()/0QColor/0randomColor()/0"   
  59.     "color/0"   
  60. };  

從上面代碼實例我們可以看到, QT的元對象編譯器moc會識別聲明在頭文件中的Q_SIGNALS,Q_SLOTS, Q_PROPERTY, Q_PROPERTY。并以此做為依據,生成了元對象數據表。在這張元對象數據表中,我們已可以看到,moc根據頭文件所聲明的定義,識別出:

兩個信號:colorChanged(), ready();      (Q_SIGNALS)

兩個槽:    try1(), try2()                          (Q_SLOTS)

五個方法,其中被標記為Q_INVOKABLE的方法randomColor()被記錄在元對象字符串數組qt_meta_stringdata_EllipseItem中。  

一個屬性:color   (Q_PROPERTY)

小結:解析關于Qt Quick宏學習教程的內容介紹完了,希望通過本文的學習能對你有所幫助!

責任編輯:zhaolei 來源: 互聯網
相關推薦

2011-07-01 14:39:08

Qt Quick

2011-08-30 15:32:08

QtQuickQML

2011-08-29 10:01:27

QTWebkit插件

2011-08-30 16:08:24

Qt4.7Qt Quick

2011-08-30 12:59:52

Qt數據庫

2011-06-10 11:24:08

Qt Quick Designer

2011-06-22 15:50:45

QT 線程

2011-07-04 11:21:59

QT Designer

2011-03-11 14:43:41

Qt-QuickQML

2011-09-06 10:36:10

QT平臺

2011-08-23 16:48:41

Lua 5.1API 函數

2011-06-20 13:23:03

Qt Quick QML

2011-06-10 11:05:05

Qt Quick QML

2011-06-20 13:05:53

Qt 4.7 Qt Quick

2011-03-03 15:32:51

Qt-Quick

2011-09-07 16:28:46

QT WidgetQWidget

2011-05-16 14:12:30

QuickWidgetQML

2011-06-24 17:22:29

Qt Quick QML

2011-09-01 14:14:00

jQuery Mobi

2011-09-01 16:01:25

Qt插件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产乱码精品一区二区三区忘忧草 | 中文字幕在线视频观看 | 久草高清视频 | 欧美精品在欧美一区二区 | 欧美日韩电影一区 | 91精品综合久久久久久五月天 | www久久| 久久久久久久久久久久久91 | 久久精品影视 | 久久久久久久久99精品 | 中文字幕91av | 99在线免费视频 | 操网站 | 国产精品福利一区二区三区 | 欧美性猛交一区二区三区精品 | 一区在线播放 | 亚洲欧美日韩精品久久亚洲区 | 欧美在线观看一区 | 91精品国产综合久久久动漫日韩 | 狠狠操电影 | 国产精品99久久久久久宅男 | 一区二区三区中文字幕 | 九九热精 | 精品视频免费 | 欧美在线a | 久久久成人精品 | 欧美激情一区二区 | 一区二区三区在线 | 欧 | 网站黄色在线 | 色综久久 | 欧美日韩视频在线 | 亚洲一av | www一级片 | 久久综合一区 | 91精品国产欧美一区二区 | 国产成人精品一区二区三区在线观看 | 成人av播放| 亚洲免费视频在线观看 | www亚洲免费国内精品 | 国产精品不卡一区二区三区 | 91久久国产综合久久 |