How to Use QPushButton/zh: 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 Bulgarian|Български]] [[How to Use QPushButton Spanish|Spanish]]<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;]


==QPushButton概览==
'''简体中文''' [[How_to_Use_QPushButton|English]] [[How_to_Use_QPushButton_Bulgarian|Български]] [[How_to_Use_QPushButton_Spanish|Spanish]]<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]'' 。
== QPushButton概览 ==


==信号==
开发人员可以使用 &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 方法来获得按钮当前的图标。


===位置和大小的设置===
=== 位置和大小的设置 ===


使用 [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]'' 方法来设置。
使用 &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_button, 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;QtGui/QPushButton&amp;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 &quot;mainwindow.h&amp;quot;
 
#include &lt;QtCore/QCoreApplication&amp;gt;
 
MainWindow::MainWindow(QWidget *parent)<br /> : QMainWindow(parent)<br />{<br /> // 创建按钮<br /> m_button = new QPushButton(&quot;My Button&amp;quot;, this);
 
// 设置按钮的大小和位置<br /> m_button-&gt;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-&gt;setText(&quot;Example&amp;quot;);
 
// 改变按钮的大小<br /> m_button-&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);


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


[http://developer.qt.nokia.com/wiki/Qt_Buttons Qt Buttons] ''[developer.qt.nokia.com]''
<code>


[http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial Basic Qt Programming Tutorial] ''[developer.qt.nokia.com]''
== 参见 ==


====欢迎讨论:====
&quot;Qt Buttons&amp;quot;:http://developer.qt.nokia.com/wiki/Qt_Buttons


[http://blog.csdn.net/qter_wd007 Qt 博客-wd007的专栏] ''[blog.csdn.net]''
&quot;Basic Qt Programming Tutorial&amp;quot;:http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial


===Categories:===
==== 欢迎讨论: ====


* [[:Category:Developing-with-Qt|Developing with Qt]]
&quot;Qt 博客-wd007的专栏&amp;quot;:http://blog.csdn.net/qter_wd007
** [[:Category:Developing-with-Qt::General|General]]
* [[:Category:HowTo|HowTo]]
* [[:Category:snippets|snippets]]
* [[:Category:Tutorial|Tutorial]]

Revision as of 09:49, 24 February 2015




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

简体中文 English Български Spanish
Русский

怎样使用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的

  • 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 方法来获得按钮当前的图标。

位置和大小的设置

使用 "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

  1. include <QtGui/QMainWindow&gt;
    #include <QtGui/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_button;
};

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

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

MainWindow::MainWindow(QWidget *parent)
 : QMainWindow(parent)
{
// 创建按钮
m_button = new QPushButton("My Button&quot;, 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&quot;);

// 改变按钮的大小
m_button->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;;
}

参见

"Qt Buttons&quot;:http://developer.qt.nokia.com/wiki/Qt_Buttons

"Basic Qt Programming Tutorial&quot;:http://developer.qt.nokia.com/wiki/Basic_Qt_Programming_Tutorial

欢迎讨论:

"Qt 博客-wd007的专栏&quot;:http://blog.csdn.net/qter_wd007