1.3 - Computer Graphics - A Brief History¶
The first computer graphics design system was developed by Evan Sutherland as his PhD thesis at MIT in 1963. It was called Sketchpad and allowed a user to sketch a mechanical part on a computer screen, place constraints on the part, and have the computer calculate the exact design of the part. It was revolutionary and computer graphics took off “as a thing” from that time forward.
In the early days, if you wanted to create computer graphics you had to write programs that directly talked to the graphics hardware. As new hardware designs were created, the software had to be completely re-written to work with the new hardware. Throughout the 1970’s many “graphics libraries” were created to solve this problem, but most of the libraries worked with individual operating systems and could not be easily ported to new operating systems or new hardware. In the 1980’s the ISO (International Organization for Standardization) attempted to create a standard computer graphics library called PHIGS. It was claimed to be the best and final answer for creating computer graphics across all computing platforms. However, it was a complete failure for one simple reason: not only did PHIGS provide a library of functionality for drawing 3D graphics, it specified exactly how you had to store and organize your graphics data. Programmers hated it.
GL and OpenGL¶
The premiere computer graphics company in the late 1980’s and throughout the 1990’s was Silicon Graphics, Inc. They were a hardware company, but they shipped their computers with a proprietary computer graphics application programmer interface (API) known as IRIS Graphics Language (IRIS GL). Programmers of the day were searching for an alternative to PHIGS and in 1992 Silicon Graphics release their graphics library (GL) as an “open” standard called OpenGL. To quote Wikipedia, “This meant that for the first time, fast, efficient, cross-platform graphics programs could be written. To this day, OpenGL remains the only real-time 3D graphics standard to be portable across a variety of operating systems. OpenGL-ES even runs on many types of cell phones. Its main competitor (Direct3D from Microsoft) runs only on Microsoft Windows-based machines and some consoles.”
OpenGL has changed drastically over the years. You can see the version details here. The major changes between versions are listed below for brevity.
- 1992: OpenGL 1.0 - A fixed function pipeline for creating computer graphics. A programmer fed vertex data into the pipeline and out came a 3D rendering.
- 2004: OpenGL 2.0 - The GPU became programmable. Programmers could write shader programs that were compiled into hardware. Fixed function pipeline programs and shader programs are not compatible.
- 2008: OpenGL 3.0 - Graphics data was moved from the CPU RAM to GPU memory for faster rendering.
- 2010: OpenGL 4.0 - Advanced shader language features and advanced texture mapping.
- 2014: OpenGL 4.5 - The most recent version.
OpenGL ES¶
OpenGL is a hardware specification that requires fairly powerful hardware to run. The software drivers for the API are very large and complex. As mobile, lower power devices starting appearing on the market, a 3D graphics solution was desired for these devices. Thus OpenGL ES (Embedded Subset) was created. From the opengl web site, OpenGL ES “slims down the rather large OpenGL API to the bare essentials, so that it can be implemented on devices with simpler, cheaper hardware, and above all, low enough power requirements to run on batteries. For example, it is available as standard on smartphones running both Apple’s IOS and Google’s Android operating system.” OpenGL ES has continually evolved from version 1.0 in 2003 to the most recent version 3.2. Full details can be found here.
WebGL¶
Software developers have continually looked for ways to ” write once, run anywhere ”. This was the Java language slogan created by Sun Microsystems in the late 1990’s. If software developers can write programs that run on multiple platforms, they have the potential to make greater profits from their efforts. For some, the web browser is the ideal target for “write once, run anywhere,” especially with the release of HTML version 5.0. The added features to HTML make it possible to write web applications that are sophisticated, powerful, and cross platform. Making the graphics processing unit (GPU) accessible in a browser became a reality with the creation of WebGL.
What is WebGL? From the WebGL Wikipedia page, “WebGL (Web Graphics Library) is a JavaScript API for rendering interactive 3D computer graphics and 2D graphics within any compatible web browser without the use of plug-ins. WebGL is integrated completely into all the web standards of the browser allowing GPU accelerated usage of physics and image processing and effects as part of the web page canvas. WebGL elements can be mixed with other HTML elements and composited with other parts of the page or page background. WebGL programs consist of control code written in JavaScript and shader code that is executed on a computer’s Graphics Processing Unit (GPU).”
WebGL is OpenGL ES 2.0 implemented for any HTML 5.0 compliant web browser. Because all web browsers support JavaScript, WebGL defines a JavaScript API for real-time, 3D graphics rendering. And since basically all devices today have a GPU, this means that you can write one program that will execute on basically all computer devices in existence today – and tomorrow – thanks to the HTML 5.0 and WebGL standards.
So what is WebGL? It is the future of real-time 3D computer graphics.
Summary¶
The following diagram shows the basic progression of OpenGL, OpenGL ES, and WebGL.
Bottom line: if you understand how to program WebGL programs, you will understand basic computer graphics programming for all computing devices.
Glossary¶
- GL
- graphics language - a proprietary software system for creating 3D computer graphics that was created by Silicon Graphics Inc. in the 1980’s
- OpenGL
- a device independent software system for creating 3D computer graphics that was released to the public by Silicon Graphics Inc. in 1992. It has gone through constant upgrades, enhancements, and re-designs.
- OpenGL ES
- OpenGL embedded subset - a stripped down version of OpenGL for cheaper, low-power hardware
- WebGL
- a device independent software system for creating 3D computer graphics in a web browser. It is an implementation of OpenGL ES 2.0 in JavaScript.