How to Use QPushButton/bg: Difference between revisions
No edit summary |
AutoSpider (talk | contribs) (Add "cleanup" tag) |
||
Line 1: | Line 1: | ||
{{Cleanup | reason=Auto-imported from ExpressionEngine.}} | |||
[[Category:Developing with Qt::General]] | [[Category:Developing with Qt::General]] | ||
[[Category:HowTo]] | [[Category:HowTo]] |
Revision as of 15:48, 3 March 2015
This article may require cleanup to meet the Qt Wiki's quality standards. Reason: Auto-imported from ExpressionEngine. Please improve this article if you can. Remove the {{cleanup}} tag and add this page to Updated pages list after it's clean. |
[toc align_right="yes" depth="3"]
Български English 简体中文 Spanish Ελληνικά Русский
Как се използва QPushButton
Общ преглед
Чрез "QPushButton":http://doc.qt.io/qt-5.0/qtwidgets/qpushbutton.html могат да създават и управляват бутони. Този клас е лесен за употреба и персонализиране, поради което е сред най-популярните класове в Qt. По принцип бутона показва текст, но също така може да показва и икона.
QPushButton наследява "QAbstractButton":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html, който наследява "QWidget":http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html.
Сигнали
Наследени от QAbstractButton
- void clicked ( bool checked = false )
- void pressed ()
- void released ()
- void toggled ( bool checked )
Наследени от QWidget
- void customContextMenuRequested ( const QPoint & pos )
Наследени от QObject
- void destroyed ( QObject * obj = 0 )
Основна употреба
Текст
Текст на QPushButton може да бъде зададен при създаването му или чрез "setText()":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop. За да достъпите текста, който е сложен в момента на бутона използвайте "text()":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop.
Икона
Както текст, така и икона може да се зададе при създаване на QPushButton. След това иконата може да бъде сменете посредством "setIcon()":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#icon-prop. За да достъпите иконата, която е сложена на бутон използвайте "icon()":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#icon-prop
Настройване на позиция и икона
To set the position and the size of the button use "setGeometry()":http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#geometry-prop. Ако желаете само да промените размера на бутона използвайте "resize()":http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#size-prop.
Управление на бутона
QPushButton излючва сигнали, ако се настъпи някакво събитие. За да управлявате бутона трябва да свържете подходящия сигнал към слот:
connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));<code>
= Пример =
Следният прост примерен код показва как се създава и използва QPushButton. Тестван е на Qt Symbian Simulator.
Създава се инстанция на QPushButton. Сигналът '''released()''' се свързва със слота '''handleButton()''', който променя текста и размера на прозореца при първо натискате на бутона.
=== mainwindow.h ===
- ifndef MAINWINDOW_H
- define MAINWINDOW_H
- include <QtGui/QMainWindow>
- include <QPushButton>
namespace Ui {
class MainWindow;
}
class MainWindow : public QMainWindow {
Q_OBJECT
public:
explicit MainWindow(QWidget parent = 0);
virtual ~MainWindow();
private slots:
void handleButton();
private:
QPushButton m_pButton;
};
- endif // MAINWINDOW_H
=== mainwindow.cpp ===
- include "mainwindow.h"
- include <QtCore/QCoreApplication>
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
{
//Create the button m_pButton = new QPushButton("My Button", this); //set size and location of the button m_pButton->setGeometry(QRect( QPoint(100, 100), QSize(200, 50) ));
//Connect button signal to appropriate slot
connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));
}
void MainWindow::handleButton() {
//change the text m_pButton->setText("Example"); //resize button m_pButton->resize(100,100);
}
MainWindow::~MainWindow() {
}
=== main.cpp ===
- include "mainwindow.h"
- include <QtGui/QApplication>
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
MainWindow mainWindow;
mainWindow.showMaximized(); return app.exec();
}