QuickDraw 3D

QuickDraw 3D

QuickDraw 3D, or QD3D for short, is a 3D graphics API developed by Apple Computer starting in 1995, originally for their Macintosh computers, but delivered as a cross-platform system.

QD3D provided a high-level API with a rich set of 3D primitives that was generally much more full-featured and easier to develop than low-level APIs such as OpenGL or Direct3D Fact|date=September 2008. Below this was a cleanly-separated hardware abstraction layer known as RAVE that allowed the system to be ported to new hardware easily. On the downside, QD3D used a number of Apple-specific ideas about how 3D hardware should work, and initially performed poorly due to the lack of hardware acceleration.

Apple abandoned work on QD3D after Steve Jobs took over in 1998, and announced that future 3D support would be based on OpenGL.

3D in general

Most 3D toolkits concentrate on the lowest levels of the 3D rendering pipeline. These include describing the basic geometry of the “world”, and systems for describing objects based on that geometry. Key to high performance in 3D applications is limiting the data that needs to be manipulated, and storing that in an efficient way in order to reduce the amount of memory that needs to be transferred to the display hardware during drawing. Computer bus operations can be many times slower than the processing of that data, so every effort must be made to reduce the overall load.

For instance, the OpenGL system consists primarily of a system for describing geometry in various ways that eliminate common vertices from the data, along with commands for manipulating the objects and drawing them in the world. To further reduce traffic, OpenGL is a “stateful” system, in which the result of drawing an object into the world will depend on the state of the system set up in previous commands. The advantage to this approach is that most graphics share considerable amounts of state, so the setup information can be sent once, followed by many drawing operations. This also means that complex programs have to carefully track and restore state during drawing, an expensive operation that can actually lead to decreased performance if done too often.

Higher-level concepts of the 3D world are generally not included in low-level libraries. For instance, OpenGL has no system for storing the relationships between parts or building objects out of other objects. This is particularly important in 3D graphics, where objects are generally constructed out of a number of parts that are moved together to produce a larger model. This grouping, known as a scene graph, is typically left to the end-user to develop on their own, although a number of attempts to provide a standardized stateless scene graph were made several times over OpenGL’s history. Issues such as interacting with the model or placing the view in a window are generally left to add-on libraries, in order to give the developer complete control over the system.

QD3D

QD3D had the disadvantage of running on computers with considerably less power than the SGI systems OpenGL was designed for. This guided the developers to cleanly separate the system into a high-level and low-level set of APIs, so that the lower levels could be implemented entirely in hardware. Since the high-level API was not intended to run directly on hardware, designers could pack it with as many features as they wanted.

The result was that QD3D offered a considerably richer programming system for developers, one that dramatically reduced the workload for basic applications. QD3D provided functionality not only for storing and manipulating a scene graph, but also added a number of easy to use 3D objects, UI elements, and even input controllers. The suite allowed developers to add 3D support to their applications with ease, in a way that had a consistent UI when compared to other 3D applications using the platform. Apple additionally introduced the 3DMF file format in order to allow developers to exchange 3D models between applications, providing all the needed code for loading and saving 3DMF files.

Additional functionality included a “plug-in” rendering system, which allowed an application to render a scene in a variety of styles. Without changing the model or their code, developers could render the same scene interactively or (with suitable plug-ins) using methods such as ray-tracing or hidden-line.

The QD3D API was an “object-like” system based on pure-C code. The various structures were carefully constructed to contain pointers to other important objects. Objects knew all the drawing state they needed, thereby eliminating code that would normally be needed when developing under OpenGL Fact|date=September 2008. For obvious reasons the APIs were also tightly integrated with the Mac OS, allowing the developer to bring up an interactive 3D view in a window with little code. The developer’s task was essentially to provide the models and “behavior” for the world, as opposed to the basic 3D framework that was needed for lower level libraries.

To contrast the two approaches, consider this sort of task that QD3D could directly support:

load the model “human”, load the style “t-shirt”, apply “t-shirt” to “human”, draw

Under OpenGL this task would resemble something more like:

load the model “human”, load the texture “t-shirt”, enable the texture “t-shirt”, draw

On the downside, QD3D’s layering introduced performance issues. For instance, the system stored and automatically set state for every object before drawing. This made development much easier, but also made the performance drop in a way the developer had no direct control over. Under OpenGL the user was forced to handle state themselves, but in doing so could often avoid the majority of state-setting commands and thereby improve performance.

Another area of concern is that the scene graph was hidden from view, and considerable improvements in rendering performance can be made by carefully “culling” the graph to remove those objects that are not in view. Although later releases of QD3D gained the ability to automatically perform visibility culling (based on the grouping of objects in the scene graph), OpenGL’s lack of support for this feature typically forced developers to implement it from the start.

RAVE

In order to deal with the performance-critical rasterization operation, Apple designed QD3D to sit on top of a separate package known as RAVE (Rendering Acceleration Virtual Engine). The result was something much closer to OpenGL — more primitive to program, but with increased control over rendering.

Although RAVE did what it intended to do, the effort was essentially doomed. Good low-level 3D performance relies not only on the programmer to provide efficient models, but high-quality drivers for the hardware as well. This is where RAVE failed. Developers had repeatedly watched the “next big thing” come out of Apple only to see it be killed off in the next company reorganization, and were increasingly wary of putting any effort into supporting Apple’s latest developments. By 1996 the market generally felt Apple was doomed to bankruptcy, making matters considerably worse. Microsoft was at the same time trying to introduce their own similar library, Direct3D (D3D), and even though QD3D beat it to market and was technically superior, it was soon clear to everyone that it was destined to be ignored in favor of Direct3D.

