How to Use QPushButton/bg: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
 
No edit summary
Line 1: Line 1:
'''Български''' [[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|Русский]]
[[Category:Developing with Qt::General]]<br />[[Category:HowTo]]<br />[[Category:Snippets]]<br />[[Category:Tutorial]]


=Как се използва QPushButton=
[toc align_right=&quot;yes&amp;quot; depth=&quot;3&amp;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|Русский]]


Чрез [http://doc.qt.io/qt-5.0/qtwidgets/qpushbutton.html QPushButton] ''[qt.io]'' могат да създават и управляват бутони. Този клас е лесен за употреба и персонализиране, поради което е сред най-популярните класове в Qt. По принцип бутона показва текст, но също така може да показва и икона.
= Как се използва QPushButton =


QPushButton наследява [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html QAbstractButton] ''[qt.io]'', който наследява [http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html QWidget] ''[qt.io]''.
== Общ преглед ==


==Сигнали==
Чрез &quot;QPushButton&amp;quot;:http://doc.qt.io/qt-5.0/qtwidgets/qpushbutton.html могат да създават и управляват бутони. Този клас е лесен за употреба и персонализиране, поради което е сред най-популярните класове в Qt. По принцип бутона показва текст, но също така може да показва и икона.


===Наследени от QAbstractButton===
QPushButton наследява &quot;QAbstractButton&amp;quot;:http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html, който наследява &quot;QWidget&amp;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 &amp; pos )
* void customContextMenuRequested ( const QPoint &amp; pos )


===Наследени от QObject===
=== Наследени от QObject ===


* void destroyed ( QObject * obj = 0 )
* void destroyed ( QObject * obj = 0 )


==Основна употреба==
== Основна употреба ==


===Текст===
=== Текст ===


Текст на QPushButton може да бъде зададен при създаването му или чрез [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop setText()] ''[qt.io]''. За да достъпите текста, който е сложен в момента на бутона използвайте [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop text()] ''[qt.io]''.
Текст на QPushButton може да бъде зададен при създаването му или чрез &quot;setText()&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop. За да достъпите текста, който е сложен в момента на бутона използвайте &quot;text()&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop.


===Икона===
=== Икона ===


Както текст, така и икона може да се зададе при създаване на QPushButton. След това иконата може да бъде сменете посредством [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#icon-prop setIcon()] ''[qt.io]''. За да достъпите иконата, която е сложена на бутон използвайте [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#icon-prop icon()] ''[qt.io]''
Както текст, така и икона може да се зададе при създаване на QPushButton. След това иконата може да бъде сменете посредством &quot;setIcon()&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#icon-prop. За да достъпите иконата, която е сложена на бутон използвайте &quot;icon()&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#icon-prop


===Настройване на позиция и икона===
=== Настройване на позиция и икона ===


To set the position and the size of the button use [http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#geometry-prop setGeometry()] ''[qt.io]''. Ако желаете само да промените размера на бутона използвайте [http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#size-prop resize()] ''[qt.io]''.
To set the position and the size of the button use &quot;setGeometry()&quot;:http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#geometry-prop. Ако желаете само да промените размера на бутона използвайте &quot;resize()&quot;: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 &lt;QtGui/QMainWindow&amp;gt;<br />#include &lt;QPushButton&amp;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 &quot;mainwindow.h&amp;quot;
 
#include &lt;QtCore/QCoreApplication&amp;gt;
 
MainWindow::MainWindow(QWidget *parent)<br /> : QMainWindow(parent)<br />{<br /> //Create the button<br /> m_pButton = new QPushButton(&quot;My Button&amp;quot;, this);<br /> //set size and location of the button<br /> m_pButton-&gt;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-&gt;setText(&quot;Example&amp;quot;);<br /> //resize button<br /> m_pButton-&gt;resize(100,100);<br />}
 
MainWindow::~MainWindow()<br />{
 
}<br /><code>
 
=== main.cpp ===
 
</code><br />#include &quot;mainwindow.h&amp;quot;


===mainwindow.cpp===
#include &lt;QtGui/QApplication&amp;gt;


===main.cpp===
int main(int argc, char *argv[])<br />{<br /> QApplication app(argc, argv);


===Categories:===
MainWindow mainWindow;<br /> mainWindow.showMaximized();<br /> return app.exec&amp;amp;#40;&amp;#41;;<br />}


* [[:Category:Developing-with-Qt|Developing with Qt]]
<code>
** [[:Category:Developing-with-Qt::General|General]]
* [[:Category:HowTo|HowTo]]
* [[:Category:snippets|snippets]]
* [[:Category:Tutorial|Tutorial]]

Revision as of 11:37, 24 February 2015




[toc align_right="yes&quot; depth="3&quot;]

Български English 简体中文 Spanish Ελληνικά
Русский

Как се използва 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

  • 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

  1. include <QtGui/QMainWindow&gt;
    #include <QPushButton&gt;

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;
};

  1. endif // MAINWINDOW_H
    === mainwindow.cpp ===
    

    #include "mainwindow.h&quot;
  1. include <QtCore/QCoreApplication&gt;

MainWindow::MainWindow(QWidget *parent)
 : QMainWindow(parent)
{
//Create the button
m_pButton = new QPushButton("My Button&quot;, 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&quot;);
//resize button
m_pButton->resize(100,100);
}

MainWindow::~MainWindow()
{

}

=== main.cpp ===


#include "mainwindow.h&quot;

  1. include <QtGui/QApplication&gt;

int main(int argc, char *argv[])
{
QApplication app(argc, argv);

MainWindow mainWindow;
mainWindow.showMaximized();
return app.exec&amp;#40;&#41;;
}