How to Use QPushButton/bg: 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_SimplifiedChinese|简体中文]] [[How_to_Use_QPushButton_Spanish|Spanish]] [[How_to_Use_QPushButton_Greek|Ελληνικά]]<br />[[How_to_Use_QPushButton_Russian|Русский]] | |||
= Как се използва QPushButton = | |||
== Общ преглед == | |||
Чрез "QPushButton&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qpushbutton.html могат да създават и управляват бутони. Този клас е лесен за употреба и персонализиране, поради което е сред най-популярните класове в Qt. По принцип бутона показва текст, но също така може да показва и икона. | |||
===Наследени от QAbstractButton=== | 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 === | |||
* void clicked ( bool checked = false ) | * void clicked ( bool checked = false ) | ||
Line 18: | Line 22: | ||
* void toggled ( bool checked ) | * void toggled ( bool checked ) | ||
===Наследени от QWidget=== | === Наследени от QWidget === | ||
* void customContextMenuRequested ( const QPoint & pos ) | * void customContextMenuRequested ( const QPoint & pos ) | ||
===Наследени от QObject=== | === Наследени от QObject === | ||
* void destroyed ( QObject * obj = 0 ) | * void destroyed ( QObject * obj = 0 ) | ||
==Основна употреба== | == Основна употреба == | ||
===Текст=== | === Текст === | ||
Текст на 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 | ||
===Настройване на позиция и икона=== | === Настройване на позиция и икона === | ||
To set the position and the size of the button use | 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 излючва сигнали, ако се настъпи някакво събитие. За да управлявате бутона трябва да свържете подходящия сигнал към слот: | QPushButton излючва сигнали, ако се настъпи някакво събитие. За да управлявате бутона трябва да свържете подходящия сигнал към слот: | ||
=Пример= | <code>connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));<code> | ||
= Пример = | |||
Следният прост примерен код показва как се създава и използва QPushButton. Тестван е на Qt Symbian Simulator. | Следният прост примерен код показва как се създава и използва QPushButton. Тестван е на Qt Symbian Simulator. | ||
Line 50: | 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 <QPushButton&gt; | |||
namespace Ui {<br /> class MainWindow;<br />} | |||
class MainWindow : public QMainWindow<br />{<br /> Q_OBJECT<br />public: | |||
explicit MainWindow(QWidget '''parent = 0);<br /> virtual ~MainWindow(); | |||
<br />private slots: | |||
<br /> void handleButton(); | |||
<br />private: | |||
<br /> QPushButton''' m_pButton;<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 /> //Create the button<br /> m_pButton = new QPushButton("My Button&quot;, this);<br /> //set size and location of the button<br /> m_pButton->setGeometry(QRect( QPoint(100, 100),<br /> QSize(200, 50) )); | |||
//Connect button signal to appropriate slot<br /> connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));<br />} | |||
void MainWindow::handleButton()<br />{<br /> //change the text<br /> m_pButton->setText("Example&quot;);<br /> //resize button<br /> m_pButton->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> | |||
Revision as of 11:37, 24 February 2015
[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&#40;);
}