Qt wiki will be updated on October 12th 2023 starting at 11:30 AM (EEST) and the maintenance will last around 2-3 hours. During the maintenance the site will be unavailable.
How to Use QPushButton/ru: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
[[Category:Developing with Qt::General]]<br />[[Category:HowTo]]<br />[[Category:Snippets]]<br />[[Category:Tutorial]] | |||
= | [toc align_right="yes&quot; depth="3&quot;] | ||
'''Русский''' [[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|Ελληνικά]] | |||
= Использование QPushButton = | |||
QPushButton | == QPushButton обзор == | ||
Используя "QPushButton&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qpushbutton.html разработчики могут создавать и управлять кнопками. Этот класс является простым в использовании и настройке, поэтому это один из самых полезных классов в Qt. В основном кнопка отображает текст, но также может отображаться и иконка. | |||
QPushButton наследует "QAbstractButton&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html который в свою очередь наследует "QWidget&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html. | |||
== | == Сигналы == | ||
===Унаследованные от | === Унаследованные от QAbstractButton === | ||
= | * <code>void clicked( bool checked = false )<code> | ||
* </code>void pressed ()</code> | |||
* <code>void released ()<code> | |||
* </code>void toggled( bool checked )</code> | |||
=== | === Унаследованные от QWidget === | ||
* <code>void customContextMenuRequested ( const QPoint & pos )<code> | |||
=== | === Унаследованные от QObject === | ||
* </code>void destroyed ( QObject * obj = 0 )</code> | |||
== | == Основное использование == | ||
=== Текст === | |||
===Обработка сигналов кнопки=== | Текст 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 высылает сигналы, если происходит событие. Для обработки сигналов кнопки необходимо подключить соответствующий сигнал к слоту. Например: | QPushButton высылает сигналы, если происходит событие. Для обработки сигналов кнопки необходимо подключить соответствующий сигнал к слоту. Например: | ||
==Пример== | <code>connect(m_button, SIGNAL (released()),this, SLOT (handleButton()));<code> | ||
== Пример == | |||
Следующий простой фрагмент кода показывает, как создавать и использовать QPushButton. Это было проверено на Qt Symbian Simulator. | Следующий простой фрагмент кода показывает, как создавать и использовать QPushButton. Это было проверено на Qt Symbian Simulator. | ||
Line 41: | Line 56: | ||
Создается экземпляр QPushButton. Сигнал '''released()''' соединятся со слотом '''handleButton()''' который изменяет текст и размер кнопки. | Создается экземпляр QPushButton. Сигнал '''released()''' соединятся со слотом '''handleButton()''' который изменяет текст и размер кнопки. | ||
===mainwindow.h=== | === mainwindow.h === | ||
</code><br />#ifndef MAINWINDOW_H<br />#define MAINWINDOW_H | |||
#include <QtGui/QMainWindow&gt;<br />#include <QtGui/QPushButton&gt; | |||
namespace Ui {<br /> class MainWindow;<br />} | |||
class MainWindow : public QMainWindow<br />{<br /> Q_OBJECT | |||
public:<br /> explicit MainWindow(QWidget *parent = 0);<br /> virtual ~MainWindow(); | |||
private slots:<br /> void handleButton(); | |||
private:<br /> QPushButton *m_button;<br />}; | |||
#endif // MAINWINDOW_H<br /><code> | |||
=== mainwindow.cpp === | |||
</code><br />#include "mainwindow.h&quot; | |||
#include <QtCore/QCoreApplication&gt; | |||
MainWindow::MainWindow(QWidget *parent)<br /> : QMainWindow(parent)<br />{<br /> // создаем кнопку<br /> m_button = new QPushButton("My Button&quot;, this);<br /> // устанавливаем размер и положение кнопки<br /> m_button->setGeometry(QRect(QPoint(100, 100),<br /> QSize(200, 50))); | |||
// подключаем сигнал к соответствующему слоту<br /> connect(m_button, SIGNAL (released()), this, SLOT (handleButton()));<br />} | |||
void MainWindow::handleButton()<br />{<br /> // меняем текст<br /> m_button->setText("Example&quot;);<br /> // изменяем размер кнопки<br /> m_button->resize(100,100);<br />} | |||
MainWindow::~MainWindow()<br />{ | |||
}<br /><code> | |||
=== main.cpp === | |||
</code><br />#include "mainwindow.h&quot; | |||
#include <QtGui/QApplication&gt; | |||
int main(int argc, char *argv[])<br />{<br /> QApplication app(argc, argv); | |||
MainWindow mainWindow;<br /> mainWindow.showMaximized();<br /> return app.exec&amp;#40;&#41;;<br />} | |||
<code> | |||
== | == Смотрите также == | ||
"Qt Buttons&quot;:http://developer.qt.nokia.com/wiki/Qt_Buttons<br />"Basic Qt Programming Tutorial&quot;:http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial | |||
Revision as of 08:53, 24 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&#40;);
}
Смотрите также
"Qt Buttons":http://developer.qt.nokia.com/wiki/Qt_Buttons
"Basic Qt Programming Tutorial":http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial