Togl - a Tk OpenGL widget
Version 1.2
Copyright (C) 1996 Brian Paul and Ben Bederson
Introduction
Togl is a Tk widget for OpenGL rendering. Togl is originally based on
OGLTK,
written by Benjamin Bederson at the University of New Mexico. Togl adds the
new features:
- color-index mode support including color allocation functions
- support for requesting stencil, accumulation, alpha buffers, etc
- multiple OpenGL drawing widgets
- OpenGL extension testing from Tcl
- simple, portable font support
Togl allows one to create and manage a special Tk/OpenGL widget with Tcl and
render into it with a C program. That is, a typical Togl program will have Tcl
code for managing the user interface and a C program for computations and
OpenGL rendering.
Togl is copyrighted by
Brian Paul
(brianp@elastic.avid.com) and
Benjamin Bederson
(bederson@cs.unm.edu).
See the LICENSE file for details.
The Togl WWW page is available from:
Prerequisites
You should have
Tcl and Tk
installed on your computer, including the Tk source code files.
Togl has been tested with Tcl 7.4/Tk 4.0, Tcl 7.5/Tk 4.1 and Tcl 7.6/Tk 4.2
at this time.
It is currently configured for Tcl7.6/Tk4.2.
You must also have
OpenGL or
Mesa
(a free alternative to OpenGL) installed on your computer.
One should be familiar with Tcl, Tk, OpenGL, and C programming to use Togl
effectively.
Getting Togl
The current version of Togl is 1.2. You may download it from either:
Togl may also be obtained manually with ftp:
- Host: iris.ssec.wisc.edu
- Login: anonymous
- Password: your email address
- Directory: pub/misc
- File: Togl-1.2.tar.gz
The Makefile included with Togl is configured for SGI systems. It shouldn't
be hard to adapt it for others.
In practice, you'll just add togl.c to your application's Makefile.
Using Togl With Your Application
Since the Togl code is in just three files (togl.c, togl.h and tkInt.h) it's
probably most convenient to just include those files with your application
sources. The Togl code could be made into a library but that's not necessary.
C Togl Functions
These are the Togl commands one may call from a C program.
#include "togl.h"
Setup and Initialization Functions
int Togl_Init( Tcl_Interp *interp )
-
Initializes the Togl module. This is typically called from the
Tk_Main() callback function.
void Togl_CreateFunc( Togl_Callback *proc )
void Togl_DisplayFunc( Togl_Callback *proc )
void Togl_ReshapeFunc( Togl_Callback *proc )
void Togl_DestroyFunc( Togl_Callback *proc )
-
Register C functions to be called by Tcl/Tk when a widget is realized,
must be redrawn, is resized, or is destroyed respectively.
Each C callback must be of the form:
void callback( struct Togl *togl )
{
...your code...
}
void Togl_CreateCommand( char *cmd_name, Togl_CmdProc *cmd_proc )
-
Used to create a new Togl sub-command. The C function which implements
the command must be of the form:
int callback( struct Togl *togl, int argc, char *argv[] )
{
...your code...
return TCL_OK or TCL_ERROR;
}
Drawing-related Commands
void Togl_PostRedisplay( struct Togl *togl )
-
Signals that the widget should be redrawn. When Tk is next idle the
user's C render callback will be invoked. This is typically called
from within a Togl sub-command which was registered with
Togl_CreateCommand().
void Togl_SwapBuffers( struct Togl *togl )
-
Swaps the front and back color buffers for a double-buffered widget.
glFlush() is executed if the window is single-buffered. This is
typically called in the rendering function which was registered with
Togl_DisplayFunc().
Query Functions
char *Togl_Ident( struct Togl *togl )
-
Returns a pointer to the identification string associated with an Togl
widget or NULL if there's no identifier string.
int Togl_Width( struct Togl *togl )
-
Returns the width of the given Togl widget. Typically called in the
function registered with Togl_ReshapeFunc().
int Togl_Height( struct Togl *togl )
-
Returns the height of the given Togl widget. Typically called in the
function registered with Togl_ReshapeFunc().
Tcl_Interp *Togl_Interp( struct Togl *togl )
-
Returns the Tcl interpreter associated with the given Togl widget.
Color Index Mode Functions
These functions are only used for color index mode.
unsigned long Togl_AllocColor( struct Togl *togl, float red, float green, float blue )
-
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 -privatecmap option is false.
void Togl_FreeColor( struct Togl *togl, unsigned long index )
-
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 -privatecmap option is false.
void Togl_SetColor( struct Togl *togl,
int index, float red, float green, float blue )
-
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 -privatecmap option
is true.
Font Functions
GLuint Togl_LoadBitmapFont( struct Togl *togl,
const char *fontname )
-
Load the named font as a set of glBitmap display lists.
fontname may be one of
- TOGL_BITMAP_8_BY_13
- TOGL_BITMAP_9_BY_15
- TOGL_BITMAP_TIMES_ROMAN_10
- TOGL_BITMAP_TIMES_ROMAN_24
- TOGL_BITMAP_HELVETICA_10
- TOGL_BITMAP_HELVETICA_12
- TOGL_BITMAP_HELVETICA_18
- or any X11 font name
Zero is returned if this function fails.
After Togl_LoadBitmapFont() has been called, returning fontbase,
you can render a string s with:
glListBase( fontbase );
glCallLists( strlen(s), GL_BYTE, s );
void Togl_UnloadBitmapFont( struct Togl *togl, GLuint fontbase )
-
Destroys the bitmap display lists created by by Togl_LoadBitmapFont().
Client Data Functions
void Togl_SetClientData( struct Togl *togl, ClientData clientData)
-
clientData is a pointer to an arbitrary user data structure.
Each Togl struct has such a pointer.
This function set's the Togl widget's client data pointer.
ClientData Togl_GetClientData( const struct Togl *togl )
-
clientData is a pointer to an arbitrary user data structure.
Each Togl struct has such a pointer.
This function returns the Togl widget's client data pointer.
Overlay Functions
These functions are modelled after GLUT's overlay sub-API.
void Togl_UseLayer( struct Togl *togl, int layer )
-
Select the layer into which subsequent OpenGL rendering will be
directed. layer may be either TOGL_OVERLAY or
TOGL_NORMAL.
void Togl_ShowOverlay( struct Togl *togl )
-
Display the overlay planes, if any.
void Togl_HideOverlay( struct Togl *togl )
-
Hide the overlay planes, if any.
void Togl_PostOverlayRedisplay( struct Togl *togl )
-
Signal that the overlay planes should be redraw.
When Tk is next idle the user's C overlay display callback will be invoked.
This is typically called from within a Togl sub-command which was
registered with Togl_CreateCommand().
void Togl_OverlayDisplayFunc( Togl_Callback *proc )
-
Registers the C callback function which should be called to redraw the
overlay planes. This is the function which will be called in
response to Togl_PostOverlayRedisplay().
The callback must be of the form:
void RedrawOverlay( struct Togl *togl )
{
...your code...
}
Tcl Togl commands
These are the Togl commands one may call from a Tcl program.
togl pathName [options]
-
Creates a new togl widget with name pathName and
an optional list of configuration options. Options include:
Option Default Comments
--------------- ------- ------------------------------------------------
-width 400 Width of widget in pixels.
-height 400 Height of widget in pixels.
-ident "" A user identification string ignored by togl.
This can be useful in your C callback functions
to determine which Togl widget is the caller.
-rgba true If true, use RGB(A) mode
If false, use Color Index mode
-double false If false, request a single buffered window
If true, request double buffered window
-depth false If true, request a depth buffer
-accum false If true, request an accumulation buffer
-alpha false If true and -rgba is true, request an alpha
channel
-stencil false If true, request a stencil buffer
-privatecmap false Only applicable in color index mode.
If false, use a shared read-only colormap.
If true, use a private read/write colormap.
-overlay false If true, request overlay planes.
-stereo false If true, request a stereo-capable window.
pathName configure
-
Returns all configuration records for the named togl widget.
pathName configure -option
-
Returns configuration information for the specifed option
which may be one of:
-width
-
Returns the width configuration of the widget in the form:
-width width Width W w
where W is the default width in pixels
and w is the current width in pixels
-height
-
Returns the height configuration of the widget in the form:
-height height Height H h
where H is the default height in pixels
and h is the current height in pixels
-extensions
-
Returns a list of OpenGL extensions available. For example:
GL_EXT_polygon_offset GL_EXT_vertex_array
pathName configure -option value
-
Reconfigure an togl widget. option may be one of:
-width
- Resize the widget to value pixels wide
-height
- Resize the widget to value pixels high
pathName render
-
Causes the render callback function to be called for pathName.
pathName swapbuffers
-
Causes front/back buffers to be swapped if in double buffer mode.
pathName makecurrent
-
Make the widget specified by pathName the current one.
Demo programs
There are three demo programs:
- double - compares single vs double buffering with two Togl widgets
- texture - lets you play with texture mapping options
- index - demo of using color index mode
To compile the demos, edit the Makefile to suit your system, then
type "make".
The Makefile currently works with Linux.
To run a demo just type "double" or "texture" or "index".
Reporting Bugs
If you find a bug in Togl please report it to both Ben and Brian.
When reporting bugs please provide as much information as possible.
Also it's very helpful to us if you can provide an example program
which demonstrates the problem.
Version History
Version 1.0, March 1996
Version 1.1 (never officially released)
- Added Togl_LoadBitmapFont function
- Fixed a few bugs
Version 1.2, November 1996
- added swapbuffers and makecurrent Tcl commands
- More bug fixes
- Upgraded to suport Tcl 7.6 and Tk 4.2
- Added stereo and overlay plane support
- Added Togl_Get/SetClientData() functions
- Added Togl_DestroyFunc()
Future plans
Last edited on December 14, 1996 by Brian Paul.