At the same time the expected market for 3D desktop applications simply didn’t materialize. Most users stayed with their workstation-based modelers for performance reasons, and most other users have limited 3D needs. 3D games, on the other hand, took off at about this time, and drove the widespread availability of consumer-level 3D hardware.

Although RAVE was designed to be cross-platform, only Mac hardware developers (ATI, NVIDIA, and 3dfx) produced drivers for it. This left any comparison between QD3D and alternative APIs one-sided, as outside of the Mac QD3D was forced to fall back to a software RAVE implementation.

witch to OpenGL

As OpenGL gained traction on Windows (often credited to id Software, who championed the API over D3D), hardware developers were increasingly designing future hardware against the future feature set planned for Microsoft’s D3D. Through its extension mechanism OpenGL was able to track these changes relatively easily, while RAVE’s feature set remained relatively fixed.

At the Macworld Expo in January 1999, Apple announced that neither QuickDraw 3D nor RAVE would be included in Mac OS X. The company laid off the development staff in June of 1999, replacing the in-house technology with OpenGL after buying a Mac implementation and key staff from Conix.

Today there remains no standard high-level API for 3D graphics. Several attempts have been made, including OpenGL++ and the SGI/Microsoft Fahrenheit graphics API, but none of these have made it to production.

After Apple withdrew support for QD3D, an Open Source implementation of the QD3D API was developed externally. Known as Quesa, this implementation combines QD3D’s higher level "concepts" with an OpenGL renderer. As well as cross-platform hardware acceleration, this library also allows the use of the QD3D API on platforms never supported by Apple (such as Linux)

Applications

Applications published employing RAVE includes Graphing Calculator in the 1990s, shipped with every Power Macintosh.

ee also

*QuickDraw
*OpenGL
*DirectX

External links

* [http://developer.apple.com/documentation/QuickTime/QD3D/qd3d_book.htm 3D Graphics Programming with QuickDraw 3D 1.5.4] - QD3D manual
* [http://www.mactech.com/articles/develop/issue_22/quickdraw.html QuickDraw 3D: A New Dimension for Macintosh Graphics] - prerelease article, June 1995
* [http://docs.info.apple.com/article.html?artnum=17411 QuickDraw 3D: Questions and Answers]
* [http://www.byte.com/art/9606/sec11/art4.htm Must-See 3-D Engines] - compares QD3D, OpenGL and Direct3D


Wikimedia Foundation. 2010.

Игры ⚽ Нужна курсовая?

Look at other dictionaries:

  • QuickDraw — also refers to equipment used for rock climbing. QuickDraw is the 2D graphics library and associated Application Programming Interface (API) which is a core part of the classic Apple Macintosh operating system. It was initially written by Bill… …   Wikipedia

  • QuickDraw GX — was a replacement for the QuickDraw (QD) 2D graphics engine and Printing Manager inside the classic Mac OS. Although GX was based on the same general geometry and dimensions of the original QD engine, the underlying drawing platform became a… …   Wikipedia

  • Quickdraw GX — war als Ablösung für die QuickDraw (QD) 2D Graphicsengine und den Printing Manager des Mac OS „Classic vorgesehen. Beschreibung Obwohl GX auf denselben grundlegenden Geometrien und Metriken wie die originale QuickDraw Engine basierte, wurde die… …   Deutsch Wikipedia

  • QuickDraw — ist auch der Englische Begriff für ein Expressset. QuickDraw (kurz: QD) war die 2D Bildschirmbeschreibungssprache des Macintosh bis Mac OS 9.2.2., mit Mac OS X wurde sie von Quartz abgelöst. QuickDraw war Bestandteil des Macintosh Baukastens. Die …   Deutsch Wikipedia

  • QuickDraw GX — war als Ablösung für die QuickDraw (QD) 2D Grafikengine und den Printing Manager des Mac OS „Classic vorgesehen. Beschreibung Obwohl GX auf denselben grundlegenden Geometrien und Metriken wie die originale QuickDraw Engine basierte, wurde die… …   Deutsch Wikipedia

  • QuickDraw —   [dt. »schnelles Zeichnen«], eine Systemkomponente des Macintosh Betriebssystems (Mac OS), die seit den ersten Mac Rechnern bis zum Mac OS 9.0 für die Bildschirm und Druckausgabe von Text und Grafiken zuständig war. Die ursprüngliche Basic… …   Universal-Lexikon

  • QuickDraw — est le nom d une bibliothèque graphique 2D qui était au cœur des systèmes d exploitations Macintosh classiques. QuickDraw a été développé initialement par Andy Hertzfeld et Bill Atkinson en quatre années homme. Il existe toujours dans les… …   Wikipédia en Français

  • Quickdraw — is also a graphics software library made by Apple Computer. Quickdraws are used by rock climbers to connect the climbing rope to bolt anchors or other protection, while lead climbing. Outdoors or indoors, the top, straight carabiner is clipped to …   Wikipedia

  • quickdraw — noun A set of two carabiners connected by a strap …   Wiktionary

  • Quickdraw — ● np. m. ►APPLE Routines graphiques des Macs, contenues en ROM, jusqu à MacOS 9 …   Dictionnaire d'informatique francophone

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”