summaryrefslogtreecommitdiffstats
path: root/doc/html/coordsys.html
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2011-07-10 15:24:15 -0500
committerTimothy Pearson <[email protected]>2011-07-10 15:24:15 -0500
commitbd0f3345a938b35ce6a12f6150373b0955b8dd12 (patch)
tree7a520322212d48ebcb9fbe1087e7fca28b76185c /doc/html/coordsys.html
downloadqt3-bd0f3345a938b35ce6a12f6150373b0955b8dd12.tar.gz
qt3-bd0f3345a938b35ce6a12f6150373b0955b8dd12.zip
Add Qt3 development HEAD version
Diffstat (limited to 'doc/html/coordsys.html')
-rw-r--r--doc/html/coordsys.html215
1 files changed, 215 insertions, 0 deletions
diff --git a/doc/html/coordsys.html b/doc/html/coordsys.html
new file mode 100644
index 0000000..ee84473
--- /dev/null
+++ b/doc/html/coordsys.html
@@ -0,0 +1,215 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
+<!-- /home/espenr/tmp/qt-3.3.8-espenr-2499/qt-x11-free-3.3.8/doc/coordsys.doc:36 -->
+<html>
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
+<title>The Coordinate System</title>
+<style type="text/css"><!--
+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; }
+--></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">Home</font></a>
+ | <a href="classes.html">
+<font color="#004faf">All&nbsp;Classes</font></a>
+ | <a href="mainclasses.html">
+<font color="#004faf">Main&nbsp;Classes</font></a>
+ | <a href="annotated.html">
+<font color="#004faf">Annotated</font></a>
+ | <a href="groups.html">
+<font color="#004faf">Grouped&nbsp;Classes</font></a>
+ | <a href="functions.html">
+<font color="#004faf">Functions</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>The Coordinate System</h1>
+
+
+
+<p> A <a href="qpaintdevice.html">paint device</a> in Qt is a drawable 2D
+surface. <a href="qwidget.html">QWidget</a>, <a href="qpixmap.html">QPixmap</a>, <a href="qpicture.html">QPicture</a> and <a href="qprinter.html">QPrinter</a> are all
+paint devices. A <a href="qpainter.html">QPainter</a> is an object which can draw on such
+devices.
+<p> The default coordinate system of a paint device has its origin at the
+top left corner. X increases to the right and Y increases downwards.
+The unit is one pixel on pixel-based devices and one point on
+printers.
+<p> <h2> An Example
+</h2>
+<a name="1"></a><p> The illustration below shows a highly magnified portion of the top
+left corner of a paint device.
+<p> <center><img src="coordsys.png"></center>
+<p> The rectangle and the line were drawn by this code (with the grid
+added and colors touched up in the illustration):
+<p> <pre>
+ void MyWidget::paintEvent( <a href="qpaintevent.html">QPaintEvent</a> * )
+ {
+ <a href="qpainter.html">QPainter</a> p( this );
+ p.<a href="qpainter.html#setPen">setPen</a>( darkGray );
+ p.<a href="qpainter.html#drawRect">drawRect</a>( 1,2, 5,4 );
+ p.<a href="qpainter.html#setPen">setPen</a>( lightGray );
+ p.<a href="qpainter.html#drawLine">drawLine</a>( 9,2, 7,7 );
+ }
+</pre>
+
+<p> Note that all of the pixels drawn by drawRect() are inside the size
+specified (5*4 pixels). This is different from some toolkits; in Qt
+the size you specify exactly encompasses the pixels drawn. This
+applies to all the relevant functions in <a href="qpainter.html">QPainter</a>.
+<p> Similarly, the drawLine() call draws both endpoints of the line, not
+just one.
+<p> Here are the classes that relate most closely to the coordinate
+system:
+<p> <center><table cellpadding="4" cellspacing="2" border="0">
+<tr bgcolor="#f0f0f0"> <td valign="top"><a href="qpoint.html">QPoint</a>
+<td valign="top">A single 2D point in the coordinate system. Most functions in
+Qt that deal with points can accept either a <a href="qpoint.html">QPoint</a> argument
+or two ints, for example <a href="qpainter.html#drawPoint">QPainter::drawPoint</a>().
+<tr bgcolor="#d0d0d0"> <td valign="top"><a href="qsize.html">QSize</a>
+<td valign="top">A single 2D vector. Internally, QPoint and <a href="qsize.html">QSize</a> are the same,
+but a point is not the same as a size, so both classes exist.
+Again, most functions accept either a QSize or two ints, for
+example <a href="qwidget.html#resize">QWidget::resize</a>().
+<tr bgcolor="#f0f0f0"> <td valign="top"><a href="qrect.html">QRect</a>
+<td valign="top">A 2D rectangle. Most functions accept either a <a href="qrect.html">QRect</a> or four
+ints, for example <a href="qwidget.html#setGeometry">QWidget::setGeometry</a>().
+<tr bgcolor="#d0d0d0"> <td valign="top"><a href="qregion.html">QRegion</a>
+<td valign="top">An arbitrary set of points, including all the normal set
+operations, e.g. <a href="qregion.html#intersect">QRegion::intersect</a>(), and also a less
+usual function to return a list of rectangles whose union is
+equal to the region. <a href="qregion.html">QRegion</a> is used e.g. by <a href="qpainter.html#setClipRegion">QPainter::setClipRegion</a>(), <a href="qwidget.html#repaint">QWidget::repaint</a>() and <a href="qpaintevent.html#region">QPaintEvent::region</a>().
+<tr bgcolor="#f0f0f0"> <td valign="top"><a href="qpainter.html">QPainter</a>
+<td valign="top">The class that paints. It can paint on any device with the
+same code. There are differences between devices, <a href="qprinter.html#newPage">QPrinter::newPage</a>() is a good example, but <a href="qpainter.html">QPainter</a> works the
+same way on all devices.
+<tr bgcolor="#d0d0d0"> <td valign="top"><a href="qpaintdevice.html">QPaintDevice</a>
+<td valign="top">A device on which QPainter can paint. There are two internal
+devices, both pixel-based, and two external devices, <a href="qprinter.html">QPrinter</a> and <a href="qpicture.html">QPicture</a> (which records QPainter commands to a
+file or other <a href="qiodevice.html">QIODevice</a>, and plays them back). Other
+devices can be defined.
+</table></center>
+<p> <h2> Transformations
+</h2>
+<a name="2"></a><p> Although Qt's default coordinate system works as described above, <a href="qpainter.html">QPainter</a> also supports arbitrary transformations.
+<p> This transformation engine is a three-step pipeline, closely following
+the model outlined in books such as
+<a href="http://www.amazon.com/exec/obidos/ASIN/0201848406/trolltech/t">Foley &amp; Van Dam</a> and the
+<a href="http://www.amazon.com/exec/obidos/ASIN/0201604582/trolltech/t">OpenGL Programming Guide.</a> Refer to those for in-depth
+coverage; here we give just a brief overview and an example.
+<p> The first step uses the world <a href="qwmatrix.html#TransformationMode">transformation matrix</a>. Use this matrix
+to orient and position your objects in your model. Qt provides
+methods such as <a href="qpainter.html#rotate">QPainter::rotate</a>(), <a href="qpainter.html#scale">QPainter::scale</a>(), <a href="qpainter.html#translate">QPainter::translate</a>() and so on to operate on this matrix.
+<p> <a href="qpainter.html#save">QPainter::save</a>() and <a href="qpainter.html#restore">QPainter::restore</a>() save and restore this
+matrix. You can also use <a href="qwmatrix.html">QWMatrix</a> objects, <a href="qpainter.html#worldMatrix">QPainter::worldMatrix</a>() and <a href="qpainter.html#setWorldMatrix">QPainter::setWorldMatrix</a>() to store and
+use named matrices.
+<p> The second step uses the window. The window describes the view
+boundaries in model coordinates. The matrix positions the <em>objects</em>
+and <a href="qpainter.html#setWindow">QPainter::setWindow</a>() positions the <em>window</em>, deciding what
+coordinates will be visible. (If you have 3D experience, the window
+is what's usually called projection in 3D.)
+<p> The third step uses the viewport. The viewport too, describes the view
+boundaries, but in device coordinates. The viewport and the windows
+describe the same rectangle, but in different coordinate systems.
+<p> On-screen, the default is the entire <a href="qwidget.html">QWidget</a> or <a href="qpixmap.html">QPixmap</a> where
+you are drawing, which is usually appropriate. For printing this
+function is vital, since very few printers can print over the entire
+physical page.
+<p> So each object to be drawn is transformed into model
+coordinates using <a href="qpainter.html#worldMatrix">QPainter::worldMatrix</a>(), then positioned
+on the drawing device using <a href="qpainter.html#window">QPainter::window</a>() and
+<a href="qpainter.html#viewport">QPainter::viewport</a>().
+<p> It is perfectly possible to do without one or two of the stages. If,
+for example, your goal is to draw something scaled, then just using <a href="qpainter.html#scale">QPainter::scale</a>() makes perfect sense. If your goal is to use a
+fixed-size coordinate system, <a href="qpainter.html#setWindow">QPainter::setWindow</a>() is
+ideal. And so on.
+<p> Here is a short example that uses all three mechanisms: the function
+that draws the clock face in the <a href="aclock-example.html">aclock/aclock.cpp</a> example. We
+recommend compiling and running the example before you read any
+further. In particular, try resizing the window to different sizes.
+<p>
+
+<pre> void AnalogClock::drawClock( <a href="qpainter.html">QPainter</a> *paint )
+ {
+ <a name="x2275"></a> paint-&gt;<a href="qpainter.html#save">save</a>();
+</pre>
+<p> Firstly, we save the painter's state, so that the calling function
+is guaranteed not to be disturbed by the transformations we're going
+to use.
+<p> <pre> <a name="x2277"></a> paint-&gt;<a href="qpainter.html#setWindow">setWindow</a>( -500,-500, 1000,1000 );
+</pre>
+<p> We set the model coordinate system we want a 1000*1000 window where
+0,0 is in the middle.
+<p> <pre> <a name="x2278"></a> <a href="qrect.html">QRect</a> v = paint-&gt;<a href="qpainter.html#viewport">viewport</a>();
+ <a name="x2282"></a><a name="x2279"></a> int d = QMIN( v.<a href="qrect.html#width">width</a>(), v.<a href="qrect.html#height">height</a>() );
+</pre>
+<p> The device may not be square and we want the clock to be, so we find
+its current viewport and compute its shortest side.
+<p> <pre> <a name="x2280"></a><a name="x2276"></a> paint-&gt;<a href="qpainter.html#setViewport">setViewport</a>( v.<a href="qrect.html#left">left</a>() + (v.<a href="qrect.html#width">width</a>()-d)/2,
+ <a name="x2281"></a> v.<a href="qrect.html#top">top</a>() + (v.<a href="qrect.html#height">height</a>()-d)/2, d, d );
+</pre>
+<p> Then we set a new square viewport, centered in the old one.
+<p> We're now done with our view. From this point on, when we draw in a
+1000*1000 area around 0,0, what we draw will show up in the largest
+possible square that'll fit in the output device.
+<p> Time to start drawing.
+<p> <pre> <a href="qpointarray.html">QPointArray</a> pts;
+</pre>
+<p> <em>pts</em> is just a temporary variable to hold some points.
+<p> Next come three drawing blocks, one for the hour hand, one for the
+minute hand and finally one for the clock face itself. First we draw
+the hour hand:
+<p> <pre> paint-&gt;<a href="qpainter.html#save">save</a>();
+ <a name="x2274"></a> paint-&gt;<a href="qpainter.html#rotate">rotate</a>( 30*(time.hour()%12-3) + time.minute()/2 );
+</pre>
+<p> We save the painter and then rotate it so that one axis points along
+the hour hand.
+<p> <pre> pts.setPoints( 4, -20,0, 0,-20, 300,0, 0,20 );
+ <a name="x2271"></a> paint-&gt;<a href="qpainter.html#drawConvexPolygon">drawConvexPolygon</a>( pts );
+</pre>
+<p> We set <em>pts</em> to a four-point polygon that looks like the hour hand at
+three o'clock, and draw it. Because of the rotation, it's drawn
+pointed in the right direction.
+<p> <pre> <a name="x2273"></a> paint-&gt;<a href="qpainter.html#restore">restore</a>();
+</pre>
+<p> We restore the saved painter, undoing the rotation. We could also
+call rotate( -30 ) but that might introduce rounding errors, so it's
+better to use save() and restore(). Next, the minute hand, drawn
+almost the same way:
+<p> <pre> paint-&gt;<a href="qpainter.html#save">save</a>();
+ paint-&gt;<a href="qpainter.html#rotate">rotate</a>( (time.minute()-15)*6 );
+ pts.setPoints( 4, -10,0, 0,-10, 400,0, 0,10 );
+ paint-&gt;<a href="qpainter.html#drawConvexPolygon">drawConvexPolygon</a>( pts );
+ paint-&gt;<a href="qpainter.html#restore">restore</a>();
+</pre>
+<p> The only differences are how the rotation angle is computed and the
+shape of the polygon.
+<p> The last part to be drawn is the clock face itself.
+<p> <pre> for ( int i=0; i&lt;12; i++ ) {
+ <a name="x2272"></a> paint-&gt;<a href="qpainter.html#drawLine">drawLine</a>( 440,0, 460,0 );
+ paint-&gt;<a href="qpainter.html#rotate">rotate</a>( 30 );
+ }
+</pre>
+<p> Twelve short hour lines at thirty-degree intervals. At the end of
+that, the painter is rotated in a way which isn't very useful, but
+we're done with painting so that doesn't matter.
+<p> <pre> paint-&gt;<a href="qpainter.html#restore">restore</a>();
+ }
+</pre>
+<p> The final line of the function restores the painter, so that the
+caller won't be affected by all the transformations we've done.
+<p>
+<!-- eof -->
+<p><address><hr><div align=center>
+<table width=100% cellspacing=0 border=0><tr>
+<td>Copyright &copy; 2007
+<a href="troll.html">Trolltech</a><td align=center><a href="trademarks.html">Trademarks</a>
+<td align=right><div align=right>Qt 3.3.8</div>
+</table></div></address></body>
+</html>