How to Use QPushButton/ru: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
[[Category:Developing with Qt::General]] | [[Category:Developing with Qt::General]] | ||
[[Category:HowTo]] | |||
[[Category:Snippets]] | |||
[[Category:Tutorial]] | |||
[toc align_right= | [toc align_right="yes" depth="3"] | ||
'''Русский''' [[How_to_Use_QPushButton|English]] [[How_to_Use_QPushButton_Bulgarian|Български]] [[How_to_Use_QPushButton_Spanish|Spanish]] [[How_to_Use_QPushButton_SimplifiedChinese|简体中文]] [[How_to_Use_QPushButton_Greek|Ελληνικά]] | '''Русский''' [[How_to_Use_QPushButton|English]] [[How_to_Use_QPushButton_Bulgarian|Български]] [[How_to_Use_QPushButton_Spanish|Spanish]] [[How_to_Use_QPushButton_SimplifiedChinese|简体中文]] [[How_to_Use_QPushButton_Greek|Ελληνικά]] | ||
Line 9: | Line 12: | ||
== QPushButton обзор == | == QPushButton обзор == | ||
Используя | Используя "QPushButton":http://doc.qt.io/qt-5.0/qtwidgets/qpushbutton.html разработчики могут создавать и управлять кнопками. Этот класс является простым в использовании и настройке, поэтому это один из самых полезных классов в Qt. В основном кнопка отображает текст, но также может отображаться и иконка. | ||
QPushButton наследует | QPushButton наследует "QAbstractButton":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html который в свою очередь наследует "QWidget":http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html. | ||
== Сигналы == | == Сигналы == | ||
Line 34: | Line 37: | ||
=== Текст === | === Текст === | ||
Текст QPushButton может быть установлен при создании или использовании | Текст 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 также может быть установлена при создании. После создания кнопки, иконку можно изменить с помощью | Икона 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 | ||
=== Установка позиции и размера === | === Установка позиции и размера === | ||
Чтобы задать позицию и размер кнопки используйте | Чтобы задать позицию и размер кнопки используйте "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. | ||
=== Обработка сигналов кнопки === | === Обработка сигналов кнопки === | ||
Line 58: | Line 61: | ||
=== mainwindow.h === | === mainwindow.h === | ||
</code> | </code> | ||
#ifndef MAINWINDOW_H | |||
#define MAINWINDOW_H | |||
#include | #include <QtGui/QMainWindow> | ||
#include <QtGui/QPushButton> | |||
namespace Ui { | namespace Ui { | ||
class MainWindow; | |||
} | |||
class MainWindow : public QMainWindow | class MainWindow : public QMainWindow | ||
{ | |||
Q_OBJECT | |||
public: | public: | ||
explicit MainWindow(QWidget *parent = 0); | |||
virtual ~MainWindow(); | |||
private slots: | private slots: | ||
void handleButton(); | |||
private: | private: | ||
QPushButton *m_button; | |||
}; | |||
#endif // MAINWINDOW_H | #endif // MAINWINDOW_H | ||
<code> | |||
=== mainwindow.cpp === | === mainwindow.cpp === | ||
</code> | </code> | ||
#include "mainwindow.h" | |||
#include | #include <QtCore/QCoreApplication> | ||
MainWindow::MainWindow(QWidget *parent) | MainWindow::MainWindow(QWidget *parent) | ||
: QMainWindow(parent) | |||
{ | |||
// создаем кнопку | |||
m_button = new QPushButton("My Button", this); | |||
// устанавливаем размер и положение кнопки | |||
m_button->setGeometry(QRect(QPoint(100, 100), | |||
QSize(200, 50))); | |||
// подключаем сигнал к соответствующему слоту | // подключаем сигнал к соответствующему слоту | ||
connect(m_button, SIGNAL (released()), this, SLOT (handleButton())); | |||
} | |||
void MainWindow::handleButton() | void MainWindow::handleButton() | ||
{ | |||
// меняем текст | |||
m_button->setText("Example"); | |||
// изменяем размер кнопки | |||
m_button->resize(100,100); | |||
} | |||
MainWindow::~MainWindow() | MainWindow::~MainWindow() | ||
{ | |||
} | } | ||
<code> | |||
=== main.cpp === | === main.cpp === | ||
</code> | </code> | ||
#include "mainwindow.h" | |||
#include | #include <QtGui/QApplication> | ||
int main(int argc, char *argv[]) | int main(int argc, char *argv[]) | ||
{ | |||
QApplication app(argc, argv); | |||
MainWindow mainWindow; | MainWindow mainWindow; | ||
mainWindow.showMaximized(); | |||
return app.exec(); | |||
} | |||
<code> | <code> | ||
Line 104: | Line 144: | ||
== Смотрите также == | == Смотрите также == | ||
"Qt Buttons":http://developer.qt.nokia.com/wiki/Qt_Buttons | |||
"Basic Qt Programming Tutorial":http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial |
Revision as of 09:22, 25 February 2015
[toc align_right="yes" depth="3"]
Русский English Български Spanish 简体中文 Ελληνικά
Использование QPushButton
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 pressed ()
void clicked( bool checked = false )<code> *
- void toggled( bool checked )
void released ()<code> *
Унаследованные от QWidget
- void destroyed ( QObject * obj = 0 )
void customContextMenuRequested ( const QPoint & pos )<code> === Унаследованные от QObject === *
Основное использование
Текст
Текст 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
Установка позиции и размера
Чтобы задать позицию и размер кнопки используйте "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_button, 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 <QtGui/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_button;
};
- endif // MAINWINDOW_H
=== mainwindow.cpp ===
- include "mainwindow.h"
- include <QtCore/QCoreApplication>
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
{
// создаем кнопку m_button = new QPushButton("My Button", this); // устанавливаем размер и положение кнопки m_button->setGeometry(QRect(QPoint(100, 100), QSize(200, 50)));
// подключаем сигнал к соответствующему слоту
connect(m_button, SIGNAL (released()), this, SLOT (handleButton()));
}
void MainWindow::handleButton() {
// меняем текст m_button->setText("Example"); // изменяем размер кнопки m_button->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();
}
Смотрите также
"Qt Buttons":http://developer.qt.nokia.com/wiki/Qt_Buttons
"Basic Qt Programming Tutorial":http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial