1998-10-20 00:46:58 +04:00
|
|
|
//
|
2005-02-25 00:55:12 +03:00
|
|
|
// "$Id$"
|
1998-10-20 00:46:58 +04:00
|
|
|
//
|
|
|
|
// OpenGL definitions for the Fast Light Tool Kit (FLTK).
|
|
|
|
//
|
2009-01-02 00:28:26 +03:00
|
|
|
// Copyright 1998-2009 by Bill Spitzak and others.
|
1998-10-20 00:46:58 +04:00
|
|
|
//
|
|
|
|
// This library is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Library General Public
|
|
|
|
// License as published by the Free Software Foundation; either
|
|
|
|
// version 2 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
|
|
|
|
// Library General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Library 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.
|
|
|
|
//
|
2001-03-14 20:20:02 +03:00
|
|
|
// Please report all bugs and problems to "fltk-bugs@easysw.com".
|
1998-10-20 00:46:58 +04:00
|
|
|
//
|
1998-10-06 22:21:25 +04:00
|
|
|
|
1998-10-20 00:46:58 +04:00
|
|
|
// Internal interface to set up OpenGL.
|
|
|
|
//
|
2001-03-14 20:20:02 +03:00
|
|
|
// A "Fl_Gl_Choice" is created from an OpenGL mode and holds information
|
|
|
|
// necessary to create a window (on X) and to create an OpenGL "context"
|
|
|
|
// (on both X and Win32).
|
|
|
|
//
|
|
|
|
// fl_create_gl_context takes a window (necessary only on Win32) and an
|
|
|
|
// Fl_Gl_Choice and returns a new OpenGL context. All contexts share
|
|
|
|
// display lists with each other.
|
|
|
|
//
|
|
|
|
// On X another fl_create_gl_context is provided to create it for any
|
|
|
|
// X visual.
|
|
|
|
//
|
|
|
|
// fl_set_gl_context makes the given OpenGL context current and makes
|
|
|
|
// it draw into the passed window. It tracks the current one context
|
|
|
|
// to avoid calling the context switching code when the same context
|
|
|
|
// is used, though it is a mystery to me why the GLX/WGL libraries
|
|
|
|
// don't do this themselves...
|
|
|
|
//
|
|
|
|
// fl_no_gl_context clears that cache so the next fl_set_gl_context is
|
|
|
|
// guaranteed to work.
|
|
|
|
//
|
|
|
|
// fl_delete_gl_context destroys the context.
|
|
|
|
//
|
|
|
|
// This code is used by Fl_Gl_Window, gl_start(), and gl_visual()
|
1998-10-06 22:21:25 +04:00
|
|
|
|
|
|
|
#ifndef Fl_Gl_Choice_H
|
|
|
|
#define Fl_Gl_Choice_H
|
|
|
|
|
2001-03-14 20:20:02 +03:00
|
|
|
// Warning: whatever GLContext is defined to must take exactly the same
|
|
|
|
// space in a structure as a void*!!!
|
1998-10-06 22:21:25 +04:00
|
|
|
#ifdef WIN32
|
2001-11-27 20:44:08 +03:00
|
|
|
# include <FL/gl.h>
|
|
|
|
# define GLContext HGLRC
|
2004-08-25 04:20:27 +04:00
|
|
|
#elif defined(__APPLE_QD__)
|
|
|
|
# include <OpenGL/gl.h>
|
|
|
|
# include <AGL/agl.h>
|
|
|
|
# define GLContext AGLContext
|
|
|
|
#elif defined(__APPLE_QUARTZ__)
|
2004-09-10 01:34:48 +04:00
|
|
|
// warning: the Quartz version should probably use Core GL (CGL) instead of AGL
|
2001-12-06 03:17:47 +03:00
|
|
|
# include <OpenGL/gl.h>
|
|
|
|
# include <AGL/agl.h>
|
|
|
|
# define GLContext AGLContext
|
1998-10-06 22:21:25 +04:00
|
|
|
#else
|
2001-11-27 20:44:08 +03:00
|
|
|
# include <GL/glx.h>
|
|
|
|
# define GLContext GLXContext
|
1998-10-06 22:21:25 +04:00
|
|
|
#endif
|
|
|
|
|
2001-03-14 20:20:02 +03:00
|
|
|
// Describes crap needed to create a GLContext.
|
1998-10-06 22:21:25 +04:00
|
|
|
class Fl_Gl_Choice {
|
|
|
|
int mode;
|
|
|
|
const int *alist;
|
|
|
|
Fl_Gl_Choice *next;
|
|
|
|
public:
|
|
|
|
#ifdef WIN32
|
2000-03-18 13:04:18 +03:00
|
|
|
int pixelformat; // the visual to use
|
|
|
|
PIXELFORMATDESCRIPTOR pfd; // some wgl calls need this thing
|
2004-08-25 04:20:27 +04:00
|
|
|
#elif defined(__APPLE_QD__)
|
|
|
|
AGLPixelFormat pixelformat;
|
|
|
|
#elif defined(__APPLE_QUARTZ__)
|
2004-09-10 01:34:48 +04:00
|
|
|
// warning: the Quartz version should probably use Core GL (CGL) instead of AGL
|
2001-12-18 14:00:09 +03:00
|
|
|
AGLPixelFormat pixelformat;
|
1998-10-06 22:21:25 +04:00
|
|
|
#else
|
|
|
|
XVisualInfo *vis; // the visual to use
|
2000-03-18 13:04:18 +03:00
|
|
|
Colormap colormap; // a colormap for that visual
|
1998-10-06 22:21:25 +04:00
|
|
|
#endif
|
1999-09-16 09:34:27 +04:00
|
|
|
// Return one of these structures for a given gl mode.
|
|
|
|
// The second argument is a glX attribute list, and is used if mode is
|
|
|
|
// zero. This is not supported on Win32:
|
1998-10-06 22:21:25 +04:00
|
|
|
static Fl_Gl_Choice *find(int mode, const int *);
|
|
|
|
};
|
|
|
|
|
|
|
|
class Fl_Window;
|
1999-09-16 09:34:27 +04:00
|
|
|
|
|
|
|
#ifdef WIN32
|
2001-03-14 20:20:02 +03:00
|
|
|
|
|
|
|
GLContext fl_create_gl_context(Fl_Window*, const Fl_Gl_Choice*, int layer=0);
|
|
|
|
|
2004-08-25 04:20:27 +04:00
|
|
|
#elif defined(__APPLE_QD__)
|
|
|
|
|
|
|
|
GLContext fl_create_gl_context(Fl_Window*, const Fl_Gl_Choice*, int layer=0);
|
|
|
|
|
|
|
|
#elif defined(__APPLE_QUARTZ__)
|
2004-09-10 01:34:48 +04:00
|
|
|
// warning: the Quartz version should probably use Core GL (CGL) instead of AGL
|
2001-11-27 20:44:08 +03:00
|
|
|
|
2001-12-06 03:17:47 +03:00
|
|
|
GLContext fl_create_gl_context(Fl_Window*, const Fl_Gl_Choice*, int layer=0);
|
2001-11-27 20:44:08 +03:00
|
|
|
|
2001-03-14 20:20:02 +03:00
|
|
|
#else
|
|
|
|
|
|
|
|
GLContext fl_create_gl_context(XVisualInfo* vis);
|
|
|
|
|
|
|
|
static inline
|
|
|
|
GLContext fl_create_gl_context(Fl_Window*, const Fl_Gl_Choice* g) {
|
|
|
|
return fl_create_gl_context(g->vis);
|
|
|
|
}
|
|
|
|
|
1998-10-06 22:21:25 +04:00
|
|
|
#endif
|
|
|
|
|
2001-03-14 20:20:02 +03:00
|
|
|
void fl_set_gl_context(Fl_Window*, GLContext);
|
1999-09-16 09:34:27 +04:00
|
|
|
void fl_no_gl_context();
|
2001-03-14 20:20:02 +03:00
|
|
|
void fl_delete_gl_context(GLContext);
|
1999-09-16 09:34:27 +04:00
|
|
|
|
1998-10-06 22:21:25 +04:00
|
|
|
#endif
|
1998-10-20 00:46:58 +04:00
|
|
|
|
|
|
|
//
|
2005-02-25 00:55:12 +03:00
|
|
|
// End of "$Id$".
|
1998-10-20 00:46:58 +04:00
|
|
|
//
|