racket/collects/sgl/scribblings/overview.scrbl
Matthew Flatt 82c212625b sgl docs
svn: r9362
2008-04-18 18:49:23 +00:00

32 lines
1.6 KiB
Racket

#lang scribble/doc
@(require "common.ss")
@title[#:tag "overview"]{Using OpenGL}
The @schememodname[sgl/gl] library provides direct access to the
C-style OpenGL API, whereas the @schememodname[sgl] library provides a
more Scheme-like interface. The @schememodname[sgl/gl] library
provides a binding for each @tt{#defined} constant and for most
functions in OpenGL 1.5 and GLU 1.3. The functions perform comparable
checking to their C-language counterparts; they check the types of
their arguments, but do not check the length of array arguments. The
@schememodname[sgl] library provides wrappers around many of the
functions in the @schememodname[sgl/gl] library to present a more
Scheme-friendly interface, including function names that follow Scheme
conventions, and checked, symbolic enumeration arguments, and
array-length checks.
@bold{Warning on Safety:} OpenGL programming is inherently unsafe,
even when using only the @schememodname[sgl] library. Although
@schememodname[sgl] checks the arguments to each function call,
violation of higher-level assumptions of the system's OpenGL library
can cause it to crash, bringing the entire Scheme system down. For
example, sending a large number of vertices in a single @tt{glBegin}
causes at least some GL implementations to crash.
Some examples are available in the @filepath{examples} directory of
the @filepath{sgl} collection in the PLT Scheme installation. For
@filepath{alpha.ss}, try choosing the @filepath{sk.jpg} image distritbuted
with PLT Scheme in the @filepath{icons} collection; you may have to
press the ``t'' key a few times if the spinning cube is blank.