1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=iso-8859-1">
<title>Popular Mechanics: Working With Spacers</title>
<meta name="generator" content="Adobe GoLive 4">
<link rel="HOME" href="book1.html">
<link rel="UP" title="Tutorial: Using Layout Management" href="chap4_1.html">
<link rel="PREVIOUS" title="Tutorial: Using Layout Management" href="chap4_1.html">
<link rel="NEXT" title="Useful Techniques" href="chap5_1.html">
</head>
<body class="SECT1" bgcolor="white" text="black" link="blue" vlink="#840084" alink="blue">
<div class="NAVHEADER">
<table border="0" cellpadding="0" cellspacing="0" width="100%">
<tr>
<td width="500" align="left" valign="middle"><img height="90" width="475" src="figures/title.png" border="0"></td>
<td></td>
<td align="right" valign="top"> <a href="../company/about/trolls.html">
<table border="0" cellpadding="0" cellspacing="0" width="137">
<tr>
<td><img height="100" width="100" src="figures/f001.png" border="0"></td>
<td><img height="100" width="100" src="figures/qtlogo.png" align="top" border="0"></td>
</tr>
</table>
</a></td>
</tr>
<tr>
<td width="500"><spacer type="block" width="500" height="20"></td>
<td><spacer type="block" width="42" height="20"></td>
<td><br>
</td>
</tr>
</table>
<table width="100%" border="0" cellpadding="3" cellspacing="0" bgcolor="black">
<tr>
<td width="10%" align="left" valign="bottom"> <a href="chap4_1.html"><img height="20" width="20" src="arrows/left.png" border="0"></a></td>
<td width="80%" align="center" valign="bottom"><font color="white"><b>Chapter 4. Tutorial: Using Layout Management</b></font></td>
<td width="10%" align="right" valign="bottom"> <a href="chap5_1.html"><img height="20" width="20" src="arrows/right.png" border="0"></a></td>
</tr>
</table>
</div>
<div class="SECT1">
<h1 class="SECT1"><a name="AEN825"></a>Popular Mechanics: Working With Spacers</h1>
<p>We promised you earlier that we would fix the position of the <span class="GUILABEL">Extra Cheese</span> check box by centering it. One way do to that is by using so-called <i class="EMPHASIS">spacers</i>.</p>
<p>You can think of a spacer as a spring that has the power to move a block (a widget) but not to deform it. So, if you have a row layout containing two widgets, and you put a spacer in between them, the widgets will be pushed to the left and right sides as far as possible, but they will still keep their original size. If the user makes the dialog wider, the spring will take up the additional space, and if he or she makes it smaller, the spring will shrink accordingly.</p>
<p>Perhaps you can already guess how we can use spacers to center the <span class="GUILABEL">Extra Cheese</span> check box. <a href="#FTN.AEN841" name="AEN841">[1] </a>We just put a spacer at both sides of the check box, and since the two spacers (springs) have equal strength, they will always keep the check box in the middle of the form.</p>
<p>To start from the previous, completely laid out form, you first have to break the outermost layout. Then make the <span class="GUILABEL">Extra Cheese</span> check box a bit smaller and move it a bit to the right so that there is space to the left of it.</p>
<p>Now select <span class="GUIMENU">Lay Out/Add Spacer</span> from the menu bar or click on the spacer icon (see <a href="#QT-DESIGNER-ICON-SPACER">Figure 4-11</a>), and insert two spacers left and right of the check box. When you try to insert a spacer, a tiny popup menu will open and ask you whether the spacer should be horizontal or vertical. Since we are talking about horizontal orientation here, select horizontal both times. Your form should now look roughly like the one in <a href="#QT-DESIGNER-FIG-LAYOUTTUTSTEP9">Figure 4-12</a>.</p>
<div class="FIGURE">
<a name="QT-DESIGNER-ICON-SPACER"></a>
<p><b>Figure 4-11. The spacer icon</b></p>
<p><img src="figures/spacer.png"></p>
</div>
<div class="FIGURE">
<a name="QT-DESIGNER-FIG-LAYOUTTUTSTEP9"></a>
<p><b>Figure 4-12. Inserting spacers into a form</b></p>
<p><img src="figures/layouttutstep9.png"></p>
</div>
<p>Next make a row out of the two spacers and the check box by selecting all three of them and assigning a horizontal layout. The result (see <a href="#QT-DESIGNER-FIG-LAYOUTTUTSTEP10">Figure 4-13</a>) will probably not be what you expected, but this problem will automatically go away in a minute.</p>
<div class="FIGURE">
<a name="QT-DESIGNER-FIG-LAYOUTTUTSTEP10"></a>
<p><b>Figure 4-13. Combining the spacers and the check box in a row</b></p>
<p><img src="figures/layouttutstep10.png"></p>
</div>
<p>Now re-create the outer layout that you had to break in order to be able to add the spacers: Assemble the three rows into a vertical layout that you create on the form itself. Change into test mode and see how the <span class="GUILABEL">Extra Cheese</span> check box always stays in the center (see <a href="#QT-DESIGNER-FIG-LAYOUTTUTSTEP11">Figure 4-14</a>).</p>
<div class="FIGURE">
<a name="QT-DESIGNER-FIG-LAYOUTTUTSTEP11"></a>
<p><b>Figure 4-14. The check box is always in the center</b></p>
<p><img src="figures/layouttutstep11.png"></p>
</div>
<p>Of course, there are many more things you can do with spacers. Look, for example, at the size button group. Perhaps you think that it looks ugly and that the three radio buttons should be evenly spaced across the button group. If you want this, just put spacers between the radio buttons. If you add another two spacers above the first and below the last radio button, the remaining space will be evenly distributed above, between, and below the radio buttons. Or you could decide that you want them close together but in the lower part of the button group. In this case, just use one spacer and put it on top of the radio buttons. As you can see, spacers give you a lot of possibilities.</p>
<p>There are more things you can do with layouts. We haven't really talked about grid layouts yet or about the various properties that the layout managers themselves have. You'll learn more about this in the section <a href="chap5_3.html"><i>All About Layout Management</i> in Chapter 5</a>.</p>
</div>
<h3 class="FOOTNOTES">Notes</h3>
<p>
<table border="0" class="FOOTNOTES" width="100%">
<tr>
<td align="left" valign="top" width="5%"> <a href="#AEN841" name="FTN.AEN841">[1]</a></td>
<td align="left" valign="top" width="95%">If you have used Qt layout management before without Qt Designer, you might have centered your widgets with the <tt class="LITERAL">AlignCenter</tt> parameter. This is not possible in Qt Designer; you must use the spacers in order to achieve this.</td>
</tr>
</table>
</p>
<div class="NAVFOOTER">
<br>
<br>
<table width="100%" border="0" cellpadding="3" cellspacing="0" bgcolor="black">
<tr>
<td width="33%" align="left" valign="top"> <a href="chap4_1.html"><img height="20" width="20" src="arrows/left.png" border="0"></a></td>
<td width="34%" align="center" valign="top"> <a href="book1.html"><img height="20" width="25" src="arrows/home.png" border="0"></a></td>
<td width="33%" align="right" valign="top"> <a href="chap5_1.html"><img height="20" width="20" src="arrows/right.png" border="0"></a></td>
</tr>
<tr>
<td width="33%" align="left" valign="top"><font color="white">Tutorial: Using Layout Management</font></td>
<td width="34%" align="center" valign="top"> <a href="chap4_1.html"><img height="20" width="20" src="arrows/up.png" border="0"></a></td>
<td width="33%" align="right" valign="top"><font color="white">Useful Techniques</font></td>
</tr>
</table>
</div>
</body>
</html>
|