OpenGLContext
Description
- Derived from
-
GLContext abstract
Full source code is included in the Tinman 3D SDK download. |
An implementation of the IGraphicsContext interface that uses an OpenGL 4.1 Core Profile context (or newer).
You can use the OpenGLContextFactory object to configure and create an instance of this class. Also you can use the constructor to wrap an existing GL object.
By default, OpenGL interprets sequences of pixel/texel rows as bottom-to-top, while ITexture2D (and thus IGraphicsContext) specifies top-to-bottom. Textures and 3D models are authored against the latter. To avoid the necessity to modify texture data and/or 3D model data (texture coordinates), the following GLSL statement must be added after outputting gl_Position
:
gl_Position.y *= 1.0;
Alternatively, call GL.ClipControl with GL.UPPER_LEFT in GLEffect.RenderStateSet.
The returned INativeHandles can be interpreted as follows:
-
OpenGLContext:
Same as returned by RenderContext object given at construction. -
IIndexBuffer (created by IGraphicsContext.BufferFactory):
The OpenGL name of the index buffer object. -
IVertexBuffer (created by IGraphicsContext.BufferFactory):
The OpenGL name of the vertex buffer object. -
ITexture2D (created by IGraphicsContext.TextureFactory:
The OpenGL name of the texture object (GL.TEXTURE_2D_ARRAY). -
ITextureCube (created by IGraphicsContext.CreateTextureCube):
The OpenGL name of the texture object (GL.TEXTURE_CUBE_MAP). -
IRenderTarget (created by IGraphicsContext.CreateRenderTarget or IGraphicsContext.CreateSwapChain):
The OpenGL name of the framebuffer object.
The IGraphicsContext.ClearRenderTarget method modifies the following state:
The IGraphicsContext.ReadPixels method modifies the following state:
-
GL.PixelStorei :
GL_PACK_*
The IGraphicsContext.SetClip method modifies the following state:
The IGraphicsContext.SetGeometryBuffer method modifies the following state:
The IGraphicsContext.SetRenderTarget method modifies the following state:
The IGraphicsContext.SetViewport method modifies the following state:
The following binding targets are modified by the classes of this graphics context implementation and will be cleared to zero after use:
Public / Constructors
OpenGLContext
Creates a new instance of OpenGLContext.
- RenderException
-
If a graphics subsystem error has occurred.