• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Zero Lee的專欄

            Qt GUI Programming Basic

             

            QT GUI PROGRAMMING BASIC

            =====================================================================

            CHAPTER1 NOTES

            =======================

            THIS CHAPTER CONTAINS 3 CASES USING QT TOOLKIT.

             

            CASE 1: HELLO QT

             

            PROGRAM CODES:

            ===============

            1 #include <qapplication.h>  

            2 #include <qlabel.h>

            3

            4 int main(int argc, char* argv[])

            5 {

            6  QApplication app(argc, argv);

            7  QLabel* label = new QLabel(“Hello Qt!”, 0);

            8  app.setMainWidget(label);

            9  label->show();

            10  return app.exec();

            11 }

             

            EXPLANATION:

            =============

            1,2 >> HEADER FILES CONTAIN THE DEFINITION OF QAPPLICATION AND QLABEL CLASSES.

            6 >> CREATE QAPPLICATION OBJECT TO MANAGE THE RESOURCE OF THIS APPLICATION. AND PARAMETERS ARE COMMAND LINE ARGUMENTS. HOWEVER, HERE CONSTRUCTOR IS ONE OF IT.

            7 >> CREATE ONE QLABEL WIDGET THAT DISPLAY “HELLO QT!”. IN QT TERM, A WIDGET IS A VISUAL ELEMENT IN A USER INTERFACE. FOR EXAMPLE, BUTTON, MENU, SCOLLBAR, AND FRAMES ARE WIDGETS. CERTAINLY, WIDGETS CAN CONTAIN OTHER WIDGETS. HERE, THIS SECOND ARGUMENT 0 MEANS THAT THE LABEL WIDGET IS ONE WINDOW IN ITS OWN RIGHT, NOT A CHILD WIDGET INSIDE ANOTHER WINDOW. CREATE ONE QLABEL OBJECT, SYNTAX:

            QLabel ( const QString & text, QWidget * parent, const char * name = 0, WFlags f = 0 );

            8 >> MAKE THE LABEL WIDGET THE APP’S MAIN WIDGET. WITHOUT A MAIN WIDGET, THE PROGRAM WOULD KEEP RUNNING IN THE BACKGROUND EVEN AFTER USER HAS CLOSED THE WINDOW.

             

            9 >> MAKE LABEL VISIBLE. SHOW FUNCTION IS NOT PUBLIC ONE OF QLABEL. IT IS INHERITED FROM QWIDGET CLASS. WIDGETS ARE ALWAYS CREATED HIDDEN, SO THAT WE CAN CUSTOMIZE THEM BEFORE SHOWING THEM.

            10 >> RETURN CONTROL OF APP TO QT. AT THIS POINT, THE PROGRAM ENTERS A KIND OF STAND-BY MODE(DEAD-LOOP), WHERE IT WAITS FOR USER ACTIONS SUCH AS MOUSE CLICKS AND KEY PRESSES.

             

            RUN RESULT:

            ===========

             

             

            =====================================================================

            CASE 2: QUIT APPLICATION

             

            PROGRAM CODES:

            ================

            1 #include <qapplication.h>

            2 #include <qpushbutton.h>

            3

            4 int main(int argc, char* argv[])

            5 {

            6   QApplication app(argc, argv);

            7   QPushButton* button = new QPushButton(“Quit”, 0);

            8   QObject::connect(button, SIGNAL(clicked()), &app, SLOT(quit()));

            9   app.setMainWidget(button);

            10 button->show();

            11 return app.exec();

            12 }

             

            EXPLANATION:

            =============

            1,2 >> HEADER FILES CONTAIN THE DEFINITION OF QAPPLICATION AND QPUSHBUTTON CLASSES.

            7 >> CREATE ONE QPUSHBUTTON OBJECT WHOSE CAPTION IS “QUIT”. HERE, CONSTRUCTOR SYNTAX IS:

            QPushButton ( const QString & text, QWidget * parent, const char * name = 0 )

            SECOND ARGUMENT 0 MEANING IS SAME AS QLABEL IN THE CASE1.

            8 >> QT’S WIDGETS EMIT SIGNALS TO INDICATE THAT A USER ACTION OR A CHANGE OF STATE HAS OCCURRED. FOR INSTANCE, HERE QPUSHBUTTON EMITS A CLICKED() SIGNAL WHEN USER CLICKS THE BUTTON. A SIGNAL CAN BE CONNECTED TO A FUNCTION (CALLED A SLOT IN THAT CONTEXT), SO THAT WHEN THE SIGNAL IS EMITTED, THE SLOT IS AUTOMATICALLY EXECUTED. HERE, WE CONNECT THE BUTTON’S CLICKED() SIGNAL TO THE QAPPLICATION OBJECT’S QUIT() SLOT. SIGNAL() AND SLOT() MACORS ARE PART OF THE SYNTAX. MORE INFO ABOUT THEIR MECHNISM, PLEASE TURN TO QT ASSISTANT.

            CONNET FUNCTION INVOKED SYNTAX:

            bool connect (const QObject * sender, const char * signal, const QObject * receiver, const char* member)

             

            RUN RESULT:

            ===========

             

             

            =====================================================================

            CASE 3: AGE APPLICATION

             

            PROGRAM CODES:

            ================

            1 #include <qapplication.h>

            2 #include <qhbox.h>

            3 #include <qslider.h>

            4 #include <qspinbox.h>

            5

            6 int main(int argc, char* argv[])

            7 {

            8   QApplication app(argc, argv);

            9   QHBox* hbox = new QHBox(0);

            10 hbox->setCaption(“Enter Your Age”);

            11 hbox->setMargin(50);

            12 hbox->setSpacing(20);

            13 

            14 QSpinBox* spinBox = new QSpinBox(hbox);

            15 QSlider* slider = new QSlider(Qt::Horizontal, hbox);

            16 spinBox->setRange(0, 130);

            17 slider->setRange(0, 130);

            18 

            19 QObject::connect(spinBox, SIGNAL(valueChanged(int)), slider, SLOT(setValue(int)));

            20 QObject::connect(slider, SIGNAL(valueChanged(int)), spinBox, SLOT(setValue(int)));

            21 spinBox->setValue(35);

            22

            23 app.setMainWidget(hbox);

            24 hbox->show();

            25

            26 return app.exec();

            27 }

             

            EXPLANATION:

            =============

            1,2,3,4 >> HEADER FILES CONTAIN DEFINITION OF QAPPLICATION, QHBOX, QSLIDER AND QSPINBOX CLASSES.

            8 >> CREATE ONE QHBOX OBJECT. THE QHBOX WIDGET PROVIDES HORIZONTAL GEOMETRY MANAGEMENT OFR ITS CHILD WIDGETS. SYNTAX:

            QHBox ( QWidget * parent = 0, const char * name = 0, WFlags f = 0 )

            11, 12 >> USE SETMARGIN() TO ADD SPACE AROUND THE EDGES, AND USE SETSPACING() TO ADD SPACE BETWEEN THE WIDGETS(SPINBOX AND SLIDER).

             UNIT: PIXEL.

             

            14, 15 >> CREATE CHILD WIDGETS IN QHBOX WIDGET. QSPINBOX AND QSLIDER.

            WHEN CREATING QSPINBOX OBJECT, INVOKE THE FOLLOWING CONSTRUCOTR:

            QSpinBox ( QWidget * parent = 0, const char * name = 0 );

            WHEN CREATING QSLIDER OBJECT, INVOKE THE FOLLOWING CONSTRUCOTR:

            QSlider ( Orientation orientation, QWidget * parent, const char * name = 0 );

            QT::ORIENTATION: THIS TYPE IS ENUMUNATION TO SIGNIFY AN OBJECT’S ORIENTATION. TWO VALUES: QT::VERTICAL AND QT::HORIZONTAL.

            19,20 >> THE TWO CONNECT() CALLS ENSURE THAT THE SPIN BOX AND THE SLIDER ARE SYNCHRONIZED SO THAT THEY ALWAYS SHOW THE SAME VALUE. WHENEVER THE VALUE OF ONE WIDGET CHANGES, ITS VALUECHANGED(INT) SIGNAL IS EMITTED, AND THE SETVALUE(INT) SLOT OF THE OTHER WIDGET IS CALLED WITH THE NEW VALUE.

             

            21 >> WHEN THE SPLIN BOX VLAUE IS SET TO 35, THE QSPINBOX EMITS THE VALUECHANGED(INT) SIGNAL WITH AN INT ARGUMENT OF 35. THIS ARGUMENT IS PASSED TO THE QSLIDER’S SETVALUE(INT) SLOT, WHICH SETS THE SLIDER VALUE TO 35. THE SLIDER THEN EMITS THE VALUECHANGED(INT) SIGNAL, BECAUSE ITS OWN VLAUE CHANGED, TRIGGERING THE SPIN BOX’S SETVALUE(INT) SLOT. BUT AT THIS POINT, SETVALUE(INT) DOESN’T EMIT ANY SIGNAL, SINCE THE SPIN BOX IS ALREADY 35. THIS PREVENTS INFINITE RECURSION. THE FOLLOWING FIRURE EXPLANS THE SITUATION:

             

            RUN RESULT:

            ============

             

            CLASSES CHART:

            ===============

            UNTILL NOW, THE CLASSES CHART:

             

             


            RESOURCE LINKS:

            ================

            1>> http://www.trolltech.com/

            2>> http://www.qtcentre.org/

            3>> http://doc.trolltech.com/4.2/examples.html#qt-tutorial

            4>> http://www.qiliang.net/qt.html

            posted on 2007-05-21 16:14 Zero Lee 閱讀(2808) 評論(0)  編輯 收藏 引用 所屬分類: CC++ Programming

            精品久久人妻av中文字幕| 精品乱码久久久久久夜夜嗨 | 99久久精品国产一区二区 | 久久久久国产成人精品亚洲午夜| 久久婷婷五月综合色99啪ak| 7777精品伊人久久久大香线蕉| 久久久久国产一区二区| 久久国产成人精品麻豆| 日日狠狠久久偷偷色综合免费| 日韩人妻无码精品久久久不卡| 国产叼嘿久久精品久久| 97久久婷婷五月综合色d啪蜜芽| 久久国产精品成人免费| 亚洲女久久久噜噜噜熟女| 777久久精品一区二区三区无码| 99久久免费国产精品特黄| 国产精品丝袜久久久久久不卡| 久久精品aⅴ无码中文字字幕重口| 久久se这里只有精品| 久久亚洲AV成人出白浆无码国产| 99久久免费只有精品国产| aaa级精品久久久国产片| 久久久久青草线蕉综合超碰 | 久久久久波多野结衣高潮| 97精品伊人久久久大香线蕉| 亚洲午夜久久久久久久久电影网| 久久天天日天天操综合伊人av| 精品久久香蕉国产线看观看亚洲 | 日本免费一区二区久久人人澡| 伊人久久综合无码成人网| 欧美粉嫩小泬久久久久久久 | 亚洲va久久久噜噜噜久久男同| 亚洲精品无码久久久| 久久久久免费视频| 色播久久人人爽人人爽人人片aV| 国产高潮国产高潮久久久91 | 99久久精品国内| 丰满少妇人妻久久久久久4| 免费观看成人久久网免费观看| 欧美伊香蕉久久综合类网站| 大美女久久久久久j久久|