[BACK]Return to SoXtGLWidget.h CVS log [TXT][DIR] Up to [Development] / inventor / libSoXt / include / Inventor / Xt

File: [Development] / inventor / libSoXt / include / Inventor / Xt / SoXtGLWidget.h (download)

Revision 1.1.1.1 (vendor branch), Tue Aug 15 12:56:27 2000 UTC (17 years, 2 months ago) by naaman
Branch: sgi, MAIN
CVS Tags: start, release-2_1_5-9, release-2_1_5-8, release-2_1_5-10, HEAD
Changes since 1.1: +0 -0 lines

Initial check-in based on 2.1.5 (SGI IRIX) source tree.

/*
 *
 *  Copyright (C) 2000 Silicon Graphics, Inc.  All Rights Reserved. 
 *
 *  This library is free software; you can redistribute it and/or
 *  modify it under the terms of the GNU Lesser General Public
 *  License as published by the Free Software Foundation; either
 *  version 2.1 of the License, or (at your option) any later version.
 *
 *  This library is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *  Lesser General Public License for more details.
 *
 *  Further, this software is distributed without any warranty that it is
 *  free of the rightful claim of any third person regarding infringement
 *  or the like.  Any license provided herein, whether implied or
 *  otherwise, applies only to this software file.  Patent licenses, if
 *  any, provided herein do not apply to combinations of this program with
 *  other software, or any other product whatsoever.
 * 
 *  You should have received a copy of the GNU Lesser General Public
 *  License along with this library; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 *  Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
 *  Mountain View, CA  94043, or:
 * 
 *  http://www.sgi.com 
 * 
 *  For further information regarding this notice, see: 
 * 
 *  http://oss.sgi.com/projects/GenInfo/NoticeExplan/
 *
 */

//  -*- C++ -*-

/*
 * Copyright (C) 1990-93   Silicon Graphics, Inc.
 *
 _______________________________________________________________________
 ______________  S I L I C O N   G R A P H I C S   I N C .  ____________
 |
 |   $Revision: 1.1.1.1 $
 |
 |   Description:
 |	This is a c++ wrapper for the Glx mixed mode widget.
 |
 |   Author(s): Alain Dumesny, David Mott
 |
 ______________  S I L I C O N   G R A P H I C S   I N C .  ____________
 _______________________________________________________________________
 */

#ifndef _SO_XT_GL_WIDGET_H_
#define _SO_XT_GL_WIDGET_H_

#include <X11/Intrinsic.h>
#include <GL/glx.h>
#include <Inventor/Xt/SoXtComponent.h>

// C-api: end
/*
 * Defines used when specifying the glModes flag to the constructor.
 * (used instead of the glx.h defines which do overlap)
 */
#define SO_GLX_RGB	(1<<0)
#define SO_GLX_DOUBLE	(1<<1)
#define SO_GLX_ZBUFFER	(1<<2)
#define SO_GLX_OVERLAY	(1<<3)
#define SO_GLX_STEREO	(1<<4)
// C-api: begin


//////////////////////////////////////////////////////////////////////////////
//
//  Class: SoXtGLWidget
//
//
//////////////////////////////////////////////////////////////////////////////

// C-api: abstract
class SoXtGLWidget : public SoXtComponent {
  public:
    
    //
    // Get the current normal and overlay GLX windows, which are needed
    // as arguments to glXMakeCurrent() when doing drawing in the normal 
    // or overlay planes.
    //
    // NOTE: These should NOT be cached by users because these will 
    // change dynamically when the visual is changed (like when
    // setDoubleBuffer() is called).
    //
    // C-api: name=getNormWin
    Window  	getNormalWindow();
    // C-api: name=getOverWin
    Window   	getOverlayWindow();
    
    // C-api: name=getNormCtx
    GLXContext	getNormalContext()     	    { return ctxNormal; }
    // C-api: name=getOverCtx
    GLXContext	getOverlayContext()    	    { return ctxOverlay; }
    
    // C-api: name=getNormWidget
    Widget	getNormalWidget()     	    { return (glModes & SO_GLX_DOUBLE) ? doubleBufferWidget : singleBufferWidget; }
    // C-api: name=getOverWidget
    Widget	getOverlayWidget()    	    { return overlayWidget; }
    
    //
    // Specify exactly what the visual should be for the normal and overlay
    // window. This allows the user to create all possible visuals supported 
    // by OpenGL. The XVisualInfo structure should be a valid OpenGL visual
    // returned by glXChooseVisual().
    //
    // C-api: expose
    // C-api: name=setNormVis
    virtual void    setNormalVisual(XVisualInfo *vis);
    // C-api: name=getNormVis
    XVisualInfo *   getNormalVisual();
    // C-api: expose
    // C-api: name=setOverVis
    virtual void    setOverlayVisual(XVisualInfo *vis);
    // C-api: name=getOverVis
    XVisualInfo *   getOverlayVisual();
    
    //
    // Routine which allows to dynamically change between single and
    // double buffering.
    //
    // C-api: expose
    // C-api: name=setDblBuf
    virtual void    setDoubleBuffer(SbBool onOrOff);
    // C-api: name=isDblBuf
    SbBool  	    isDoubleBuffer()  	    { return (glModes & SO_GLX_DOUBLE); }
    
    //
    // shows/hides a border of thickness 3 around the glx widgets. This
    // if OFF by default, but turned on by the render area.
    //
    void	setBorder(SbBool onOrOff);
    SbBool	isBorder() const	    { return borderSize != 0; }
    
