`
icheng
  • 浏览: 821617 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
文章分类
社区版块
存档分类
最新评论

WebKit -- qt4 的应用程序

 
阅读更多

记得以前学习 VB/Delphi/MFC 时,开始的例子一般是在窗口上有个按钮和文本标签。点击按钮时,文本标签上会显示一段话。这样的例子在 QT 里是怎么做呢?

在 QT 里就是 QLabel 和 QPushButton,并用 connect 把它们联系起来。先看一下头文件 helloqt2.h :

  1. #ifndefHELLO_QT2
  2. #defineHELLO_QT2
  3. #include<QDialog>
  4. classQLabel;
  5. classQPushButton;
  6. classMyEvent:publicQDialog
  7. {
  8. Q_OBJECT
  9. public:
  10. MyEvent(QWidget*parent=0);
  11. privateslots:
  12. voidbutton1Clicked();
  13. private:
  14. QLabel*m_label;
  15. QPushButton*m_button;
  16. };
  17. #endif

再看下实现体 -- helloqt2.cpp :

  1. #include<QtGui>
  2. #include<QApplication>
  3. #include"helloqt2.h"
  4. MyEvent::MyEvent(QWidget*parent)
  5. :QDialog(parent)
  6. {
  7. m_label=newQLabel(tr("label1"));
  8. m_button=newQPushButton(tr("button1"));
  9. connect(m_button,SIGNAL(clicked()),this,SLOT(button1Clicked()));
  10. QHBoxLayout*layout=newQHBoxLayout;
  11. layout->addWidget(m_button);
  12. layout->addWidget(m_label);
  13. setLayout(layout);
  14. setWindowTitle(tr("MyEvent"));
  15. }
  16. voidMyEvent::button1Clicked()
  17. {
  18. m_label->setText(tr("Goodmorning!"));
  19. }
  20. intmain(intargc,char*argv[])
  21. {
  22. QApplicationapp(argc,argv);
  23. MyEventdialog;
  24. returndialog.exec();
  25. }

关键要注意第 11 行,在这里把按钮的 click 事件和当前类的 button1Clicked() 成员函数关联了起来。而在 button1Clicked() 成员函数里可以设置标签的内容。

其它的则比较好理解,在第 8, 9 行新建了标签和按钮,在 13 - 16 行给窗口添加了一个排版的对象并把标签和按钮加入其中。在 17 行是设置窗口标题为 "MyEvent"。

依次执行如下 4 条命令进行编译运行。

  1. qmake-qt4-project
  2. qmake-qt4
  3. make
  4. ./helloqt2

出现如下窗口:

点一下 button1,显示如下图:

有意思的是,不必指定按钮或者标签的具体位置,QT会自动进行排版。可以继续进行多一点尝试,比如试着把第 13 行改成下面的样子: QVBoxLayout *layout = new QVBoxLayout;

再或者把第 8 和第 9 行前后位置换一下,再编译运行查看结果。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics