This is mainly a developer's function, so most users can skip this section. You will need some Python knowledge to understand the example.
Athough all OpenGL rendering in PyMOL is perfomed at the C level, PyOpenGL provides an alternative binding of the OpenGL API from Python. Unfortunately, it is impossible for PyMOL to produces ray-traced images of objects rendered using PyOpenGL. Nevertheless, PyOpenGL can be used within PyMOL via Callback objects for pure OpenGL-based rendering pursposes. If you need your graphics to ray-tracable, then you should use Compiled Graphics Objects (see previous section).
Callback objects are trivial Python objects which have a "__call__" method for rendering and a "get_extent" method which tells PyMOL where in space the object is located. Once a callback object has been loaded into PyMOL, Python will automatically call this object when needed to update the screen.
PyMOL includes a copy of PyOpenGL under the pymol module hierarchy (pymol.opengl), but usage of this copy is of course optional. You can instead bind to the latest version without problems, provided that you install it yourself into the Python library that PyMOL is using by default.
NOTE: The current Window's version of PyMOL does not include Numeric, which makes heavy usage of PyOpenGL from within PyMOL impractical under Windows at present.
The following Python program shows how you can use a Callback object within PyMOL to perform rendering using OpenGL. For more examples, see the directory "$PYMOL_PATH/examples/devel".
from pymol.opengl.gl import * from pymol.callback import Callback from pymol import cmd class myCallback(Callback): def __call__(self): glBegin(GL_LINES) glColor3f(1.0,1.0,1.0) glVertex3f(0.0,0.0,0.0) glVertex3f(1.0,0.0,0.0) glVertex3f(0.0,0.0,0.0) glVertex3f(0.0,2.0,0.0) glVertex3f(0.0,0.0,0.0) glVertex3f(0.0,0.0,3.0) glEnd() def get_extent(self): return [[0.0,0.0,0.0],[1.0,2.0,3.0]] cmd.load_callback(myCallback(),'gl01')
Callback objects are loaded into PyMOL using the "load_callback" function.
cmd.load_callback(object,name,state)