📄 tutorial1-03.html
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- /home/reggie/tmp/qt-3.0-reggie-5401/qt-win-commercial-3.0.5/doc/tutorial.doc:303 -->
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta name="Translator" content="Cavendish">
<meta name="Qt zh_CN Documents Website" content="http://www.qiliang.net/qt">
<title>Qt教程一 —— 第三章:家庭价值</title>
<style type="text/css"><!--
h3.fn,span.fn { margin-left: 1cm; text-indent: -1cm; }
a:link { color: #004faf; text-decoration: none }
a:visited { color: #672967; text-decoration: none }
body { background: #ffffff; color: black; font-family: "Times New Roman" }
--></style>
</head>
<body>
<table border="0" cellpadding="0" cellspacing="0" width="100%">
<tr bgcolor="#E5E5E5">
<td valign=center>
<a href="index.html">
<font color="#004faf">主页</font></a>
| <a href="classes.html">
<font color="#004faf">所有的类</font></a>
| <a href="mainclasses.html">
<font color="#004faf">主要的类</font></a>
| <a href="annotated.html">
<font color="#004faf">注释的类</font></a>
| <a href="groups.html">
<font color="#004faf">分组的类</font></a>
| <a href="functions.html">
<font color="#004faf">函数</font></a>
</td>
<td align="right" valign="center"><img src="logo32.png" align="right" width="64" height="32" border="0"></td></tr></table>
<h1 align=center>Qt教程一 —— 第三章:家庭价值</h1>
<p> <center><img src="t3.png" alt="Screenshot of tutorial three"></center>
<p> 这个例子演示了如何创建一个父窗口部件和子窗口部件。
<p> 我们将会保持这个程序的简单性,并且只使用一个单一的父窗口部件和一个独立的子窗口部件。
<p> <pre>/****************************************************************
**
** Qt教程一 - 3
**
****************************************************************/
#include <<a href="qapplication-h.html">qapplication.h</a>>
#include <<a href="qpushbutton-h.html">qpushbutton.h</a>>
#include <<a href="qfont-h.html">qfont.h</a>>
#include <<a href="qvbox-h.html">qvbox.h</a>>
int main( int argc, char **argv )
{
<a href="qapplication.html">QApplication</a> a( argc, argv );
<a href="qvbox.html">QVBox</a> box;
box.<a href="qwidget.html#resize">resize</a>( 200, 120 );
<a href="qpushbutton.html">QPushButton</a> quit( "Quit", &box );
quit.<a href="qwidget.html#setFont">setFont</a>( QFont( "Times", 18, QFont::Bold ) );
QObject::<a href="qobject.html#connect">connect</a>( &quit, SIGNAL(<a href="qbutton.html#clicked">clicked</a>()), &a, SLOT(<a href="qapplication.html#quit">quit</a>()) );
a.<a href="qapplication.html#setMainWidget">setMainWidget</a>( &box );
box.<a href="qwidget.html#show">show</a>();
return a.<a href="qapplication.html#exec">exec</a>();
}
</pre>
<p> <h2> 一行一行地解说
</h2>
<a name="1"></a><p> <pre> #include <<a href="qvbox-h.html">qvbox.h</a>>
</pre>
<p> 我们添加了一个头文件qvbox.h用来获得我们要使用的布局类。
<p> <pre> <a href="qvbox.html">QVBox</a> box;
</pre>
<p> 这里我们简单地创建了一个垂直的盒子容器。<a href="qvbox.html">QVBox</a>把它的子窗口部件排成一个垂直的行,一个在其它的上面,根据每一个子窗口部件的<a href="qwidget.html#sizePolicy">QWidget::sizePolicy</a>()来安排空间。
<p> <pre> <a name="x2232"></a> box.<a href="qwidget.html#resize">resize</a>( 200, 120 );
</pre>
<p> 我们它的高设置为120像素,宽为200像素。
<p> <pre> <a href="qpushbutton.html">QPushButton</a> quit( "Quit", &box );
</pre>
<p> 子窗口部件产生了。
<p> <a href="qpushbutton.html">QPushButton</a>通过一个文本(“text”)和一个父窗口部件(box)生成的。子窗口部件总是放在它的父窗口部件的最顶端。当它被显示的时候,它被父窗口部件的边界挡住了一部分。
<p> 父窗口部件,QVBox,自动地把这个子窗口部件添加到它的盒子中央。因为没有其它的东西被添加了,这个按钮就获得了父窗口部件的所有空间。
<p> <pre> <a name="x2234"></a> box.<a href="qwidget.html#show">show</a>();
</pre>
<p> 当父窗口部件被显示的时候,它会调用所有子窗口部件的显示函数(除非在这些子窗口部件中你已经明确地使用<a href="qwidget.html#hide">QWidget::hide</a>())。
<p> <h2> 行为
</h2>
<a name="2"></a><p> 这个按钮不再充满整个窗口部件。相反,它获得了一个“自然的”大小。这是因为现在的这个新的顶层窗口,使用了按钮的大小提示和大小变化策略来设置这个按钮的大小和位置。(请看<a href="qwidget.html#sizeHint">QWidget::sizeHint</a>()和<a href="qwidget.html#setSizePolicy">QWidget::setSizePolicy</a>()来获得关于这几个函数的更详细的信息。)
<p> (请看<a href="tutorial1-01.html#compiling">编译</a>来学习如何创建一个makefile和连编应用程序。)
<p> <h2> 练习
</h2>
<a name="3"></a><p> 试着改变窗口的大小。按钮是如何变化的?按钮的大小变化策略是什么?如果你运行这个程序的时候使用了一个大一些的字体,按钮的高度发生了什么变化?如果你试图让这个窗口<em>真的</em>变小,发生了什么?
<p> 现在你可以进行<a href="tutorial1-04.html">第四章</a>了。
<p> [<a href="tutorial1-02.html">上一章</a>]
[<a href="tutorial1-04.html">下一章</a>]
[<a href="tutorial.html">教程一主页</a>]
<p>
<!-- eof -->
<p><address><hr><div align=center>
<table width=100% cellspacing=0 border=0><tr>
<td>Copyright © 2002
<a href="http://www.trolltech.com">Trolltech</a>
<td><a href="http://www.trolltech.com/trademarks.html">Trademarks</a>
<td><a href="zh_CN.html">译者:Cavendish</a>
<td align=right><div align=right>Qt 3.0.5版</div>
</table></div></address></body>
</html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -