doc/src/platforms/x11overlays.qdoc
changeset 0 1918ee327afb
equal deleted inserted replaced
-1:000000000000 0:1918ee327afb
       
     1 /****************************************************************************
       
     2 **
       
     3 ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
       
     4 ** All rights reserved.
       
     5 ** Contact: Nokia Corporation (qt-info@nokia.com)
       
     6 **
       
     7 ** This file is part of the documentation of the Qt Toolkit.
       
     8 **
       
     9 ** $QT_BEGIN_LICENSE:LGPL$
       
    10 ** No Commercial Usage
       
    11 ** This file contains pre-release code and may not be distributed.
       
    12 ** You may use this file in accordance with the terms and conditions
       
    13 ** contained in the Technology Preview License Agreement accompanying
       
    14 ** this package.
       
    15 **
       
    16 ** GNU Lesser General Public License Usage
       
    17 ** Alternatively, this file may be used under the terms of the GNU Lesser
       
    18 ** General Public License version 2.1 as published by the Free Software
       
    19 ** Foundation and appearing in the file LICENSE.LGPL included in the
       
    20 ** packaging of this file.  Please review the following information to
       
    21 ** ensure the GNU Lesser General Public License version 2.1 requirements
       
    22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
       
    23 **
       
    24 ** In addition, as a special exception, Nokia gives you certain additional
       
    25 ** rights.  These rights are described in the Nokia Qt LGPL Exception
       
    26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
       
    27 **
       
    28 ** If you have questions regarding the use of this file, please contact
       
    29 ** Nokia at qt-info@nokia.com.
       
    30 **
       
    31 **
       
    32 **
       
    33 **
       
    34 **
       
    35 **
       
    36 **
       
    37 **
       
    38 ** $QT_END_LICENSE$
       
    39 **
       
    40 ****************************************************************************/
       
    41 
       
    42 /*!
       
    43     \page x11overlays.html
       
    44     \title How to Use X11 Overlays with Qt
       
    45 
       
    46     X11 overlays are a powerful mechanism for drawing
       
    47     annotations etc., on top of an image without destroying it, thus saving
       
    48     a great deal of image rendering time. For more information, see the highly
       
    49     recommended book \e{OpenGL Programming for the X Window System} (Mark
       
    50     Kilgard, Addison Wesley Developers Press 1996).
       
    51 
       
    52     \warning The Qt OpenGL Extension includes direct support for the
       
    53     use of OpenGL overlays. For many uses of overlays, this makes the
       
    54     technique described below redundant. The following is a discussion
       
    55     on how to use non-QGL widgets in overlay planes.
       
    56 
       
    57     In the typical case, X11 overlays can easily be used together with the
       
    58     current version of Qt and the Qt OpenGL Extension. The following
       
    59     requirements apply:
       
    60 
       
    61     \list 1
       
    62     \i Your X server and graphics card/hardware must support overlays.
       
    63        For many X servers, overlay support can be turned on with
       
    64        a configuration option; consult your X server installation
       
    65        documentation.
       
    66 
       
    67     \i Your X server must (be configured to) use an overlay visual as the
       
    68        default visual. Most modern X servers do this, since this has the
       
    69        added advantage that pop-up menus, overlapping windows etc., will
       
    70        \e not affect underlying images in the main plane, thereby
       
    71        avoiding expensive redraws.
       
    72 
       
    73     \i The best (deepest) visual for OpenGL rendering is in the main
       
    74        plane. This is the normal case. Typically, X servers that support
       
    75        overlays provide a 24-bit \c TrueColor visual in the main plane,
       
    76        and an 8-bit \c PseudoColor (default) visual in the overlay plane.
       
    77     \endlist
       
    78 
       
    79     Assuming that the requirements mentioned above are met, a
       
    80     QGLWidget will default to using the main plane visual, while all
       
    81     other widgets will use the overlay visual. Thus, we can place a
       
    82     normal widget on top of the QGLWidget, and do drawing on it,
       
    83     without affecting the image in the OpenGL window. In other words,
       
    84     we can use all the drawing capabilities of QPainter to draw
       
    85     annotations, rubberbands, etc. For the typical use of overlays,
       
    86     this is much easier than using OpenGL for rendering annotations.
       
    87 
       
    88     An overlay plane has a specific color called the transparent
       
    89     color. Pixels drawn in this color will not be visible; instead
       
    90     the underlying OpenGL image will show through.
       
    91 
       
    92     To use this technique, you must not use the
       
    93     QApplication::ManyColor or QApplication::TrueColor color
       
    94     specification for QApplication, because this will force the
       
    95     normal Qt widgets to use a \c TrueColor visual, which will
       
    96     typically be in the main plane, not in the overlay plane as
       
    97     desired.
       
    98 */