<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
<html>
  <!-- vi:set sw=2: -->
  <!--
  Copyright (C) 1996-2002  Brian Paul and Ben Bederson
  Copyright (C) 2005-2009  Greg Couch
  See the LICENSE file for copyright details.
  -->

  <head>
    <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
    <title>Togl C API</title>
  </head>

  <body>
    <script type="text/javascript" src="header.js"></script>
    <script type="text/javascript">
      NavigationBar();
    </script>

    <h1 align="center">Togl C API</h1>

    <h2>Contents</h2>
    <ul>
      <li><a href="#compile">Compiling and linking C Togl Functions</a>
      <li><a href="#setup">Setup and Initialization Functions</a>
      <ul>
	<li><code>Togl_Init</code>,
	<code>Togl_InitStubs</code>
      </ul>
      <li><a href="#drawing">Drawing-related Commands</a>
      <ul>
	<li><code>Togl_PostRedisplay</code>,
	<code>Togl_SwapBuffers</code>,
	<code>Togl_MakeCurrent</code>,
	<code>Togl_SwapInterval</code>
	<code>Togl_CopyContext</code>
      </ul>
      <li><a href="#query">Query Functions</a>
      <ul>
	<li><code>Togl_Ident</code>,
	<code>Togl_Width</code>,
	<code>Togl_Height</code>,
	<code>Togl_Interp</code>,
	<code>Togl_TkWin</code>,
	<code>Togl_GetProcAddr</code>,
	<code>Togl_ContextTag</code>
	<code>Togl_UpdatePending</code>
	<code>Togl_HasRGBA</code>
	<code>Togl_IsDoubleBuffered</code>
	<code>Togl_HasDepthBuffer</code>
	<code>Togl_HasAccumulationBuffer</code>
	<code>Togl_HasDestinationAlpha</code>
	<code>Togl_HasStencilBuffer</code>
	<code>Togl_StereoMode</code>
	<code>Togl_HasMultisample</code>
      </ul>
      <li><a href="#index">Color Index Mode Functions</a>
      <ul>
	<li><code>Togl_AllocColor</code>,
	<code>Togl_FreeColor</code>,
	<code>Togl_SetColor</code>
      </ul>
      <li><a href="#font">Font Functions</a>
      <ul>
	<li><code>Togl_LoadBitmapFont</code>,
	<code>Togl_UnloadBitmapFont</code>,
	<code>Togl_WriteObj</code>,
	<code>Togl_WriteChars</code>
      </ul>
      <li><a href="#client">Client Data Functions</a>
      <ul>
	<li><code>Togl_SetClientData</code>,
	<code>Togl_GetClientData</code>
      </ul>
      <li><a href="#overlay">Overlay Functions</a>
      <ul>
	<li><code>Togl_UseLayer</code>,
	<code>Togl_ShowOverlay</code>,
	<code>Togl_HideOverlay</code>,
	<code>Togl_PostOveralyRedisplay</code>,
	<code>Togl_ExistsOverlay</code>,
	<code>Togl_GetOverlayTransparentValue</code>,
	<code>Togl_IsMappedOverlay</code>,
	<code>Togl_AllocColorOverlay</code>,
	<code>Togl_FreeColorOverlay</code>
      </ul>
      <li><a href="#stereo">Stereo Functions</a>
      <ul>
	<li><code>Togl_Drawbuffer</code>,
	<li><code>Togl_Clear</code>
	<li><code>Togl_Frustum</code>
	<li><code>Togl_Ortho</code>
	<li><code>Togl_NumEyes</code>
      </ul>
      <li><a href="#image">Image Functions</a>
      <ul>
	<li><code>Togl_TakePhoto</code>
      </ul>
      <li><a href="#convert">Conversion Functions</a>
      <ul>
	<li><code>Togl_GetToglFromObj</code>,
	<li><code>Togl_GetToglFromName</code>
      </ul>
    </ul>

    <hr>

    <h2><a name="compile">Compiling and linking C Togl Functions</a></h2>

    <p>
    All Togl functions are found in the Togl header file.

    <blockquote>
      <code>
	#include "togl.h"
      </code>
    </blockquote>

    <p>
    For portability, you should include the <code>togl.h</code> header
    before any other OpenGL headers
    so it will compile on Microsoft Windows.

    <p>
    Before calling any Togl functions, you need to initialize it.
    Regardless if you're using stubs (by defining <code>USE_TOGL_STUBS</code>)
    or not, the following code will properly initialize togl:

    <blockquote><pre>
