How to Use QPushButton/bg: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
(Don't #include the module prefix)
 
(6 intermediate revisions by 3 users not shown)
Line 1: Line 1:
[[Category:Developing with Qt::General]]<br />[[Category:HowTo]]<br />[[Category:Snippets]]<br />[[Category:Tutorial]]
{{Cleanup | reason=Auto-imported from ExpressionEngine.}}


[toc align_right="yes" depth="3"]
[[Category:Developing with Qt::General]]
[[Category:HowTo]]
[[Category:Snippets]]
[[Category:Tutorial]]


'''Български''' [[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|Русский]]
 
'''Български''' [[How_to_Use_QPushButton|English]] [[How_to_Use_QPushButton_SimplifiedChinese|简体中文]] [[How_to_Use_QPushButton_Spanish|Spanish]] [[How_to_Use_QPushButton_Greek|Ελληνικά]]
[[How_to_Use_QPushButton_Russian|Русский]]


= Как се използва QPushButton =
= Как се използва QPushButton =
Line 9: Line 14:
== Общ преглед ==
== Общ преглед ==


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


QPushButton наследява "QAbstractButton":http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html, който наследява "QWidget":http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html.
QPushButton наследява [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html QAbstractButton], който наследява [http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html QWidget].


== Сигнали ==
== Сигнали ==
Line 24: Line 29:
=== Наследени от QWidget ===
=== Наследени от QWidget ===


* void customContextMenuRequested ( const QPoint &amp; pos )
* void customContextMenuRequested ( const QPoint & pos )


=== Наследени от QObject ===
=== Наследени от QObject ===
Line 34: Line 39:
=== Текст ===
=== Текст ===


Текст на 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 може да бъде зададен при създаването му или чрез [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop setText()]. За да достъпите текста, който е сложен в момента на бутона използвайте [http://doc.qt.io/qt-5.0/qtwidgets/qabstractbutton.html#text-prop text()].


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


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


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


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.
To set the position and the size of the button use [http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#geometry-prop setGeometry()]. Ако желаете само да промените размера на бутона използвайте [http://doc.qt.io/qt-5.0/qtwidgets/qwidget.html#size-prop resize()].


=== Управление на бутона ===
=== Управление на бутона ===
Line 58: Line 63:
=== mainwindow.h ===
=== mainwindow.h ===


</code><br />#ifndef MAINWINDOW_H<br />#define MAINWINDOW_H
</code>
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
 
#include <QMainWindow>
#include <QPushButton>
 
namespace Ui {
class MainWindow;
}
 
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
 
explicit MainWindow(QWidget '''parent = 0);
virtual ~MainWindow();


#include <QtGui/QMainWindow><br />#include <QPushButton>
private slots:


namespace Ui {<br /> class MainWindow;<br />}
void handleButton();


class MainWindow : public QMainWindow<br />{<br /> Q_OBJECT<br />public:
private:


explicit MainWindow(QWidget '''parent = 0);<br /> virtual ~MainWindow();
QPushButton''' m_pButton;
<br />private slots:
};
<br /> void handleButton();
<br />private:
<br /> QPushButton''' m_pButton;<br />};


#endif // MAINWINDOW_H<br /><code>
#endif // MAINWINDOW_H
<code>


=== mainwindow.cpp ===
=== mainwindow.cpp ===


</code><br />#include "mainwindow.h"
</code>
#include "mainwindow.h"


#include <QtCore/QCoreApplication>
#include <QCoreApplication>


MainWindow::MainWindow(QWidget *parent)<br /> : QMainWindow(parent)<br />{<br /> //Create the button<br /> m_pButton = new QPushButton("My Button", this);<br /> //set size and location of the button<br /> m_pButton->setGeometry(QRect( QPoint(100, 100),<br /> QSize(200, 50) ));
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<br /> connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));<br />}
//Connect button signal to appropriate slot
connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));
}


void MainWindow::handleButton()<br />{<br /> //change the text<br /> m_pButton->setText("Example");<br /> //resize button<br /> m_pButton->resize(100,100);<br />}
void MainWindow::handleButton()
{
//change the text
m_pButton->setText("Example");
//resize button
m_pButton->resize(100,100);
}


MainWindow::~MainWindow()<br />{
MainWindow::~MainWindow()
{


}<br /><code>
}
<code>


=== main.cpp ===
=== main.cpp ===


</code><br />#include "mainwindow.h"
</code>
#include "mainwindow.h"


#include <QtGui/QApplication>
#include <QApplication>


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


MainWindow mainWindow;<br /> mainWindow.showMaximized();<br /> return app.exec();<br />}
MainWindow mainWindow;
mainWindow.showMaximized();
return app.exec();
}


<code>
<code>

Latest revision as of 13:26, 27 April 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.


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

Как се използва QPushButton

Общ преглед

Чрез QPushButton могат да създават и управляват бутони. Този клас е лесен за употреба и персонализиране, поради което е сред най-популярните класове в Qt. По принцип бутона показва текст, но също така може да показва и икона.

QPushButton наследява QAbstractButton, който наследява QWidget.

Сигнали

Наследени от 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(). За да достъпите текста, който е сложен в момента на бутона използвайте text().

Икона

Както текст, така и икона може да се зададе при създаване на QPushButton. След това иконата може да бъде сменете посредством setIcon(). За да достъпите иконата, която е сложена на бутон използвайте icon()

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

To set the position and the size of the button use setGeometry(). Ако желаете само да промените размера на бутона използвайте resize().

Управление на бутона

QPushButton излючва сигнали, ако се настъпи някакво събитие. За да управлявате бутона трябва да свържете подходящия сигнал към слот:

connect(m_pButton, SIGNAL (released()),this, SLOT (handleButton()));<code>

= Пример =

Следният прост примерен код показва как се създава и използва QPushButton. Тестван е на Qt Symbian Simulator.

Създава се инстанция на QPushButton. Сигналът '''released()''' се свързва със слота '''handleButton()''', който променя текста и размера на прозореца при първо натискате на бутона.

=== mainwindow.h ===
  1. ifndef MAINWINDOW_H
  2. define MAINWINDOW_H
  1. include <QMainWindow>
  2. 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;

};

  1. endif // MAINWINDOW_H
=== mainwindow.cpp ===
  1. include "mainwindow.h"
  1. include <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 ===
  1. include "mainwindow.h"
  1. include <QApplication>

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

QApplication app(argc, argv);

MainWindow mainWindow;

mainWindow.showMaximized();
return app.exec();

}