    //
    // Inventor 2.1 changed the behavior of double buffered windows to
    // redraw temporary to the front buffer when an expose event is received
    // or when a new sceneGraph() is set on an SoXtRenderArea. This does not
    // apply for general interactive rendering. The idea is that it is 
    // better to see something redraw (especially if it is slow) than
    // to see garbage in the window (in the expose case) or an old invalid 
    // scene graph (in the SoXtRenderArea::setSceneGraph() case).
    //
    // This API enables you to turn this functionality OFF if for some reason
    // you are unable to prevent repeated expose from causing a redraw (which
    // is bad and should be fixed, as it gets worse for large scenes). 
    // This will be the case for example if you can't create a pulldown 
    // menu in the popup planes.
    //
    // NOTE: this api might be removed in some future releases and is only
    // intended as a porting help for Inventor 2.0 to 2.1
    //
    // C-api: name=setDrwFrontBuf
    void	setDrawToFrontBufferEnable(SbBool enableFlag);
    // C-api: name=isDrwFrontBuf
    SbBool	isDrawToFrontBufferEnable() const   { return enableDrawToFrontBuffer; }
    
  protected:
    
    // Subclasses can pass in a bitwise OR specifying the GL modes
    // (e.g. SO_GLX_RGB | SO_GLX_DOUBLE | SO_GLX_ZBUFFER | SO_GLX_OVERLAY)
    // If buildNow is FALSE, this will not build its widget tree until
    // buildWidget() is explicity called; else, buildWidget() is called here.
    SoXtGLWidget(
	    Widget parent = NULL,
	    const char *name = NULL, 
	    SbBool buildInsideParent = TRUE, 
	    int glModes = SO_GLX_RGB, 
	    SbBool buildNow = TRUE);
    virtual ~SoXtGLWidget();
    
    // subclasses MUST redefine redraw() to draw in the normal bit planes.
    // redrawOverlay() should be defined if the overlay planes are being
    // used, and processEvent() should be defined if X events are being 
    // received (see eventMask).
    virtual void	redraw() = 0;
    virtual void	redrawOverlay();
    virtual void	processEvent(XAnyEvent *anyevent);
    
    // subclasses can redefine these to do something useful.
    // initGraphic() is called whenever a GLX window gets created
    // sizeChanged() is called whenever the window changes size
    // widgetChanged() is called whenever the widget is changed (i.e. at
    //    initialization or after switching from single->double buffer)
    virtual void	initGraphic();
    virtual void	initOverlayGraphic();
    virtual void	sizeChanged(const SbVec2s &newSize);
    virtual void	widgetChanged(Widget newWidget);
    
    // sets/gets the size of the glx widget(s) - Note this size could be
    // different from the SoXtComponent::getSize() method which return
    // the size of the component, not necessary the same as the glx widget
    // window (because of extra stuff like the decoration in the viewers).
    void		setGlxSize(SbVec2s newSize);
    const SbVec2s &	getGlxSize() const			{ return glxSize; }
    
    // subclasses can use this routine as the event handler for any
    // devices they wish to get input from.
    static void eventHandler(Widget, SoXtGLWidget *, XAnyEvent *, Boolean *);
    
    // set/get stereo buffering visual. This routine (like setDoubleBuffer)
    // can be called interactively, althought slower since a new window
    // with the needed visual is always created on the fly.
    void		setStereoBuffer(SbBool flag);
    SbBool		isStereoBuffer()  { return (glModes & SO_GLX_STEREO); }
    
    // returns TRUE if main window is in rgb mode (FALSE if color index)
    SbBool		isRGBMode()	    { return (glModes & SO_GLX_RGB); }
    
    // returns the display lists share group for given context:
    int			getDisplayListShareGroup(GLXContext ctx);

    Colormap	    	colorMap;	// set when color index is used
    Colormap	    	overlayColorMap; // set when overlay is used
    SbBool		waitForExpose;	// prevent redraws until an expose is received
    SbBool		drawToFrontBuffer; // used by RA to draw new scenes to front buffer
    
    // make those methods protected to enable the SoXtRenderArea to use them
    // directly when it needs to build the widget and get its resources.
    Widget		buildWidget(Widget parent);
    Widget		getGlxMgrWidget()		{ return mgrWidget; }
    
  private:
    // local vars
    Widget		mgrWidget;
    Widget  	    	doubleBufferWidget, singleBufferWidget, overlayWidget;
    GLXContext		ctxNormal, ctxOverlay, ctxSingle, ctxDouble;
    SbVec2s		glxSize; // size of glx widgets which is always up to date
    int			*attribList;
    int			glModes;
    int			borderSize;
    SbBool		enableDrawToFrontBuffer;
    
    // specify if sizeChanged() should be called when an expose event
    // is received (as opposed to when a resize event is received, where
    // the window hasn't yet been maped to the new size).
    // ??? a GlxDraw bug ?
    SbBool		windowResized;
    
    // creates a GLX widget of the correct current type and get the current
    // set of windows, color maps, etc...
    void  	    	buildNormalGLXWidget(XVisualInfo *vis = NULL);
    void		buildOverlayGLXWidget(XVisualInfo *vis = NULL);
    void		destroyNormalWindows();
    void		destroyGLXWidget(Widget &w, GLXContext &ctx, SbBool normalWindow);
    
    // callbacks from glx widget
    static void	ginitCB(Widget, SoXtGLWidget *, XtPointer);
    static void	overlayGinitCB(Widget, SoXtGLWidget *, XtPointer);
    static void	exposeCB(Widget, SoXtGLWidget *, XtPointer);
    static void	overlayExposeCB(Widget, SoXtGLWidget *, XtPointer);
    static void	resizeCB(Widget, SoXtGLWidget *, XtPointer);
};


#endif // _SO_XT_GL_WIDGET_H_