if (Tcl_InitStubs(interp, "8.1", 0) == NULL
|| Togl_InitStubs(interp, "2.0", 0) == NULL) {
    /* fail */
}
</pre></blockquote>

    <p>
    If you are using a prebuilt binary distribution,
    you should be sure to define <code>USE_TOGL_STUBS</code> beforehand.

    <p>
    See the source for the demo programs in the Togl source distribution
    for working examples.

    <h3>Linking</h3>

    <p>
    If you are using a prebuilt binary,
    be sure to link against the stub library.
    On Microsoft Windows,
    link against <code>Toglstub21.lib opengl32.lib user32.lib gdi32.lib</code>,
    on Mac OS X,
    link against <code>-lToglstub2.1 -framework OpenGL</code>,
    on other platforms,
    link against <code>-lToglstub2.1 -lGLU -lGL -lm</code>.

    <p>
    If building your own Togl package,
    you can use the stubs interface or link in the Tcl and Tk libraries as well.
    If using the stubs interface, link as shown above.
    Otherwise:
    on Microsoft Windows,
    link against <code>Togl21.lib tk84.lib tcl84.lib opengl32.lib user32.lib gdi32.lib</code>,
    on Mac OS X,
    link against <code>-lTogl2.1 -framework Tk -framework Tcl -framework OpenGL</code>,
    on other platforms,
    link against <code>-lTogl2.1 -ltk8.4 -ltcl8.4 -lGLU -lGL -lm</code>.

    <h2><a name="setup">Setup and Initialization Functions</a></h2>

    <dl>
      <dt><code>int Togl_Init(Tcl_Interp *interp)</code>
      <dd>
      Initializes the Togl module.  This is typically called from the
      Tk_Main() function
      or other Tcl package initialization function that is directly linked
      to the Togl (shared) library.
      It is also indirectly called via
      Tcl's <code>package require Togl</code> command.
      If successful, the return value is TCL_OK.
    </dl>

    <dl>
      <dt>
      <code>const char *Togl_InitStubs(Tcl_Interp *interp, const char *version, int exact)</code>
      <dd>
      Loads the Togl package into the given <code>interp</code>reter
      and initializes it.
      <code>version</code> should be <code>"2.0"</code> or higher.
      This is typically called from C/C++ code that accesses Togl's C API
      and has installed Togl into the standard TCL hierarchy.
      See the Tcl InitStubs(3) or the Tk TkInitStubs(3) manual pages for
      more information.
    </dl>

    <h2><a name="drawing">Drawing-related Commands</a></h2>

    <dl>
      <dt><code>void Togl_PostRedisplay(Togl *togl)</code>
      <dd>
      Signals that the widget should be redrawn.  When Tk is next idle,
      the <code>displaycommand</code> callback will be invoked.
    </dl>

    <dl>
      <dt><code>void Togl_SwapBuffers(const Togl *togl)</code>
      <dd>
      Swaps the front and back color buffers for a double-buffered widget.
      <a href="http://www.opengl.org/sdk/docs/man/xhtml/glFlush.xml">
	glFlush</a> is executed if the window is single-buffered.  So this call
      works for both single- and double-buffered contexts.  This is
      typically called in the <code>displaycommand</code> callback function.
    </dl>

    <dl>
      <dt><code>void Togl_MakeCurrent(const Togl *togl)</code>
      <dd>
      Sets the current rendering context to the given widget.  This is done
      automatically before any Togl callback functions is called.  So the
      call is only needed if you have multiple widgets with separate OpenGL
      contexts.  If the argument is NULL, then the rendering context is cleared
      and subsequent OpenGL commands will fail.
    </dl>

    <dl>
      <dt><code>Bool Togl_SwapInterval(const Togl *togl, int interval)</code>
      <dd>
      Returns True if successful.
      Attempts to change the maximum refresh rate
      by setting the minimum number of cycles between successive swap buffers.
      For benchmarking purposes, you should set the swap interval to 0.
    </dl>

    <dl>
      <dt><code>int Togl_CopyContext(const Togl *from, const Togl *to, unsigned int mask)</code>
      <dd>
      Copy a subset of the OpenGL context state from from one context
      to another using the mask parameter who values are the same as
      <a href="http://www.opengl.org/sdk/docs/man/xhtml/glPushAttrib.xml">
	glPushAttrib</a>.
      The return value is TCL_OK if the context was copied.
    </dl>

    <h2><a name="query">Query Functions</a></h2>

    <dl>
      <dt><code>char *Togl_Ident(const Togl *togl)</code>
      <dd>
      Returns a pointer to the identification string associated with a Togl
      widget or NULL if there's no identifier string.
    </dl>

    <dl>
      <dt><code>int Togl_Width(const Togl *togl)</code>
      <dd>
      Returns the width of the given Togl widget.  Typically called in the
      <code>reshapecommand</code> callback function.
    </dl>

    <dl>
      <dt><code>int Togl_Height(const Togl *togl)</code>
      <dd>
      Returns the height of the given Togl widget.  Typically called in the
      <code>reshapecommand</code> callback function.
    </dl>

    <dl>
      <dt><code>Tcl_Interp *Togl_Interp(const Togl *togl)</code>
      <dd>
      Returns the Tcl interpreter associated with the given Togl widget.
    </dl>
    <dl>
      <dt>
      <code>Tk_Window Togl_TkWin(const Togl *togl)</code>
      <dd>
      Returns the Tk window associated with the given Togl widget.
    </dl>

    <dl>
      <dt><code>Togl_FuncPtr Togl_GetProcAddr(const char *funcname)</code>
      <dd>
      Platform-independent way to get OpenGL function pointers from a
      function name.
      Note that in Microsoft Windows (WGL) versions that
      "the extension function addresses are unique for each pixel format.
      All rendering contexts of a given pixel format
      share the same extension function addresses."
      And on *nix (GLX/X11) platforms, 
      "the function pointers returned are context independent"
      (Linux ABI documentation).
      The Mac OS X (AGL) platform acts like a *nix platform.
    </dl>

    <dl>
      <dt><code>int Togl_ContextTag(const Togl *t)</code>
      <dd>
      Returns an integer that represents the context tag.
      All Togl widgets with the same context tag share display lists.
    </dl>

    <dl>
      <dt><code>Bool Togl_UpdatePending(const Togl *t)</code>
      <dd>
      Returns True if the window should be redrawn.  See Togl_PostRedisplay.
    </dl>

    <dl>
      <dt><code>Bool Togl_HasRGBA(const Togl *t)</code>
      <dd>
      Return True if Togl widget has a RBGA color buffer.
      False means that the widget is using a color index buffer.
    </dl>

    <dl>
      <dt><code>Bool Togl_IsDoubleBuffered(const Togl *t)</code>
      <dd>
      Return True if Togl widget is double buffered.
    </dl>

    <dl>
      <dt><code>Bool Togl_HasDepthBuffer(const Togl *t)</code>
      <dd>
      Return True if Togl widget is has a depth buffer.
    </dl>

    <dl>
      <dt><code>Bool Togl_HasAccumulationBuffer(const Togl *t)</code>
      <dd>
      Return True if Togl widget has an accumulation buffer.
    </dl>

    <dl>
      <dt><code>Bool Togl_HasDestinationAlpha(const Togl *t)</code>
      <dd>
      Return True if Togl widget has a destination alpha buffer.
    </dl>

    <dl>
      <dt><code>Bool Togl_HasStencilBuffer(const Togl *t)</code>
      <dd>
      Return True if Togl widget has a stencil buffer.
    </dl>

    <dl>
      <dt><code>int Togl_StereoMode(const Togl *t)</code>
      <dd>
      Return current stereo mode.  See ??
    </dl>

    <dl>
      <dt><code>Bool Togl_HasMultisample(const Togl *t)</code>
      <dd>
      Return True if Togl widget has a multisample buffer.
    </dl>

    <h2><a name="index">Color Index Mode Functions</a></h2>

    <p>
    These functions are only used for color index mode.

    <dl>
      <dt><code>unsigned long Togl_AllocColor(Togl *togl, float red, float green, float blue)</code>
      <dd>
      Allocate a color from a read-only colormap.  Given a color specified
      by red, green, and blue return a colormap index (aka pixel value)
      whose entry most closely matches the red, green, blue color.  Red,
      green, and blue are values in [0,1].  This function is only used in
      color index mode when the <code>-privatecmap</code> option is false.
    </dl>

    <dl>
      <dt><code>void Togl_FreeColor(Togl *togl, unsigned long index)</code>
      <dd>
      Free a color in a read-only colormap.  Index is a value which was
      returned by the Togl_AllocColor() function.  This function is only
      used in color index mode when the <code>-privatecmap</code> option
      is false.
    </dl>

    <dl>
      <dt><code>void Togl_SetColor(Togl *togl,
	int index, float red, float green, float blue)</code>
      <dd>
      Load the colormap entry specified by index with the given red, green
      and blue values.  Red, green, and blue are values in [0,1].  This
      function is only used in color index mode when the
      <code>-privatecmap</code> option is true.
    </dl>


    <h2><a name="font">Font Functions</a></h2>

    <p>
    These functions provide an interface to the simple bitmap font capabilities
    that every OpenGL implementation provides.
    Better font support is found in other C APIs, <i>e.g.</i>,
    <a href="http://quesoglc.sourceforge.net/">QuesoGLC</a>
    or <a href="http://sourceforge.net/projects/ftgl">FTGL</a>.

    <dl>
      <dt><code>Tcl_Obj *Togl_LoadBitmapFont(Togl *togl,
	const char *fontname)</code>
      <dd>
      Load the named font as a set of
      <a href="http://www.opengl.org/sdk/docs/man/xhtml/glBitmap.xml">
	glBitmap</a> display lists.
      <var>fontname</var> may be any of the font description styles
      accepted by the Tk font command.
      For maximum portability, one of the standard Tk fonts,
      <b>Courier</b>, <b>Times</b>, and <b>Helvetica</b>, should be used.
      Unicode fonts are treated as if they have only have an 8-bit index
      (so poorly).
      If successful, a Togl BitmapFont object is returned.
      NULL is returned on failure.
    </dl>

    <dl>
      <dt><code>int Togl_UnloadBitmapFont(Togl *togl, Tcl_Obj *toglfont)
      </code>
      <dd>
      Destroys the bitmap display lists created by by Togl_LoadBitmapFont().
      If successful, the return value is TCL_OK.
    </dl>

    <dl>
      <dt><code>int Togl_WriteChars(const Togl *togl, const Tcl_Obj *toglfont, const char *string, int length)
      </code>
      Draw the given <em>string</em>.
      If the given <em>length</em> is zero, then it is computed using strlen.
      Returns the length of the drawn string.
      <dd>
    </dl>

    <dl>
      <dt><code>int Togl_WriteObj(const Togl *togl, const Tcl_Obj *toglfont, Tcl_Obj *obj)
      </code>
      <dd>
      Tcl_Obj interface to <code>Tcl_WriteChars</code>.
    </dl>

    <h2><a name="client">Client Data Functions</a></h2>

    <p>
    Each Togl structure has a pointer to an arbitrary client data structure.

    <dl>
      <dt><code>void Togl_SetClientData(Togl *togl, ClientData clientData)</code>
      <dd>
      Set the Togl widget's client data pointer to <em>clientData</em>.
    </dl>

    <dl>
      <dt><code>ClientData Togl_GetClientData(const Togl *togl)</code>
      <dd>
      Return the Togl widget's client data pointer.
    </dl>


    <h2><a name="overlay">Overlay Functions</a></h2>

    <p>
    These functions are modeled after GLUT's overlay sub-API.

    <dl>
      <dt><code>void Togl_UseLayer(Togl *togl, int layer)</code>
      <dd>
      Select the layer into which subsequent OpenGL rendering will be
      directed.  <em>layer</em> may be either <em>TOGL_OVERLAY</em> or
      <em>TOGL_NORMAL</em>.
    </dl>

    <dl>
      <dt><code>void Togl_ShowOverlay(Togl *togl)</code>
      <dd>
      Display the overlay planes, if any.
    </dl>

    <dl>
      <dt><code>void Togl_HideOverlay(Togl *togl)</code>
      <dd>
      Hide the overlay planes, if any.
    </dl>

    <dl>
      <dt><code>void Togl_PostOverlayRedisplay(Togl *togl)</code>
      <dd>
      Signal that the overlay planes should be redraw.  
      When Tk is next idle,
      the <code>overlaydisplaycommand</code> callback will be invoked.
    </dl>

    <dl>
      <dt><code>int Togl_ExistsOverlay(Togl *togl)</code>
      <dd>
      Returns 1 if overlay planes exist, 0 otherwise.
    </dl>

    <dl>
      <dt><code>int Togl_GetOverlayTransparentValue(const Togl *togl)</code>
      <dd>
      Returns the color index of the overlay's transparent pixel value.
    </dl>

    <dl>
      <dt><code>int Togl_IsMappedOverlay(const Togl *togl)</code>
      <dd>
      Returns 1 if the overlay planes are currently displayed, 0 otherwise.
    </dl>

    <dl>
      <dt><code>unsigned long Togl_AllocColorOverlay(const Togl *togl,
	float red, float green, float blue)</code>
      <dd>
      Allocate a color in the overlay planes.  Red, green, and blue are
      values in [0,1].  Return the color index or -1 if the allocation
      fails.
    </dl>

    <dl>
      <dt><code>void Togl_FreeColorOverlay(const Togl *togl, unsigned long index)</code>
      <dd>
      Free a color which was allocated with Togl_AllocColorOverlay().
    </dl>

    <h2><a name="stereo">Stereo Functions</a></h2>

    <p>
    Togl abstracts part of the stereo drawing process to seamlessly
    support quad-buffered stereo as well as various alternative stereo
    formats.  The stereo viewing parameters, <code>eyeseparation</code>
    and <code>convergence</code> need to be set with the Togl's
    <a href="tclapi.html#stereo options">stereo options</a>.

    <dl>
      <dt><code>void Togl_DrawBuffer(Togl *togl, GLenum mode)</code>
      <dd>
      Switch to OpenGL draw buffer.
      Should be one of GL_BACK_LEFT, GL_BACK_RIGHT, GL_FRONT_LEFT, or
      GL_FRONT_RIGHT.
      It is not possible to draw in the left and right buffers at the same
      time in the alternate stereo modes.
    </dl>

    <dl>
      <dt><code>void Togl_Clear(const Togl *togl, GLbitfield mask)</code>
      <dd>
      Replacement for OpenGL's
      <a href="http://www.opengl.org/sdk/docs/man/xhtml/glClear.xml">
	glClear</a> that takes into account the alternate stereo mode.
    </dl>

    <dl>
      <dt><code>void Togl_Frustum(const Togl *togl, GLfloat left, GLfloat right, GLfloat bottom, GLfloat top, GLfloat near, GLfloat far)</code>
      <dd>
      Replacement for OpenGL's
      <a href="http://www.opengl.org/sdk/docs/man/xhtml/glFrustum.xml">
	glFrustum</a> that takes into account the alternate stereo mode.
    </dl>

    <dl>
      <dt><code>void Togl_Ortho(const Togl *togl, GLfloat left, GLfloat right, GLfloat bottom, GLfloat top, GLfloat near, GLfloat far)</code>
      <dd>
      Replacement for OpenGL's
      <a href="http://www.opengl.org/sdk/docs/man/xhtml/glOrtho.xml">
	glOrtho</a> that takes into account the alternate stereo mode.
    </dl>

    <dl>
      <dt><code>int Togl_NumEyes(const Togl *togl)</code>
      <dd>
    </dl>

    <h3>Stereo Example</h3>

    <p>
    This code works for quad-buffered stereo,
    as well as the other stereo modes.

    <blockquote><pre>
