/////////////////////////////////////////////////////////////////////////////
// Name: glcanvas.h
-// Purpose: documentation for wxGLContext class
+// Purpose: interface of wxGLContext
// Author: wxWidgets team
// RCS-ID: $Id$
// Licence: wxWindows license
@library{wxgl}
@category{gl}
- @seealso
- wxGLCanvas
+ @see wxGLCanvas
*/
class wxGLContext : public wxObject
{
public:
/**
Constructor.
-
+
@param win
- The canvas that is used to initialize this context. This parameter is needed
- only temporarily,
- and the caller may do anything with it (e.g. destroy the window) after the
+ The canvas that is used to initialize this context. This parameter is
+ needed only temporarily,
+ and the caller may do anything with it (e.g. destroy the window) after the
constructor returned.
-
- It will be possible to bind (make current) this context to any other wxGLCanvas
- that has been created
- with equivalent attributes as win.
-
+ It will be possible to bind (make current) this context to any other
+ wxGLCanvas that has been created
+ with equivalent attributes as win.
@param other
- Context to share display lists with or @NULL (the default) for no sharing.
+ Context to share display lists with or @NULL (the default) for no sharing.
*/
- wxGLContext(wxGLCanvas* win, const wxGLContext* other=@NULL);
+ wxGLContext(wxGLCanvas* win, const wxGLContext* other = NULL);
/**
Makes the OpenGL state that is represented by this rendering context current
with the wxGLCanvas @e win.
- Note that @e win can be a different wxGLCanvas window than the one that was
+ Note that @a win can be a different wxGLCanvas window than the one that was
passed to the constructor of this rendering context.
If @e RC is an object of type wxGLContext, the statements @e
RC.SetCurrent(win); and @e win.SetCurrent(RC); are equivalent,
void SetCurrent(const wxGLCanvas& win);
};
+/**
+ Constants for use with wxGLCanvas.
+
+ Notice that not all implementation support options such as stereo,
+ auxiliary buffers, alpha channel, and accumulator buffer, use
+ wxGLCanvas::IsDisplaySupported() to check for individual attributes support.
+ */
+enum
+{
+ /// Use true color palette (on if no attributes at all specified).
+ WX_GL_RGBA = 1,
+
+ /// Specifies the number of bits for buffer if not WX_GL_RGBA.
+ WX_GL_BUFFER_SIZE,
+
+ /// Must be followed by 0 for main buffer, >0 for overlay, <0 for underlay.
+ WX_GL_LEVEL,
+
+ /// Use double buffering if present (on if no attributes specified).
+ WX_GL_DOUBLEBUFFER,
+
+ /// Use stereoscopic display.
+ WX_GL_STEREO,
+
+ /// Specifies number of auxiliary buffers.
+ WX_GL_AUX_BUFFERS,
+
+ /// Use red buffer with most bits (> MIN_RED bits)
+ WX_GL_MIN_RED,
+
+ /// Use green buffer with most bits (> MIN_GREEN bits)
+ WX_GL_MIN_GREEN,
+
+ /// Use blue buffer with most bits (> MIN_BLUE bits)
+ WX_GL_MIN_BLUE,
+
+ /// Use alpha buffer with most bits (> MIN_ALPHA bits)
+ WX_GL_MIN_ALPHA,
+
+ /// Specifies number of bits for Z-buffer (typically 0, 16 or 32).
+ WX_GL_DEPTH_SIZE,
+
+ /// Specifies number of bits for stencil buffer.
+ WX_GL_STENCIL_SIZE,
+
+ /// Specifies minimal number of red accumulator bits.
+ WX_GL_MIN_ACCUM_RED,
+
+ /// Specifies minimal number of green accumulator bits.
+ WX_GL_MIN_ACCUM_GREEN,
+
+ /// Specifies minimal number of blue accumulator bits.
+ WX_GL_MIN_ACCUM_BLUE,
+
+ /// Specifies minimal number of alpha accumulator bits.
+ WX_GL_MIN_ACCUM_ALPHA
+
+};
/**
@class wxGLCanvas
@library{wxgl}
@category{gl}
- @seealso
- wxGLContext
+ @see wxGLContext
*/
class wxGLCanvas : public wxWindow
{
/**
Creates a window with the given parameters. Notice that you need to create and
use a wxGLContext to output to this window.
-
If
-
+
@param attribList is not specified, double buffered RGBA mode is used.
-
+
parent
- Pointer to a parent window.
-
+ Pointer to a parent window.
@param id
- Window identifier. If -1, will automatically create an identifier.
-
+ Window identifier. If -1, will automatically create an identifier.
@param pos
- Window position. wxDefaultPosition is (-1, -1) which indicates that wxWidgets
- should generate a default position for the window.
-
+ Window position. wxDefaultPosition is (-1, -1) which indicates that
+ wxWidgets
+ should generate a default position for the window.
@param size
- Window size. wxDefaultSize is (-1, -1) which indicates that wxWidgets should
- generate a default size for the window. If no suitable size can be found, the
- window will be sized to 20x20 pixels so that the window is visible but obviously not correctly sized.
-
+ Window size. wxDefaultSize is (-1, -1) which indicates that wxWidgets should
+ generate a default size for the window. If no suitable size can be found,
+ the window will be sized to 20x20 pixels so that the window is visible but obviously not correctly sized.
@param style
- Window style.
-
+ Window style.
@param name
- Window name.
-
+ Window name.
@param attribList
- Array of integers. With this parameter you can set the device context
- attributes associated to this window.
- This array is zero-terminated: it should be set up with constants described in
- the table above.
- If a constant should be followed by a value, put it in the next array position.
- For example, the WX_GL_DEPTH_SIZE should be followed by the value that
- indicates the number of
- bits for the depth buffer, so:
-
+ Array of integers. With this parameter you can set the device
+ context attributes associated to this window. This array is
+ zero-terminated: it should be set up with constants described in
+ the table above. If a constant should be followed by a value, put
+ it in the next array position. For example, the WX_GL_DEPTH_SIZE
+ should be followed by the value that indicates the number of bits
+ for the depth buffer, e.g:
+ @code
+ attribList[n++] = WX_GL_DEPTH_SIZE;
+ attribList[n++] = 32;
+ attribList[n] = 0; // terminate the list
+ @endcode
+ If the attribute list is not specified at all, i.e. if this
+ parameter is @NULL, the default attributes including @c WX_GL_RGBA
+ and @c WX_GL_DOUBLEBUFFER are used. But notice that if you do
+ specify some attributes you also need to explicitly include these
+ two default attributes in the list if you need them.
@param palette
- Palette for indexed colour (i.e. non WX_GL_RGBA) mode.
- Ignored under most platforms.
+ Palette for indexed colour (i.e. non WX_GL_RGBA) mode.
+ Ignored under most platforms.
*/
wxGLCanvas(wxWindow* parent, wxWindowID id = wxID_ANY,
- const int* attribList = @NULL,
+ const int* attribList = NULL,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
- long style=0,
- const wxString& name="GLCanvas",
+ long style = 0,
+ const wxString& name = "GLCanvas",
const wxPalette& palette = wxNullPalette);
/**
Determines if a canvas having the specified attributes is available.
-
Returns @true if attributes are supported.
-
+
@param attribList
- See attribList for wxGLCanvas().
+ See attribList for wxGLCanvas().
*/
- static bool IsDisplaySupported(const int * attribList = @NULL);
+ static bool IsDisplaySupported(const int* attribList = NULL);
/**
Sets the current colour for this window (using @c glcolor3f()), using the
/**
Makes the OpenGL state that is represented by the OpenGL rendering context
- @e context current, i.e. it will be used by all subsequent OpenGL calls.
-
+ @a context current, i.e. it will be used by all subsequent OpenGL calls.
This is equivalent to wxGLContext::SetCurrent
called with this window as parameter.
-
Note that this function may only be called when the window is shown on screen,
in particular it can't usually be called from the constructor as the window
isn't yet shown at this moment.
-
Returns @false if an error occurred.
*/
bool SetCurrent(const wxGLContext context);
Swaps the double-buffer of this window, making the back-buffer the front-buffer
and vice versa,
so that the output of the previous OpenGL commands is displayed on the window.
-
Returns @false if an error occurred.
*/
bool SwapBuffers();
};
+