learnxinyminutes-docs/zh-cn/qt-cn.html.markdown
即使孤独依旧前行 587873df7f
Update zh-cn/qt-cn.html.markdown
Co-authored-by: 谭九鼎 <109224573@qq.com>
2020-10-20 23:22:15 +08:00

161 lines
4.3 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
category: tool
tool: Qt Framework
language: c++
filename: learnqt-cn.cpp
contributors:
- ["Aleksey Kholovchuk", "https://github.com/vortexxx192"]
translators:
- ["GengchenXU", "https://github.com/GengchenXU"]
lang: zh-cn
---
**Qt** Qt是一个广为人知的框架用于开发跨平台软件该软件可以在各种软件和硬件平台上运行代码几乎没有变化同时具有本机应用程序的能力和速度。虽然**Qt**最初是用*C*++,但也有其他语言的端口: *[PyQt](https://learnxinyminutes.com/docs/pyqt/)*, *QtRuby*, *PHP-Qt*, 等等.
**Qt** 非常适合使用图形用户界面 GUI 创建应用程序。本教程是关于如何用*C++*去实现。
```c++
/*
* 让我们从最经典的开始
*/
// Qt框架的所有标头均以大写字母'Q'开头
#include <QApplication>
#include <QLineEdit>
int main(int argc, char *argv[]) {
// 创建一个对象来管理应用程序范围内的资源
QApplication app(argc, argv);
// 创建行编辑widgets并在屏幕上显示
QLineEdit lineEdit("Hello world!");
lineEdit.show();
// 启动应用程序的事件循环
return app.exec();
}
```
**Qt**与 GUI 相关的部分与*widgets*及其之间的*connection*有关。
[阅读更多有关widgets的信息](http://doc.qt.io/qt-5/qtwidgets-index.html)
```c++
/*
* 让我们创建一个标签和一个按钮。
* 按下按钮时应显示一个标签。
* Qt代码本身就可以说明问题。
*/
#include <QApplication>
#include <QDialog>
#include <QVBoxLayout>
#include <QPushButton>
#include <QLabel>
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
QDialog dialogWindow;
dialogWindow.show();
// 添加垂直布局
QVBoxLayout layout;
dialogWindow.setLayout(&layout);
QLabel textLabel("Thanks for pressing that button");
layout.addWidget(&textLabel);
textLabel.hide();
QPushButton button("Press me");
layout.addWidget(&button);
// 按下按钮时显示隐藏标签
QObject::connect(&button, &QPushButton::pressed,
&textLabel, &QLabel::show);
return app.exec();
}
```
注意,*QObject :: connect*部分。 此方法用于将一个对象的*SIGNAL*连接到另一个对象的*SLOTS*。
**Signals** 会被发出当对象发生某些事情时例如当用户按下QPushButton对象时会发出*push*的信号。
**Slots** 是可以响应于接收到的信号而执行的*action*。
[阅读有关SLOTS和SIGNALS的更多信息](http://doc.qt.io/qt-5/signalsandslots.html)
接下来让我们了解到我们不仅可以使用标准的wigets而且可以通过继承扩展其行为。 让我们创建一个按钮并计算其被按下的次数。 为此,我们定义了自己的类* CounterLabel *。 由于特定的Qt体系结构必须在单独的文件中声明它。
```c++
// counterlabel.hpp
#ifndef COUNTERLABEL
#define COUNTERLABEL
#include <QLabel>
class CounterLabel : public QLabel {
Q_OBJECT // 在每个自定义wiget中必须存在的Qt定义的宏
public:
CounterLabel() : counter(0) {
setText("Counter has not been increased yet"); // QLabel方法
}
public slots:
// 将响应按钮按下而调用的操作
void increaseCounter() {
setText(QString("Counter value: %1").arg(QString::number(++counter)));
}
private:
int counter;
};
#endif // COUNTERLABEL
```
```c++
// main.cpp
// 与前面的示例几乎相同
#include <QApplication>
#include <QDialog>
#include <QVBoxLayout>
#include <QPushButton>
#include <QString>
#include "counterlabel.hpp"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
QDialog dialogWindow;
dialogWindow.show();
QVBoxLayout layout;
dialogWindow.setLayout(&layout);
CounterLabel counterLabel;
layout.addWidget(&counterLabel);
QPushButton button("Push me once more");
layout.addWidget(&button);
QObject::connect(&button, &QPushButton::pressed,
&counterLabel, &CounterLabel::increaseCounter);
return app.exec();
}
```
当然Qt框架比本教程介绍的部分要复杂得多因此请仔细阅读和练习。
## 进一步阅读
- [Qt 4.8 tutorials](http://doc.qt.io/qt-4.8/tutorials.html)
- [Qt 5 tutorials](http://doc.qt.io/qt-5/qtexamplesandtutorials.html)
祝你好运,生活愉快!