if (Togl_NumEyes(togl) == 1) {
    Togl_DrawBuffer(togl, GL_BACK);
    Togl_Clear(togl);
    glMatrixMode(GL_PROJECTION);
    glLoadIdentity();
    Togl_Frustum(togl, left, right, bottom, top, near, far);
    glMatrixMode(GL_MODELVIEW);
    <b><i>draw image</i></b>
} else {
    Togl_DrawBuffer(togl, GL_BACK_LEFT);
    Togl_Clear(togl);
    glMatrixMode(GL_PROJECTION);
    glLoadIdentity();
    Togl_Frustum(togl, left, right, bottom, top, near, far);
    glMatrixMode(GL_MODELVIEW);
    <b><i>draw left-eye image</i></b>
    Togl_DrawBuffer(togl, GL_BACK_RIGHT);
    Togl_Clear(togl);
    glMatrixMode(GL_PROJECTION);
    glLoadIdentity();
    Togl_Frustum(togl, left, right, bottom, top, near, far);
    glMatrixMode(GL_MODELVIEW);
    <b><i>draw right-eye image</i></b>
}
Togl_SwapBuffers(togl);
</pre></blockquote>

    <h2><a name="image">Image Functions</a></h2>

    <p>
    <!--description-->

    <dl>
      <dt><code>int Togl_TakePhoto(Togl *togl, Tk_PhotoHandle photo)</code>
      <dd>
      Take a photo image of the current Togl window and place it in the
      given <code>photo</code> object.
      If the window is partially obscured,
      either by other windows or by the edges of the display,
      the results are undefined in the obscured region. 
      If successful, the return value is TCL_OK.
    </dl>

    <h2><a name="convert">Conversion Functions</a></h2>

    <p>
    These functions aid the programmer when writing Togl callback functions.

    <dl>
      <dt><code>int Togl_GetToglFromObj(Tcl_Interp *interp, Tcl_Obj *obj, Togl **toglPtr)</code>
      <dd>
      Attempt to return a Togl structure "toglPtr" from the Tcl object "obj".
      If successful, the return value is TCL_OK.
    </dl>

    <dl>
      <dt><code>int Togl_GetToglFromName(Tcl_Interp *interp, const char *cmdName, Togl **toglPtr)</code>
      <dd>
      Attempt to return a Togl structure "toglPtr" from the Tcl command name "cmdName".
      If successful, the return value is TCL_OK.
    </dl>

    <hr>
    <a href="http://sourceforge.net/projects/togl">
      <img src="http://sflogo.sourceforge.net/sflogo.php?group_id=519&amp;type=13" width="120" height="30" border="0" alt="Get Togl at SourceForge.net. Fast, secure and Free Open Source software downloads">
    </a>
    <a href="http://validator.w3.org/check?uri=referer">
      <img src="http://www.w3.org/Icons/valid-html401-blue"
      alt="Valid HTML 4.01 Transitional" height="31" width="88" border="0">
    </a>
  </body>
</html>