You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
584 lines
33 KiB
584 lines
33 KiB
13 years ago
|
<!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/src/opengl/qgl.cpp:1126 -->
|
||
|
<html>
|
||
|
<head>
|
||
|
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
||
|
<title>TQGLWidget Class</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 Classes</font></a>
|
||
|
| <a href="mainclasses.html">
|
||
|
<font color="#004faf">Main Classes</font></a>
|
||
|
| <a href="annotated.html">
|
||
|
<font color="#004faf">Annotated</font></a>
|
||
|
| <a href="groups.html">
|
||
|
<font color="#004faf">Grouped 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>TQGLWidget Class Reference<br><small>[<a href="opengl.html">OpenGL module</a>]</small></h1>
|
||
|
|
||
|
<p>The TQGLWidget class is a widget for rendering OpenGL graphics.
|
||
|
<a href="#details">More...</a>
|
||
|
<p><tt>#include <<a href="qgl-h.html">qgl.h</a>></tt>
|
||
|
<p>Inherits <a href="qwidget.html">TQWidget</a> and <a href="qgl.html">TQGL</a>.
|
||
|
<p><a href="qglwidget-members.html">List of all member functions.</a>
|
||
|
<h2>Public Members</h2>
|
||
|
<ul>
|
||
|
<li class=fn><a href="#TQGLWidget"><b>TQGLWidget</b></a> ( TQWidget * parent = 0, const char * name = 0, const TQGLWidget * shareWidget = 0, WFlags f = 0 )</li>
|
||
|
<li class=fn><a href="#TQGLWidget-2"><b>TQGLWidget</b></a> ( TQGLContext * context, TQWidget * parent, const char * name = 0, const TQGLWidget * shareWidget = 0, WFlags f = 0 )</li>
|
||
|
<li class=fn><a href="#TQGLWidget-3"><b>TQGLWidget</b></a> ( const TQGLFormat & format, TQWidget * parent = 0, const char * name = 0, const TQGLWidget * shareWidget = 0, WFlags f = 0 )</li>
|
||
|
<li class=fn><a href="#~TQGLWidget"><b>~TQGLWidget</b></a> ()</li>
|
||
|
<li class=fn>void <a href="#qglColor"><b>qglColor</b></a> ( const TQColor & c ) const</li>
|
||
|
<li class=fn>void <a href="#qglClearColor"><b>qglClearColor</b></a> ( const TQColor & c ) const</li>
|
||
|
<li class=fn>bool <a href="#isValid"><b>isValid</b></a> () const</li>
|
||
|
<li class=fn>bool <a href="#isSharing"><b>isSharing</b></a> () const</li>
|
||
|
<li class=fn>virtual void <a href="#makeCurrent"><b>makeCurrent</b></a> ()</li>
|
||
|
<li class=fn>void <a href="#doneCurrent"><b>doneCurrent</b></a> ()</li>
|
||
|
<li class=fn>bool <a href="#doubleBuffer"><b>doubleBuffer</b></a> () const</li>
|
||
|
<li class=fn>virtual void <a href="#swapBuffers"><b>swapBuffers</b></a> ()</li>
|
||
|
<li class=fn>TQGLFormat <a href="#format"><b>format</b></a> () const</li>
|
||
|
<li class=fn>const TQGLContext * <a href="#context"><b>context</b></a> () const</li>
|
||
|
<li class=fn>virtual TQPixmap <a href="#renderPixmap"><b>renderPixmap</b></a> ( int w = 0, int h = 0, bool useContext = FALSE )</li>
|
||
|
<li class=fn>virtual TQImage <a href="#grabFrameBuffer"><b>grabFrameBuffer</b></a> ( bool withAlpha = FALSE )</li>
|
||
|
<li class=fn>virtual void <a href="#makeOverlayCurrent"><b>makeOverlayCurrent</b></a> ()</li>
|
||
|
<li class=fn>const TQGLContext * <a href="#overlayContext"><b>overlayContext</b></a> () const</li>
|
||
|
<li class=fn>const TQGLColormap & <a href="#colormap"><b>colormap</b></a> () const</li>
|
||
|
<li class=fn>void <a href="#setColormap"><b>setColormap</b></a> ( const TQGLColormap & cmap )</li>
|
||
|
<li class=fn>void <a href="#renderText"><b>renderText</b></a> ( int x, int y, const TQString & str, const TQFont & fnt = TQFont ( ), int listBase = 2000 )</li>
|
||
|
<li class=fn>void <a href="#renderText-2"><b>renderText</b></a> ( double x, double y, double z, const TQString & str, const TQFont & fnt = TQFont ( ), int listBase = 2000 )</li>
|
||
|
</ul>
|
||
|
<h2>Public Slots</h2>
|
||
|
<ul>
|
||
|
<li class=fn>virtual void <a href="#updateGL"><b>updateGL</b></a> ()</li>
|
||
|
<li class=fn>virtual void <a href="#updateOverlayGL"><b>updateOverlayGL</b></a> ()</li>
|
||
|
</ul>
|
||
|
<h2>Static Public Members</h2>
|
||
|
<ul>
|
||
|
<li class=fn>TQImage <a href="#convertToGLFormat"><b>convertToGLFormat</b></a> ( const TQImage & img )</li>
|
||
|
</ul>
|
||
|
<h2>Protected Members</h2>
|
||
|
<ul>
|
||
|
<li class=fn>virtual void <a href="#initializeGL"><b>initializeGL</b></a> ()</li>
|
||
|
<li class=fn>virtual void <a href="#resizeGL"><b>resizeGL</b></a> ( int width, int height )</li>
|
||
|
<li class=fn>virtual void <a href="#paintGL"><b>paintGL</b></a> ()</li>
|
||
|
<li class=fn>virtual void <a href="#initializeOverlayGL"><b>initializeOverlayGL</b></a> ()</li>
|
||
|
<li class=fn>virtual void <a href="#resizeOverlayGL"><b>resizeOverlayGL</b></a> ( int width, int height )</li>
|
||
|
<li class=fn>virtual void <a href="#paintOverlayGL"><b>paintOverlayGL</b></a> ()</li>
|
||
|
<li class=fn>void <a href="#setAutoBufferSwap"><b>setAutoBufferSwap</b></a> ( bool on )</li>
|
||
|
<li class=fn>bool <a href="#autoBufferSwap"><b>autoBufferSwap</b></a> () const</li>
|
||
|
<li class=fn>virtual void <a href="#paintEvent"><b>paintEvent</b></a> ( TQPaintEvent * )</li>
|
||
|
<li class=fn>virtual void <a href="#resizeEvent"><b>resizeEvent</b></a> ( TQResizeEvent * )</li>
|
||
|
<li class=fn>virtual void <a href="#glInit"><b>glInit</b></a> ()</li>
|
||
|
<li class=fn>virtual void <a href="#glDraw"><b>glDraw</b></a> ()</li>
|
||
|
</ul>
|
||
|
<hr><a name="details"></a><h2>Detailed Description</h2>
|
||
|
|
||
|
|
||
|
The TQGLWidget class is a widget for rendering OpenGL graphics.
|
||
|
|
||
|
<p>
|
||
|
|
||
|
|
||
|
|
||
|
<p> TQGLWidget provides functionality for displaying OpenGL<sup>*</sup>
|
||
|
graphics integrated into a TQt application. It is very simple to
|
||
|
use. You inherit from it and use the subclass like any other
|
||
|
<a href="qwidget.html">TQWidget</a>, except that instead of drawing the widget's contents
|
||
|
using <a href="qpainter.html">TQPainter</a> etc. you use the standard OpenGL rendering
|
||
|
commands.
|
||
|
<p> TQGLWidget provides three convenient virtual functions that you can
|
||
|
reimplement in your subclass to perform the typical OpenGL tasks:
|
||
|
<p> <ul>
|
||
|
<li> <a href="#paintGL">paintGL</a>() - Renders the OpenGL scene. Gets called whenever the widget
|
||
|
needs to be updated.
|
||
|
<li> <a href="#resizeGL">resizeGL</a>() - Sets up the OpenGL viewport, projection, etc. Gets
|
||
|
called whenever the the widget has been resized (and also when it
|
||
|
is shown for the first time because all newly created widgets get a
|
||
|
resize event automatically).
|
||
|
<li> <a href="#initializeGL">initializeGL</a>() - Sets up the OpenGL rendering context, defines display
|
||
|
lists, etc. Gets called once before the first time resizeGL() or
|
||
|
paintGL() is called.
|
||
|
</ul>
|
||
|
<p> Here is a rough outline of how a TQGLWidget subclass might look:
|
||
|
<p> <pre>
|
||
|
class MyGLDrawer : public TQGLWidget
|
||
|
{
|
||
|
Q_OBJECT // must include this if you use TQt signals/slots
|
||
|
|
||
|
public:
|
||
|
MyGLDrawer( <a href="qwidget.html">TQWidget</a> *parent, const char *name )
|
||
|
: TQGLWidget(parent, name) {}
|
||
|
|
||
|
protected:
|
||
|
|
||
|
void initializeGL()
|
||
|
{
|
||
|
// Set up the rendering context, define display lists etc.:
|
||
|
...
|
||
|
glClearColor( 0.0, 0.0, 0.0, 0.0 );
|
||
|
glEnable(GL_DEPTH_TEST);
|
||
|
...
|
||
|
}
|
||
|
|
||
|
void resizeGL( int w, int h )
|
||
|
{
|
||
|
// setup viewport, projection etc.:
|
||
|
glViewport( 0, 0, (GLint)w, (GLint)h );
|
||
|
...
|
||
|
glFrustum( ... );
|
||
|
...
|
||
|
}
|
||
|
|
||
|
void paintGL()
|
||
|
{
|
||
|
// draw the scene:
|
||
|
...
|
||
|
glRotatef( ... );
|
||
|
glMaterialfv( ... );
|
||
|
glBegin( GL_QUADS );
|
||
|
glVertex3f( ... );
|
||
|
glVertex3f( ... );
|
||
|
...
|
||
|
glEnd();
|
||
|
...
|
||
|
}
|
||
|
|
||
|
};
|
||
|
</pre>
|
||
|
|
||
|
<p> If you need to trigger a repaint from places other than <a href="#paintGL">paintGL</a>()
|
||
|
(a typical example is when using <a href="qtimer.html">timers</a> to
|
||
|
animate scenes), you should call the widget's <a href="#updateGL">updateGL</a>() function.
|
||
|
<p> Your widget's OpenGL rendering context is made current when
|
||
|
paintGL(), <a href="#resizeGL">resizeGL</a>(), or <a href="#initializeGL">initializeGL</a>() is called. If you need to
|
||
|
call the standard OpenGL API functions from other places (e.g. in
|
||
|
your widget's constructor or in your own paint functions), you
|
||
|
must call <a href="#makeCurrent">makeCurrent</a>() first.
|
||
|
<p> TQGLWidget provides functions for requesting a new display <a href="qglformat.html">format</a> and you can also create widgets with
|
||
|
customized rendering <a href="qglcontext.html">contexts</a>.
|
||
|
<p> You can also share OpenGL display lists between TQGLWidgets (see
|
||
|
the documentation of the TQGLWidget constructors for details).
|
||
|
<p> <h3> Overlays
|
||
|
</h3>
|
||
|
<a name="1"></a><p> The TQGLWidget creates a GL overlay context in addition to the
|
||
|
normal context if overlays are supported by the underlying system.
|
||
|
<p> If you want to use overlays, you specify it in the <a href="qglformat.html">format</a>. (Note: Overlay must be requested in the format
|
||
|
passed to the TQGLWidget constructor.) Your GL widget should also
|
||
|
implement some or all of these virtual methods:
|
||
|
<p> <ul>
|
||
|
<li> <a href="#paintOverlayGL">paintOverlayGL</a>()
|
||
|
<li> <a href="#resizeOverlayGL">resizeOverlayGL</a>()
|
||
|
<li> <a href="#initializeOverlayGL">initializeOverlayGL</a>()
|
||
|
</ul>
|
||
|
<p> These methods work in the same way as the normal <a href="#paintGL">paintGL</a>() etc.
|
||
|
functions, except that they will be called when the overlay
|
||
|
context is made current. You can explicitly make the overlay
|
||
|
context current by using <a href="#makeOverlayCurrent">makeOverlayCurrent</a>(), and you can access
|
||
|
the overlay context directly (e.g. to ask for its transparent
|
||
|
color) by calling <a href="#overlayContext">overlayContext</a>().
|
||
|
<p> On X servers in which the default visual is in an overlay plane,
|
||
|
non-GL TQt windows can also be used for overlays. See the
|
||
|
examples/opengl/overlay_x11 example program for details.
|
||
|
<p> <sup>*</sup> OpenGL is a trademark of Silicon Graphics, Inc. in the
|
||
|
United States and other countries.
|
||
|
<p>See also <a href="graphics.html">Graphics Classes</a> and <a href="images.html">Image Processing Classes</a>.
|
||
|
|
||
|
<hr><h2>Member Function Documentation</h2>
|
||
|
<h3 class=fn><a name="TQGLWidget"></a>TQGLWidget::TQGLWidget ( <a href="qwidget.html">TQWidget</a> * parent = 0, const char * name = 0, const <a href="qglwidget.html">TQGLWidget</a> * shareWidget = 0, WFlags f = 0 )
|
||
|
</h3>
|
||
|
Constructs an OpenGL widget with a <em>parent</em> widget and a <em>name</em>.
|
||
|
<p> The <a href="qglformat.html#defaultFormat">default format</a> is
|
||
|
used. The widget will be <a href="#isValid">invalid</a> if the
|
||
|
system has no <a href="qglformat.html#hasOpenGL">OpenGL support</a>.
|
||
|
<p> The <em>parent</em>, <em>name</em> and <a href="qt.html#WidgetFlags">widget flag</a>, <em>f</em>, arguments are passed
|
||
|
to the <a href="qwidget.html">TQWidget</a> constructor.
|
||
|
<p> If the <em>shareWidget</em> parameter points to a valid TQGLWidget, this
|
||
|
widget will share OpenGL display lists with <em>shareWidget</em>. If
|
||
|
this widget and <em>shareWidget</em> have different <a href="#format">formats</a>, display list sharing may fail. You can check
|
||
|
whether display list sharing succeeded by calling <a href="#isSharing">isSharing</a>().
|
||
|
<p> The initialization of OpenGL rendering state, etc. should be done
|
||
|
by overriding the <a href="#initializeGL">initializeGL</a>() function, rather than in the
|
||
|
constructor of your TQGLWidget subclass.
|
||
|
<p> <p>See also <a href="qglformat.html#defaultFormat">TQGLFormat::defaultFormat</a>().
|
||
|
|
||
|
<h3 class=fn><a name="TQGLWidget-2"></a>TQGLWidget::TQGLWidget ( <a href="qglcontext.html">TQGLContext</a> * context, <a href="qwidget.html">TQWidget</a> * parent, const char * name = 0, const <a href="qglwidget.html">TQGLWidget</a> * shareWidget = 0, WFlags f = 0 )
|
||
|
</h3>
|
||
|
Constructs an OpenGL widget with parent <em>parent</em>, called <em>name</em>.
|
||
|
<p> The <em>context</em> argument is a pointer to the <a href="qglcontext.html">TQGLContext</a> that
|
||
|
you wish to be bound to this widget. This allows you to pass in
|
||
|
your own TQGLContext sub-classes.
|
||
|
<p> The widget will be <a href="#isValid">invalid</a> if the system
|
||
|
has no <a href="qglformat.html#hasOpenGL">OpenGL support</a>.
|
||
|
<p> The <em>parent</em>, <em>name</em> and <a href="qt.html#WidgetFlags">widget flag</a>, <em>f</em>, arguments are passed
|
||
|
to the <a href="qwidget.html">TQWidget</a> constructor.
|
||
|
<p> If the <em>shareWidget</em> parameter points to a valid TQGLWidget, this
|
||
|
widget will share OpenGL display lists with <em>shareWidget</em>. If
|
||
|
this widget and <em>shareWidget</em> have different <a href="#format">formats</a>, display list sharing may fail. You can check
|
||
|
whether display list sharing succeeded by calling <a href="#isSharing">isSharing</a>().
|
||
|
<p> The initialization of OpenGL rendering state, etc. should be done
|
||
|
by overriding the <a href="#initializeGL">initializeGL</a>() function, rather than in the
|
||
|
constructor of your TQGLWidget subclass.
|
||
|
<p> <p>See also <a href="qglformat.html#defaultFormat">TQGLFormat::defaultFormat</a>() and <a href="#isValid">isValid</a>().
|
||
|
|
||
|
<h3 class=fn><a name="TQGLWidget-3"></a>TQGLWidget::TQGLWidget ( const <a href="qglformat.html">TQGLFormat</a> & format, <a href="qwidget.html">TQWidget</a> * parent = 0, const char * name = 0, const <a href="qglwidget.html">TQGLWidget</a> * shareWidget = 0, WFlags f = 0 )
|
||
|
</h3>
|
||
|
Constructs an OpenGL widget with parent <em>parent</em>, called <em>name</em>.
|
||
|
<p> The <em>format</em> argument specifies the desired <a href="qglformat.html">rendering options</a>. If the underlying OpenGL/Window system
|
||
|
cannot satisfy all the features requested in <em>format</em>, the
|
||
|
nearest subset of features will be used. After creation, the
|
||
|
<a href="#format">format</a>() method will return the actual format obtained.
|
||
|
<p> The widget will be <a href="#isValid">invalid</a> if the system
|
||
|
has no <a href="qglformat.html#hasOpenGL">OpenGL support</a>.
|
||
|
<p> The <em>parent</em>, <em>name</em> and <a href="qt.html#WidgetFlags">widget flag</a>, <em>f</em>, arguments are passed
|
||
|
to the <a href="qwidget.html">TQWidget</a> constructor.
|
||
|
<p> If the <em>shareWidget</em> parameter points to a valid TQGLWidget, this
|
||
|
widget will share OpenGL display lists with <em>shareWidget</em>. If
|
||
|
this widget and <em>shareWidget</em> have different <a href="#format">formats</a>, display list sharing may fail. You can check
|
||
|
whether display list sharing succeeded by calling <a href="#isSharing">isSharing</a>().
|
||
|
<p> The initialization of OpenGL rendering state, etc. should be done
|
||
|
by overriding the <a href="#initializeGL">initializeGL</a>() function, rather than in the
|
||
|
constructor of your TQGLWidget subclass.
|
||
|
<p> <p>See also <a href="qglformat.html#defaultFormat">TQGLFormat::defaultFormat</a>() and <a href="#isValid">isValid</a>().
|
||
|
|
||
|
<h3 class=fn><a name="~TQGLWidget"></a>TQGLWidget::~TQGLWidget ()
|
||
|
</h3>
|
||
|
Destroys the widget.
|
||
|
|
||
|
<h3 class=fn>bool <a name="autoBufferSwap"></a>TQGLWidget::autoBufferSwap () const<tt> [protected]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns TRUE if the widget is doing automatic GL buffer swapping;
|
||
|
otherwise returns FALSE.
|
||
|
<p> <p>See also <a href="#setAutoBufferSwap">setAutoBufferSwap</a>().
|
||
|
|
||
|
<h3 class=fn>const <a href="qglcolormap.html">TQGLColormap</a> & <a name="colormap"></a>TQGLWidget::colormap () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns the colormap for this widget.
|
||
|
<p> Usually it is only top-level widgets that can have different
|
||
|
colormaps installed. Asking for the colormap of a child widget
|
||
|
will return the colormap for the child's top-level widget.
|
||
|
<p> If no colormap has been set for this widget, the TQColormap
|
||
|
returned will be empty.
|
||
|
<p> <p>See also <a href="#setColormap">setColormap</a>().
|
||
|
|
||
|
<h3 class=fn>const <a href="qglcontext.html">TQGLContext</a> * <a name="context"></a>TQGLWidget::context () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns the context of this widget.
|
||
|
<p> It is possible that the context is not valid (see <a href="#isValid">isValid</a>()), for
|
||
|
example, if the underlying hardware does not support the format
|
||
|
attributes that were requested.
|
||
|
|
||
|
<h3 class=fn><a href="qimage.html">TQImage</a> <a name="convertToGLFormat"></a>TQGLWidget::convertToGLFormat ( const <a href="qimage.html">TQImage</a> & img )<tt> [static]</tt>
|
||
|
</h3>
|
||
|
Converts the image <em>img</em> into the unnamed format expected by
|
||
|
OpenGL functions such as glTexImage2D(). The returned image is not
|
||
|
usable as a <a href="qimage.html">TQImage</a>, but <a href="qimage.html#width">TQImage::width</a>(), <a href="qimage.html#height">TQImage::height</a>() and
|
||
|
<a href="qimage.html#bits">TQImage::bits</a>() may be used with OpenGL. The following few lines
|
||
|
are from the texture example. Most of the code is irrelevant, so
|
||
|
we just quote the relevant bits:
|
||
|
<p>
|
||
|
|
||
|
<pre> <a href="qimage.html">TQImage</a> tex1, tex2, buf;
|
||
|
if ( !buf.load( "gllogo.bmp" ) ) { // Load first image from file
|
||
|
</pre>
|
||
|
<p> We create <em>tex1</em> (and another variable) for OpenGL, and load a real
|
||
|
image into <em>buf</em>.
|
||
|
<p> <pre> <a name="x2118"></a> tex1 = TQGLWidget::<a href="#convertToGLFormat">convertToGLFormat</a>( buf ); // flipped 32bit RGBA
|
||
|
</pre>
|
||
|
<p> A few lines later, we convert <em>buf</em> into OpenGL format and store it
|
||
|
in <em>tex1</em>.
|
||
|
<p> <pre> <a name="x2121"></a><a name="x2120"></a> glTexImage2D( GL_TEXTURE_2D, 0, 3, tex1.<a href="qimage.html#width">width</a>(), tex1.<a href="qimage.html#height">height</a>(), 0,
|
||
|
<a name="x2119"></a> GL_RGBA, GL_UNSIGNED_BYTE, tex1.<a href="qimage.html#bits">bits</a>() );
|
||
|
</pre>
|
||
|
<p> Note the dimension restrictions for texture images as described in
|
||
|
the glTexImage2D() documentation. The width must be 2^m + 2*border
|
||
|
and the height 2^n + 2*border where m and n are integers and
|
||
|
border is either 0 or 1.
|
||
|
<p> Another function in the same example uses <em>tex1</em> with OpenGL.
|
||
|
|
||
|
<p>Example: <a href="qglwidget.html#x2118">opengl/texture/gltexobj.cpp</a>.
|
||
|
<h3 class=fn>void <a name="doneCurrent"></a>TQGLWidget::doneCurrent ()
|
||
|
</h3>
|
||
|
|
||
|
<p> Makes no GL context the current context. Normally, you do not need
|
||
|
to call this function; <a href="qglcontext.html">TQGLContext</a> calls it as necessary. However,
|
||
|
it may be useful in multithreaded environments.
|
||
|
|
||
|
<h3 class=fn>bool <a name="doubleBuffer"></a>TQGLWidget::doubleBuffer () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns TRUE if the contained GL rendering context has double
|
||
|
buffering; otherwise returns FALSE.
|
||
|
<p> <p>See also <a href="qglformat.html#doubleBuffer">TQGLFormat::doubleBuffer</a>().
|
||
|
|
||
|
<h3 class=fn><a href="qglformat.html">TQGLFormat</a> <a name="format"></a>TQGLWidget::format () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns the format of the contained GL rendering context.
|
||
|
|
||
|
<h3 class=fn>void <a name="glDraw"></a>TQGLWidget::glDraw ()<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
Executes the virtual function <a href="#paintGL">paintGL</a>().
|
||
|
<p> The widget's rendering context will become the current context and
|
||
|
<a href="#initializeGL">initializeGL</a>() will be called if it hasn't already been called.
|
||
|
|
||
|
<h3 class=fn>void <a name="glInit"></a>TQGLWidget::glInit ()<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
Initializes OpenGL for this widget's context. Calls the virtual
|
||
|
function <a href="#initializeGL">initializeGL</a>().
|
||
|
|
||
|
<h3 class=fn><a href="qimage.html">TQImage</a> <a name="grabFrameBuffer"></a>TQGLWidget::grabFrameBuffer ( bool withAlpha = FALSE )<tt> [virtual]</tt>
|
||
|
</h3>
|
||
|
Returns an image of the frame buffer. If <em>withAlpha</em> is TRUE the
|
||
|
alpha channel is included.
|
||
|
<p> Depending on your hardware, you can explicitly select which color
|
||
|
buffer to grab with a glReadBuffer() call before calling this
|
||
|
function.
|
||
|
|
||
|
<h3 class=fn>void <a name="initializeGL"></a>TQGLWidget::initializeGL ()<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
This virtual function is called once before the first call to
|
||
|
<a href="#paintGL">paintGL</a>() or <a href="#resizeGL">resizeGL</a>(), and then once whenever the widget has
|
||
|
been assigned a new <a href="qglcontext.html">TQGLContext</a>. Reimplement it in a subclass.
|
||
|
<p> This function should set up any retquired OpenGL context rendering
|
||
|
flags, defining display lists, etc.
|
||
|
<p> There is no need to call <a href="#makeCurrent">makeCurrent</a>() because this has already
|
||
|
been done when this function is called.
|
||
|
|
||
|
<h3 class=fn>void <a name="initializeOverlayGL"></a>TQGLWidget::initializeOverlayGL ()<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
This virtual function is used in the same manner as <a href="#initializeGL">initializeGL</a>()
|
||
|
except that it operates on the widget's overlay context instead of
|
||
|
the widget's main context. This means that <a href="#initializeOverlayGL">initializeOverlayGL</a>()
|
||
|
is called once before the first call to <a href="#paintOverlayGL">paintOverlayGL</a>() or
|
||
|
<a href="#resizeOverlayGL">resizeOverlayGL</a>(). Reimplement it in a subclass.
|
||
|
<p> This function should set up any retquired OpenGL context rendering
|
||
|
flags, defining display lists, etc. for the overlay context.
|
||
|
<p> There is no need to call <a href="#makeOverlayCurrent">makeOverlayCurrent</a>() because this has
|
||
|
already been done when this function is called.
|
||
|
|
||
|
<h3 class=fn>bool <a name="isSharing"></a>TQGLWidget::isSharing () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns TRUE if display list sharing with another TQGLWidget was
|
||
|
requested in the constructor, and the GL system was able to
|
||
|
provide it; otherwise returns FALSE. The GL system may fail to
|
||
|
provide display list sharing if the two TQGLWidgets use different
|
||
|
formats.
|
||
|
<p> <p>See also <a href="#format">format</a>().
|
||
|
|
||
|
<h3 class=fn>bool <a name="isValid"></a>TQGLWidget::isValid () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns TRUE if the widget has a valid GL rendering context;
|
||
|
otherwise returns FALSE. A widget will be invalid if the system
|
||
|
has no <a href="qglformat.html#hasOpenGL">OpenGL support</a>.
|
||
|
|
||
|
<h3 class=fn>void <a name="makeCurrent"></a>TQGLWidget::makeCurrent ()<tt> [virtual]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Makes this widget the current widget for OpenGL operations, i.e.
|
||
|
makes the widget's rendering context the current OpenGL rendering
|
||
|
context.
|
||
|
|
||
|
<h3 class=fn>void <a name="makeOverlayCurrent"></a>TQGLWidget::makeOverlayCurrent ()<tt> [virtual]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Makes the overlay context of this widget current. Use this if you
|
||
|
need to issue OpenGL commands to the overlay context outside of
|
||
|
<a href="#initializeOverlayGL">initializeOverlayGL</a>(), <a href="#resizeOverlayGL">resizeOverlayGL</a>(), and <a href="#paintOverlayGL">paintOverlayGL</a>().
|
||
|
<p> Does nothing if this widget has no overlay.
|
||
|
<p> <p>See also <a href="#makeCurrent">makeCurrent</a>().
|
||
|
|
||
|
<h3 class=fn>const <a href="qglcontext.html">TQGLContext</a> * <a name="overlayContext"></a>TQGLWidget::overlayContext () const
|
||
|
</h3>
|
||
|
|
||
|
<p> Returns the overlay context of this widget, or 0 if this widget
|
||
|
has no overlay.
|
||
|
<p> <p>See also <a href="#context">context</a>().
|
||
|
|
||
|
<h3 class=fn>void <a name="paintEvent"></a>TQGLWidget::paintEvent ( <a href="qpaintevent.html">TQPaintEvent</a> * )<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
Handles paint events. Will cause the virtual <a href="#paintGL">paintGL</a>() function to
|
||
|
be called.
|
||
|
<p> The widget's rendering context will become the current context and
|
||
|
<a href="#initializeGL">initializeGL</a>() will be called if it hasn't already been called.
|
||
|
|
||
|
<p>Reimplemented from <a href="qwidget.html#paintEvent">TQWidget</a>.
|
||
|
<h3 class=fn>void <a name="paintGL"></a>TQGLWidget::paintGL ()<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
This virtual function is called whenever the widget needs to be
|
||
|
painted. Reimplement it in a subclass.
|
||
|
<p> There is no need to call <a href="#makeCurrent">makeCurrent</a>() because this has already
|
||
|
been done when this function is called.
|
||
|
|
||
|
<h3 class=fn>void <a name="paintOverlayGL"></a>TQGLWidget::paintOverlayGL ()<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
This virtual function is used in the same manner as <a href="#paintGL">paintGL</a>()
|
||
|
except that it operates on the widget's overlay context instead of
|
||
|
the widget's main context. This means that <a href="#paintOverlayGL">paintOverlayGL</a>() is
|
||
|
called whenever the widget's overlay needs to be painted.
|
||
|
Reimplement it in a subclass.
|
||
|
<p> There is no need to call <a href="#makeOverlayCurrent">makeOverlayCurrent</a>() because this has
|
||
|
already been done when this function is called.
|
||
|
|
||
|
<h3 class=fn>void <a name="qglClearColor"></a>TQGLWidget::qglClearColor ( const <a href="qcolor.html">TQColor</a> & c ) const
|
||
|
</h3>
|
||
|
Convenience function for specifying the clearing color to OpenGL.
|
||
|
Calls glClearColor (in RGBA mode) or glClearIndex (in color-index
|
||
|
mode) with the color <em>c</em>. Applies to the current GL context.
|
||
|
<p> <p>See also <a href="#qglColor">qglColor</a>(), <a href="qglcontext.html#currentContext">TQGLContext::currentContext</a>(), and <a href="qcolor.html">TQColor</a>.
|
||
|
|
||
|
<h3 class=fn>void <a name="qglColor"></a>TQGLWidget::qglColor ( const <a href="qcolor.html">TQColor</a> & c ) const
|
||
|
</h3>
|
||
|
Convenience function for specifying a drawing color to OpenGL.
|
||
|
Calls glColor3 (in RGBA mode) or glIndex (in color-index mode)
|
||
|
with the color <em>c</em>. Applies to the current GL context.
|
||
|
<p> <p>See also <a href="#qglClearColor">qglClearColor</a>(), <a href="qglcontext.html#currentContext">TQGLContext::currentContext</a>(), and <a href="qcolor.html">TQColor</a>.
|
||
|
|
||
|
<h3 class=fn><a href="qpixmap.html">TQPixmap</a> <a name="renderPixmap"></a>TQGLWidget::renderPixmap ( int w = 0, int h = 0, bool useContext = FALSE )<tt> [virtual]</tt>
|
||
|
</h3>
|
||
|
Renders the current scene on a pixmap and returns the pixmap.
|
||
|
<p> You can use this method on both visible and invisible TQGLWidgets.
|
||
|
<p> This method will create a pixmap and a temporary <a href="qglcontext.html">TQGLContext</a> to
|
||
|
render on the pixmap. It will then call <a href="#initializeGL">initializeGL</a>(),
|
||
|
<a href="#resizeGL">resizeGL</a>(), and <a href="#paintGL">paintGL</a>() on this context. Finally, the widget's
|
||
|
original GL context is restored.
|
||
|
<p> The size of the pixmap will be <em>w</em> pixels wide and <em>h</em> pixels
|
||
|
high unless one of these parameters is 0 (the default), in which
|
||
|
case the pixmap will have the same size as the widget.
|
||
|
<p> If <em>useContext</em> is TRUE, this method will try to be more
|
||
|
efficient by using the existing GL context to render the pixmap.
|
||
|
The default is FALSE. Only use TRUE if you understand the risks.
|
||
|
<p> Overlays are not rendered onto the pixmap.
|
||
|
<p> If the GL rendering context and the desktop have different bit
|
||
|
depths, the result will most likely look surprising.
|
||
|
<p> Note that the creation of display lists, modifications of the view
|
||
|
frustum etc. should be done from within initializeGL(). If this is
|
||
|
not done, the temporary TQGLContext will not be initialized
|
||
|
properly, and the rendered pixmap may be incomplete/corrupted.
|
||
|
|
||
|
<h3 class=fn>void <a name="renderText"></a>TQGLWidget::renderText ( int x, int y, const <a href="qstring.html">TQString</a> & str, const <a href="qfont.html">TQFont</a> & fnt = TQFont ( ), int listBase = 2000 )
|
||
|
</h3>
|
||
|
Renders the string <em>str</em> into the GL context of this widget.
|
||
|
<p> <em>x</em> and <em>y</em> are specified in window coordinates, with the origin
|
||
|
in the upper left-hand corner of the window. If <em>fnt</em> is not
|
||
|
specified, the currently set application font will be used to
|
||
|
render the string. To change the color of the rendered text you can
|
||
|
use the glColor() call (or the <a href="#qglColor">qglColor</a>() convenience function),
|
||
|
just before the <a href="#renderText">renderText</a>() call. Note that if you have
|
||
|
GL_LIGHTING enabled, the string will not appear in the color you
|
||
|
want. You should therefore switch lighting off before using
|
||
|
renderText().
|
||
|
<p> <em>listBase</em> specifies the index of the first display list that is
|
||
|
generated by this function. The default value is 2000. 256 display
|
||
|
lists will be generated, one for each of the first 256 characters
|
||
|
in the font that is used to render the string. If several fonts are
|
||
|
used in the same widget, the display lists for these fonts will
|
||
|
follow the last generated list. You would normally not have to
|
||
|
change this value unless you are using lists in the same range. The
|
||
|
lists are deleted when the widget is destroyed.
|
||
|
<p> Note: This function only works reliably with ASCII strings.
|
||
|
|
||
|
<h3 class=fn>void <a name="renderText-2"></a>TQGLWidget::renderText ( double x, double y, double z, const <a href="qstring.html">TQString</a> & str, const <a href="qfont.html">TQFont</a> & fnt = TQFont ( ), int listBase = 2000 )
|
||
|
</h3> This is an overloaded member function, provided for convenience. It behaves essentially like the above function.
|
||
|
<p> <em>x</em>, <em>y</em> and <em>z</em> are specified in scene or object coordinates
|
||
|
relative to the currently set projection and model matrices. This
|
||
|
can be useful if you want to annotate models with text labels and
|
||
|
have the labels move with the model as it is rotated etc.
|
||
|
|
||
|
<h3 class=fn>void <a name="resizeEvent"></a>TQGLWidget::resizeEvent ( <a href="qresizeevent.html">TQResizeEvent</a> * )<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Handles resize events. Calls the virtual function <a href="#resizeGL">resizeGL</a>().
|
||
|
|
||
|
<p>Reimplemented from <a href="qwidget.html#resizeEvent">TQWidget</a>.
|
||
|
<h3 class=fn>void <a name="resizeGL"></a>TQGLWidget::resizeGL ( int width, int height )<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> This virtual function is called whenever the widget has been
|
||
|
resized. The new size is passed in <em>width</em> and <em>height</em>.
|
||
|
Reimplement it in a subclass.
|
||
|
<p> There is no need to call <a href="#makeCurrent">makeCurrent</a>() because this has already
|
||
|
been done when this function is called.
|
||
|
|
||
|
<h3 class=fn>void <a name="resizeOverlayGL"></a>TQGLWidget::resizeOverlayGL ( int width, int height )<tt> [virtual protected]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> This virtual function is used in the same manner as <a href="#paintGL">paintGL</a>()
|
||
|
except that it operates on the widget's overlay context instead of
|
||
|
the widget's main context. This means that <a href="#resizeOverlayGL">resizeOverlayGL</a>() is
|
||
|
called whenever the widget has been resized. The new size is
|
||
|
passed in <em>width</em> and <em>height</em>. Reimplement it in a subclass.
|
||
|
<p> There is no need to call <a href="#makeOverlayCurrent">makeOverlayCurrent</a>() because this has
|
||
|
already been done when this function is called.
|
||
|
|
||
|
<h3 class=fn>void <a name="setAutoBufferSwap"></a>TQGLWidget::setAutoBufferSwap ( bool on )<tt> [protected]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> If <em>on</em> is TRUE automatic GL buffer swapping is switched on;
|
||
|
otherwise it is switched off.
|
||
|
<p> If <em>on</em> is TRUE and the widget is using a double-buffered format,
|
||
|
the background and foreground GL buffers will automatically be
|
||
|
swapped after each <a href="#paintGL">paintGL</a>() call.
|
||
|
<p> The buffer auto-swapping is on by default.
|
||
|
<p> <p>See also <a href="#autoBufferSwap">autoBufferSwap</a>(), <a href="#doubleBuffer">doubleBuffer</a>(), and <a href="#swapBuffers">swapBuffers</a>().
|
||
|
|
||
|
<h3 class=fn>void <a name="setColormap"></a>TQGLWidget::setColormap ( const <a href="qglcolormap.html">TQGLColormap</a> & cmap )
|
||
|
</h3>
|
||
|
|
||
|
<p> Set the colormap for this widget to <em>cmap</em>. Usually it is only
|
||
|
top-level widgets that can have colormaps installed.
|
||
|
<p> <p>See also <a href="#colormap">colormap</a>().
|
||
|
|
||
|
<h3 class=fn>void <a name="swapBuffers"></a>TQGLWidget::swapBuffers ()<tt> [virtual]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Swaps the screen contents with an off-screen buffer. This only
|
||
|
works if the widget's format specifies double buffer mode.
|
||
|
<p> Normally, there is no need to explicitly call this function
|
||
|
because it is done automatically after each widget repaint, i.e.
|
||
|
each time after <a href="#paintGL">paintGL</a>() has been executed.
|
||
|
<p> <p>See also <a href="#doubleBuffer">doubleBuffer</a>(), <a href="#setAutoBufferSwap">setAutoBufferSwap</a>(), and <a href="qglformat.html#setDoubleBuffer">TQGLFormat::setDoubleBuffer</a>().
|
||
|
|
||
|
<h3 class=fn>void <a name="updateGL"></a>TQGLWidget::updateGL ()<tt> [virtual slot]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Updates the widget by calling <a href="#glDraw">glDraw</a>().
|
||
|
|
||
|
<h3 class=fn>void <a name="updateOverlayGL"></a>TQGLWidget::updateOverlayGL ()<tt> [virtual slot]</tt>
|
||
|
</h3>
|
||
|
|
||
|
<p> Updates the widget's overlay (if any). Will cause the virtual
|
||
|
function <a href="#paintOverlayGL">paintOverlayGL</a>() to be executed.
|
||
|
<p> The widget's rendering context will become the current context and
|
||
|
<a href="#initializeGL">initializeGL</a>() will be called if it hasn't already been called.
|
||
|
|
||
|
<!-- eof -->
|
||
|
<hr><p>
|
||
|
This file is part of the <a href="index.html">TQt toolkit</a>.
|
||
|
Copyright © 1995-2007
|
||
|
<a href="http://www.trolltech.com/">Trolltech</a>. All Rights Reserved.<p><address><hr><div align=center>
|
||
|
<table width=100% cellspacing=0 border=0><tr>
|
||
|
<td>Copyright © 2007
|
||
|
<a href="troll.html">Trolltech</a><td align=center><a href="trademarks.html">Trademarks</a>
|
||
|
<td align=right><div align=right>TQt 3.3.8</div>
|
||
|
</table></div></address></body>
|
||
|
</html>
|