Before you dive in and start creating your own graphic images, you need to understand a few basic concepts about what CorelDRAW does--both on your screen and behind the scenes. That's what this section is about.
Teach Yourself CorelDRAW 8 in 24 Hours
Before you dive in and start creating your own graphic images, you need to understand a few basic concepts about what CorelDRAW does--both on your screen and behind the scenes. That's what this section is about.
Dreamweaver MX - Tutorial Part 1
Understanding the Dreamweaver MX Screen
We will begin this tutorial by looking at the toolbars and menus available to you in Dreamweaver MX. These tools will make your web development experience faster and easier. Below is an overview of the screen. In order to introduce you to the Dreamweaver MX screen, small labels will appear as you roll over each section of the screen image below with your mouse cursor. Try to move your mouse around the different areas to familiarize yourself with the screen before we continue a more detailed description of each section.
Vision Systems
The first stage of any vision system is the image acquisition stage.
After the image has been obtained, various methods of processing can be applied to the image to perform the many different vision tasks required today.
However, if the image has not been acquired satisfactorily then the intended tasks may not be achievable, even with the aid of some form of image enhancement
2D Image Input
A digitised image is one whereFor computational purposes, we may think of a digital image as a two-dimensional array where x and y index an image point. Each element in the array is called a pixel (picture element)
spatial and greyscale values have been made discrete. intensity measured across a regularly spaced grid in x and y directions intensities sampled to 8 bits (256 values)2D Input Devices
TV Camera or Vidicon TubeA first choice for a two-dimensional image input device may be a television camera -- output is a video signal:
Image focused onto a photoconductive target. Target scanned line by line horizontally by an electron beam Electric current produces as the beam passes over target. Current proportional to the intensity of light at each point. Tap current to give a video signal.This form of device has several disadvantages.
PNG - The Definitive Guide
Part I is intended for designers, web site owners, casual image creators, and web surfers--anyone who wants a quick start on using PNG images in a variety of applications. Such users may need only a brief overview of PNG features, but they want to know what applications support the format and to what extent, how to invoke PNG-specific features within the applications, and how to work around certain bugs or incompatibilities in the applications. Of course, a book like this cannot possibly stay current, particularly not when it comes to software, but every effort has been made to ensure that the information is accurate as of the day this is written (mid-April 1999).
- Chapter 1, "An Introduction to PNG", covers some basic concepts of computer images and file formats, explains how PNG fits in and where using it is most appropriate (and most inappropriate!), and ends with an in-depth look at an image-editing application with particularly good PNG support.
- Chapter 2, "Applications: WWW Browsers and Servers", looks at PNG support in web browsers and servers and shows how to use the HTML OBJECT tag and server-side content negotiation to serve PNG images to browsers capable of viewing them.
- Chapter 3, "Applications: Image Viewers", lists more than 75 applications capable of viewing PNG images, with support for a dozen operating systems. Viewers that are additionally capable of converting to or from other image formats are so noted.
- Chapter 4, "Applications: Image Editors", looks at PNG support in five of the most popular image editors, showing how to invoke such features as gamma correction and alpha transparency, and indicating some of the problems unwary users may encounter.
- Chapter 5, "Applications: Image Converters", covers five conversion applications in detail, including one specifically designed to optimize PNG images and another designed to test PNG images for conformance to the specification. In addition, the chapter lists another 16 dedicated image converters beyond those in Chapter 3, "Applications: Image Viewers".
- Chapter 6, "Applications: VRML Browsers and Other 3D Apps", looks at PNG as a required texture format of the VRML 97 specification and investigates the level of conformance of seven browsers. It also lists a dozen PNG-supporting applications designed for the editing or rendering of 3D scenes.
Part II, The Design of PNG
Part II looks at the PNG format from an historical and technical perspective, detailing its structure and the rationale behind its design. Part II is intended for more technical readers who want to understand PNG to its core.
- Chapter 7, "History of the Portable Network Graphics Format", looks at the events leading up to the creation of PNG, some of the design decisions that went into the format, how it has fared in the subsequent years, and what to expect for the future.
- Chapter 8, "PNG Basics", covers the basic ``chunk'' structure of PNG files and compares PNG's level of support for various fundamental image types against that of other image formats.
- Chapter 9, "Compression and Filtering", delves into the heart of PNG's compression engine, provides the results of some real-world compression tests, and offers a number of tips for improving compression to both users and programmers of the format.
- Chapter 10, "Gamma Correction and Precision Color", discusses one of the least understood but most important features of PNG, its support for platform-independent image display. That is, in order for an image to appear the same way on different computer systems or even different print media, it is necessary for both the user and the program to understand and support gamma and color correction.
- Chapter 11, "PNG Options and Extensions", details the optional features supported by PNG, including text annotations, timestamps, background colors, and other ancillary information.
- Chapter 12, "Multiple-Image Network Graphics", is a brief look at PNG's multi-image cousin, MNG, which supports animations, slide shows, and even highly efficient storage of some types of single images.
Part III, Programming with PNG
Part III covers three working, libpng-based demo programs in detail, and lists a number of other toolkits that offer PNG support for various programming languages and platforms. It is intended for programmers who wish to add PNG support to their applications.
- Chapter 13, "Reading PNG Images", is a detailed tutorial on how to write a basic PNG-reading display program in C using the official PNG reference library. The application is divided into a generic PNG back end and platform-specific front ends, of which two are provided (for 32-bit Windows and the X Window System).
- Chapter 14, "Reading PNG Images Progressively", inverts the logic of the previous chapter's demo program, simulating the design of a web browser's display-as-you-go PNG code. Progressive display of interlaced, transparent PNG images over a background image is supported.
- Chapter 15, "Writing PNG Images", shows how to create a basic PNG-writing program. The supplied code compiles into a simple command-line program under both Windows and Unix, and it includes support for interlacing, gamma correction, alpha transparency, and text annotations.
- Chapter 16, "Other Libraries and Concluding Remarks", lists a number of alternative libraries and toolkits, both free and commercial, including ones for C, C++, JavaTM, Pascal, tcl/tk, Python, and Visual Basic. The chapter ends with a look back at what parts of the PNG design process worked and what didn't, and also a look forward at what lies ahead.
The References section lists technical references and resources for further information, both printed and electronic. - The Glossary defines a number of acronyms and technical terms used throughout the book.
Compute!'s First Book of Atari Graphics
For some reason, many people are intimidated by the programming steps required to create computer graphics. Probably this is because creating computer graphics is not as easy as it looks. The typical buyer of a personal computer is dazzled in the store by all the fantastic arcade games and impressive graphics demos with which the sales people are armed. It all looks so simple. Then the buyer eagerly unpacks the computer at home and quickly discovers that even crude pictures cannot be created without screenfuls of cryptic programming that seemingly have more in common with Sanskrit than English.
But there is hope. It's not really that hard--honest. Nobody is promising that you'll be able to duplicate Star Raidersor PacManany time soon, but the basics of computer graphics are quite easy to grasp for anyone who has some knowledge of BASIC programming. You don't need to be a math wizard, either. The most valuable attributes are a willingness to learn and to experiment. And, of course, to be creative.
Atari graphics are particularly challenging to learn, mainly because the Atari computers have extremely versatile graphics. Luckily, Atari made it easier for us by including many special keywords in Atari BASIC that are dedicated to graphics. The first step, then, is to learn those keywords. And by the way, if you don't already have your Atari BASIC Reference Manualhandy, take a second to grab it. This book and the Manualshould help to explain each other.
The most basic of the keywords is the GRAPHICS command. This tells the computer which graphics mode you want, which in turn determines how the screen will look. The format is GRAPHICS (aexp), where (aexp) is any arithmetic expression that results in a positive integer (in other words, not a negative number or a fraction). For example, GRAPHICS 6 is a valid command which tells the computer you want graphics mode six. GRAPHICS 3 + 3 or GRAPHICS 3*2 would do the same thing.
Depending upon how old your Atari is, the GRAPHICS command gives you access to either nine or twelve different graphics modes. The reason for the difference is that earlier Ataris (generally, those shipped before late 1981) came with a TV controller chip called the CTIA. Later Ataris have a GTIA chip instead. The chips are fully compatible--programs written on CTIA Ataris will run on GTIA machines and vice versa--but the GTIA adds three new graphics modes. Users with CTIA chips can have their computers upgraded if they wish. (See "Atari Video Graphics And The New GTIA" in Chapter 6.)
Atari Graphics & Arcade Game Design
The only requirements for this book are an inquisitive mind, perseverance, and a good Assembler. Although prior Assembly language programming experience isn't necessary, you won't be able to write code without an Assembler.
We will attempt to explain the ideas in this book through a combination of text, drawings, flow charts, and working code. The concepts in this book may seem easy at times, and somewhat difficult at other times. The Atari is a complex machine with many idiosyncrasies. The hardware sometimes makes game design relatively easy, yet the concept of an interrupt-driven machine with its timing problems can make advanced programming frustrating. Out advice is to read the book in stages and try the examples. Learn how they work.
Vector Math for 3D Computer Graphics
Although primarily aimed at university computer science students, this tutorial is useful to any programmer interested in 3D computer graphics or 3D computer game programming. In spite of their appealing blood-and-gore covers, mass trade books on game programming require the same understanding of vectors and matrices as college text books (and usually defer these topics to the same skimpy mathematical appendix).
This tutorial is useful for more than computer graphics. Vectors and matrices are used in all scientific and engineering fields, and any other field that uses computers (are there any that don't?) In many fields, the vocabulary used for vectors and matrices does not match that used in computer graphics. But the ideas are the same, and reading these notes will take only a slight mental adjustment.
These notes assume that you have studied plane geometry and trigonometry sometime in the past. Notions such as point, line, plane, and angle should be familiar to you. Other notions such as sine, cosine, determinant, real number, and the common trig identities should at least be a distant memory.
Computer Graphics Primer
Computer Graphics C Version Second Edition
Java Personal OpenGL Tutorial (JPOT)
- JPot is platform independent.
- The interface is improved.
- There are more lessons.
- A tool is provided to generate lessons automatically.
As an accademic project, JPot is free for all non-commercial uses, and we are strongly welcome other contributions for JPot. Even though we can not be responsible for any consequence of using it, we still try our best to assist you when you have problem regarding using and working on JPot.
Using OpenGL in Visual C++
- Writing an OpenGL Program
- Simple 2-D Graphics
- Transformations and the Matrix Stack
- Simple 3-D Graphics
OpenGL Programming Guide Second Edition
This guide assumes only that you know how to program in the C language and that you have some background in mathematics (geometry, trigonometry, linear algebra, calculus, and differential geometry). Even if you have little or no experience with computer-graphics technology, you should be able to follow most of the discussions in How to Obtain the Sample Code xxi this book. Of course, computer graphics is a huge subject, so you may want to enrich your learning experience with supplemental reading.
- Computer Graphics: Principles and Practice by James D. Foley, Andries van Dam, Steven K. Feiner, and John F. Hughes (Reading, MA: Addison-Wesley, 1990)—This book is an encyclopedic treatment of the subject of computer graphics. It includes a wealth of information but is probably best read after you have some experience with the subject.
- 3D Computer Graphics: A User’s Guide for Artists and Designers by Andrew S. Glassner (New York: Design Press, 1989)—This book is a nontechnical, gentle introduction to computer graphics. It focuses on the visual effects that can be achieved rather than on the techniques needed to achieve them.
Once you begin programming with OpenGL, you might want to obtain the OpenGL Reference Manual by the OpenGL Architecture Review Board (Reading, MA: Addison-Wesley Developers Press, 1996), which is designed as a companion volume to this guide. The Reference Manual provides a technical view of how OpenGL operates on data that describes a geometric object or an image to produce an image on the screen. It also contains full descriptions of each set of related OpenGL commands—the parameters used by the commands, the default values for those parameters, and what the commands accomplish. Many OpenGL implementations have this same material on-line, in the form of man pages or other help documents, and it’s probably more up-to-date. There is also a http version on the World Wide Web; consult Silicon Graphics OpenGL Web Site (http://www.sgi.com/Technology/openGL) for the latest pointer. OpenGL is really a hardware-independent specification of a programming interface, and you use a particular implementation of it on a particular kind of hardware.
This guide explains how to program with any OpenGL implementation. However, since implementations may vary slightly—in performance and in providing additional, optional features, for example—you might want to investigate whether supplementary documentation is available for the particular implementation you’re using. In addition, you might have OpenGL-related utilities, toolkits, programming and debugging support, widgets, sample programs, and demos available to you with your system.
OpenGL Simple Shading Example -Sample Chapter
OpenGL Texture Mapping - Sample Chapter
- Understand what texture mapping can add to your scene
- Specify texture images in compressed and uncompressed formats
- Control how a texture image is filtered as it is applied to a fragment
- Create and manage texture images in texture objects and, if available, control a high-performance working set of those texture objects
- Specify how the color values in the image combine with those of the fragment to which it’s being applied
- Supply texture coordinates to indicate how the texture image should be aligned with the objects in your scene
- Generate texture coordinates automatically to produce effects such as contour maps and environment maps
- Perform complex texture operations in a single pass with multitexturing (sequential texture units)
- Use texture combiner functions to mathematically operate on texture, fragment, and constant color values
- After texturing, process fragments with secondary colors
- Perform transformations on texture coordinates using the texture matrix
- Render shadowed objects, using depth textures
So far, every geometric primitive has been drawn as either a solid color or smoothly shaded between the colors at its vertices—that is, they’ve been drawn without texture mapping. If you want to draw a large brick wall without texture mapping, for example, each brick must be drawn as a separate polygon. Without texturing, a large flat wall—which is really a single rectangle—might require thousands of individual bricks, and even then the bricks may appear too smooth and regular to be realistic.
Texture mapping allows you to glue an image of a brick wall (obtained, perhaps, by scanning in a photograph of a real wall) to a polygon and to draw the entire wall as a single polygon. Texture mapping ensures that all the right things happen as the polygon is transformed and rendered. For example, when the wall is viewed in perspective, the bricks may appear smaller as the wall gets farther from the viewpoint. Other uses for texture mapping include depicting vegetation on large polygons representing the ground in flight simulation; wallpaper patterns; and textures that make polygons look like natural substances such as marble, wood, and cloth. The possibilities are endless. Although it’s most natural to think of applying textures to polygons, textures can be applied to all primitives—points, lines, polygons, bitmaps, and images. Plates 6, 8, 18–21, and 24–32 all demonstrate the use of textures.
The OpenGL Utility Toolkit (GLUT) Programming Interface
- Multiplewindows for OpenGL rendering.
- Callback driven event processing.
- Sophisticated input devices.
- An “idle” routine and timers.
- A simple, cascading pop-up menu facility.
- Utility routines to generate various solid and wire frame objects.
- Support for bitmap and stroke fonts.
- Miscellaneous window management functions, including managing overlays.
An ANSI C implementation of GLUT for the X Window System [15] has been implemented by the author. Windows NT and OS/2 versions of GLUT are also available.
This documentation serves as both a specification and a programming guide. If you are interested in a brief introduction to programming with GLUT, look for the introductory OpenGL column [9] published in The X Journal. For a complete introduction to using GLUT, obtain the book Programming OpenGL for the XWindow System [10]. GLUT is also used by the 2nd edition of the OpenGL Programming Guide. Teachers and students interested in using GLUT in conjunction with a college-level computer graphics class should investigate Angel’s textbook Interactive Computer Graphics: A top-down approach with OpenGL [2] that uses GLUT for its OpenGL-based examples programs.
The remainder of this section describes GLUT’s design philosophy and usagemodel. The following sections specify the GLUT routines, grouped by functionality.
The final sections discuss usage advice, the FORTRAN binding, and implementation issues. AppendixA enumerates and annotates the logical programmer visible state maintained by GLUT. Appendix B presents the ANSI C GLUT API via its header file. Appendix C presents the FORTRAN GLUT API via its header file.
OpenGL Tutorial
Following are the content of this tutorial
Rendering Pipeline
Libraries
Include Files
Setting Up Compilers
2. Simple OpenGL Program
Initialization
Creating a Window
Display Function
Reshape Function
Main Loop
3. Geometric Objects
Points, Lines and Polygons
Drawing 3-D Objects
Transformations
Scaling
Translation
Rotation Display Lists
4. Viewing
Color
Shading
Viewing Transformation
Projection
Orthographic
Perspective Manipulating the Matrix Stacks
Light
Viewport Transformation
5. Input Devices and Interaction
Menu
Mouse
Keyboard
Animation
6. Selection
Name Stacks
Picking
Hits
Teach Yourself Illustrator 7 in 24 Hours
Teach Yourself Photoshop® in 14 Days
Teach Yourself Photoshop in 14 Days is going to be your help and your guide--at least to start. The stated goal is to make you not only proficient in the basics of Photoshop, but to create a learning environment in which you feel comfortable enough to experiment, test, and develop your own tips, tricks, and ultimately, skills.
This book will show you everything from the basics of opening files, manipulating selections, and working with layers all the way to creating images for publishing on the World Wide Web.
The skills build from chapter to chapter, starting at the basics and moving on to more complex techniques, but I have tried to make each day modular enough so that you can dive in and pick up a skill or technique no matter what day you are currently working on. And if you are having problems, consult the index for an answer.
The CD-ROM that accompanies this book contains all the files used in the tutorials. The files are at all stages of completion so that you might get a better sense of what is really happening as we examine different processes.
Notes are scattered throughout the chapters. These focus on higher-level techniques, tricks, and information that is not essential but useful. Use them to supplement your understanding of Photoshop.
Without further discussion, let's begin our 14-day journey through the basics of this fascinating and incredibly powerful software.
Introduction to Adobe Photoshop
extropia.com
VRML Tutorial
VRML Primer and Tutorial
As Mark Pesce [Pesce, 1995, p. 16] points out, the WWW had two fundamental dimensions: connectivity (the http protocol) and interface (i.e. the rendering of content, especially HTML and embedded URLS). VRML inserts itself seamlessly in the Web's connectivity. VRML browsers can access other VRML files via an URL. They can access any other format that then is passed to another application (e.g. an HTML browser or a HTML window). On the other hand HTML browsers can be configured to fire up VRML helper applications (or plug-ins). HTTP servers, finally, can be configured to tell the client that a VRML (*.wrl) document is transferred.
A short word on its history: The major impulse for VRML can be traced back to a ``birds of the feature sessions'' on ``Virtual Reality Markup Languages'' at the First International Conference on the World-Wide-Web, May 25-27, 1994 at CERN in Geneva. It's conceptual origins are older, e.g. (a) Science Fiction literature (e.g. [Gibson, 1994], [Stephenson, 1992]), (b) Mark Pesce's, P. Kennard's and Toni Parisi's ``Labyrinth'' system ([Pesce et al., 1994]) and proposal for a 3-D navigation and representation scheme and (c) more generally 3-D computer graphics (including VR). Based upon SGI's ``Open Inventor'' format, a almost final draft for VRML 1.0 was presented at the second WWW conference in fall 94 in Chicago. On April 3, 1995 SGI presented WebSpace, the first publicly available VRML browser. So all in all it took about a year to set standards and make the first browser available. Since VRML is a relatively simple format building upon a well defined standard, very quickly a number of modeling tools and convertors also became available.
In the next sections we will look at simple static VRML scences. These are built with VRML's symbolic description language. Note different VRML browsers all have a different user interface (e.g. for navigation and object examination). They also render things a bit differently. Most will also give you a ``quality'' choice (e.g. faster renderning and lower quality vs. slower rendering but better quality. For now, let's just assume that the user can move himself though 3D space by moving a camera through the space (and therefore what he sees on the display is what sees ``his'' camera).
VRML Interactive Tutorial
VRML Audio Tutorial
Texture Mapping in VRML
Whenever you see the word "example" highlighted on the page, you can click on it to see a VRML illustration of the process being discussed. I've put copies of the examples in the text to make it easier to see the syntax. I would suggest that you save the examples to your disk and modify them to help you understand the concepts we'll be talking about. Several people have asked me to make an archive containing all of the examples available for downloading. The archive for the VRML 1.0 section is called tex-examples.tar.gz.
There are several good books about VRML on the market and all of them discuss texture mapping. I would suggest that anyone interested in VRML get one or two and read up on the subject. Rest assured that any book you find will be at least partially out of date by the time it's published, but the basic information will still be very useful.
Introduction to VRML
VRML 2.0 is a scene description language which is human readable. There is currently no ratified API associated with VRML. The language has the following capabilities:
- Built in geometric primitives including face sets and solids
- Lighting, material, texure, movie control
- Spatialised sound
- Absolute time for animations
- The concept of an avatar to allow collision detection
- Hyperlinking, viewpoints and navigation methods
- The ability to extend the language through prototyping
- Event handling to detect when geometry is interacted with in some way
- Routing of events to allow one object to affect another
- Scripting in various languages which allows logic in the world
VRML files describe a scene graph structure which is parsed by a browser. The browser may be a plug-in for a web browser or a helper application.The scene graph is composed of nodes which fall into two categories, grouping nodes and others. These nodes may have routes between them, above and beyond the scene graph hierarchy, which define the possible interactions of one node with another. Nodes have fields which define what actual values the node has associated with it.
Within this scene graph certain special nodes, known as bindable, have stacks associated with them which allow them to be pushed and popped to control certain world parameters.
Confused? Don't be, all this is explained in the concepts sections. The bottom line is this, it has never been easier to write 3D graphics.
Introduction to VRML 97
- General information, such as this preface
- Tutorial slides and examples
The tutorial slides are arranged as a sequence of 500+ hyper-linked pages containing VRML syntax notes, VRML usage comments, or images of sample VRML worlds. Clicking on a sample world’s image, or the file name underneath it, loads the VRML world into your browser for you to examine yourself.
You can view the text for any of the VRML worlds using a text editor and see how I created a particular effect. In most cases, the VRML files contain extensive comments providing information about the techniques the file illustrates.
The tutorial notes provide a necessarily terse overview of VRML. I recommend that you invest in one of the VRML books on the market to get thorough coverage of the language. I am a co-author of one such VRML book, The VRML 2.0 Sourcebook. Several other good VRML books are on the market as well.
3D Graphics & VRML 2.0
Simulating Humans: Computer Graphics, Animation and Control
The decade of the 80's saw the dramatic expansion of high performance computer graphics into domains previously able only to irt with the technology. Among the most dramatic has been the incorporation of real-time interactive manipulation and display for human gures. Though actively pursued by several research groups, the problem of providing a virtual or synthetic human for an engineer or designer already accustomed to Computer-Aided Design techniques was most comprehensively attacked by the Computer Graphics Research Laboratory at the University of Pennsylvania. The breadth of that effort as well as the details of its methodology and software environment are presented in this volume.
This book is intended for human factors engineers requiring current knowledge of how a computer graphics surrogate human can augment their analyses of designed environments. It will also help inform design engineers of the state-of-the-art in human gure modeling, and hence of the human-centered design central to the emergent notion of Concurrent Engineering. Finally, it documents for the computer graphics community a major research effort in the interactive control and motion specification of articulated human figures.
Graphics Programming in Icon
Encyclopedia of Graphics File Formats, Second Edition
Part One, Overview, is an introduction to those computer graphics concepts that are especially helpful when you need to work with graphics file formats.
- Chapter 1, Introduction, introduces some basic terminology, and gives an overview of computer graphics data and the different types of graphics file formats used in computer graphics. This chapter also lists all of the formats described in this book.
- Chapter 2, Computer Graphics Basics, discusses some concepts from the broader field of computer graphics that are necessary for an understanding of the rest of the book.
- Chapter 3, Bitmap Files, describes the structure and characteristics of bitmap files.
- Chapter 4, Vector Files, describes the structure and characteristics of vector files.
- Chapter 5, Metafiles, describes the structure and characteristics of metafiles.
- Chapter 6, Platform Dependencies, describes the few machine and operating system dependencies you will need to understand.
- Chapter 7, Format Conversion, discusses issues to consider when you are converting between the different format types (e.g., bitmap to vector), as well as between formats within a type (e.g., vector to vector).
- Chapter 8, Working With Graphics Files, describes the issues that come up when you read, write, and test graphics files. It also covers the corruption and encryption of graphics files, the potential for virus infection in those files, and the issues involved in writing your own file formats and file format specifications, including copyright issues.
- Chapter 9, Data Compression, describes data compression, particularly as compression techniques apply to graphics data and the graphics files described in this book.
- Chapter 10, Multimedia, surveys multimedia formats and issues.
Part Two, Graphics File Formats, describes the graphics file formats themselves. There is one article per format or format set, and articles are arranged alphabetically. Each article provides basic classification information, an overview, and details of the format. In many cases we've included short code examples. We've also indicated whether the specification itself (or an article that describes the details of the format) is included on the CD-ROM, as well as code examples and images encoded in that format. Also provided in the articles are references for further information.
Part Three, Appendices, contains the following material:
- Appendix A, Graphics Files and Resources on the Internet, describes how to use a variety of information services on the Internet (email, USENET, FTP, Archie, and the World Wide Web) to obtain, post, and otherwise deal with graphics files. It includes a listing of recommended sources of information about computer graphics and graphics file formats.
- Appendix B, Graphics Files and Resources on the Commercial Services, provides pointers to information about graphics files and resources on CompuServe, America Online, and a variety of bulletin board systems (BBSs).
- Appendix C, Installation and Setup, describes how to get the online product up and running on your system.
Basic Graphics Programming With The Xlib Library
After reading this tutorial, one would be able to write very simple graphical programs, but not programs with a descent user interface. For such programs, one of the previously mentioned libraries would be used.
The X window system was developed with one major goal - flexibility. The idea was that the way things look is one thing, but the way things work is another matter. Thus, the lower levels provide the tools required to draw windows, handle user input, allow drawing graphics using colors (or black and white screens), etc. To this point, a decision was made to separate the system into two parts. A client that decides what to do, and a server that actually draws on the screen and reads user input in order to send it to the client for processing.
Visualization
- The Purpose of Visualization
Information visualization, Card, Mackinlay, Schneiderman (handout)
Spatial schemas in depictions, Tversky (handout)
Decision to launch the Challenger, Tufte (handout) - Data and Image Models
The eyes have it, Schneiderman (html)
Bertin and beyond, Green (html)
The structure of the information visualization design space, Card, Mackinlay (pdf) - Discussion of examples of good and bad visualizations
- Perception and Cognition
Small Multiples, In Envisioning Information
Layering, In Envisioning Information
Graphical perception, Spence and Lawandowsky (handout)
Integral vs. separable dimensions, Palmer (handout)
Graphical perception, Cleveland and McGill (html).
Demonstrations
Healey's preattentive vision applet
Rensink's change blindness applet
The Game of Set - Design Problem I
Diffusion tensor MRI, Dave Akers, Rachel Mackenzie
Ancestral trees, Jeff Klingner, Merrie Ringel - Space (On Being in the Right Space)
Escaping flatland, In Envisioning Information
Narratives of space and time, In Envisioning Information
Map Projections in PDF
Postmortem of an example, Bertin (handout)
A tour of Trellis graphics, R. Becker et al. (ps)
Table lens, Rao and Card, (acm) - Design Problem II
C++ classes and methods, Mike Cammarano, Daniel Horn
Network intrusion detection, Amir Lopatin, John Gerth - Color
Color and information, In Envisioning Information
Abstracting reality, MacEachren (handout)
Area Colors, Imhof (handout), Virtual Library
PRAVDA, Bergman, Treinish, Rogowitz
Color guidelines, Brewer
CIELUV and CIELAB Applets, P. Rhodes - Design Problem III
Gene arrays, Johann Won, Jessy Kang
Flows of people and commodities, Ron Yeh, Doantam Phan - Interaction
Dynamic queries, Ahlberg, C. and Shneiderman, B., (html)
Dynamic queries, starfield displays, and the path to Spotfire, html.
Demonstrations and videos
ggobi
Excentric labels
Homefinder
Cellphones
Fry's zipcodes
Attribute explorer and cone tree video
Table lens - Design Problem IV
User event logs (VIBE), Kjell Reutersward, Stace Peterson
Social networks, Mike Choy, Jed Crosby
Light fields, Bill Chen, Chris Hong - Trees and Graphs
Rheingold-Tilford (handout)
Kamada-Kawai (handout)
DOI-tree (html)
dot paper, Gansner et al. (pdf) - Self Illustrating Phenomena
- Temporal Photography
- Conveying Shape: Line Drawings
Dooley, Cohen, Line illustration (handout)
Hayes, Ross, Lines of sight (handout)
DeCarlo, et al, Suggestive contours (html) - Conveying Shape: Shading and Texturing
Gooch and Gooch, Communicating shape
Ramachandran, 2-D or not 2-D--that is the question (handout)
Interrante, Texture
Akers et al. Conveying shape with image-based relighting - Animation
Principles, Lasseter, (acm)
Animation: Can it facilitate?, B. Tversky et al., (handout)
Slithy, (html) - Graphical Integrity
Graphical integrity, Tufte, (handout)
Every map shows this, but not that, Wood, (handout)
Real-Time Graphics Architectures
- Introduction (Kurt, Pat)
- The graphics pipeline (Pat)
- Nuts and bolts (Kurt)
- Performance analysis and characterization (Pat)
- Framebuffers and displays (Kurt)
- Rasterization (Kurt)
- Texturing (Pat)
- Geometry (Kurt)
- Parallelism and communication (Pat)
- Trends in Graphics Architectures, Tim Van Hook, ATI
- UNC High Performance Graphics Hardware, Anselmo Lastra, UNC
- Antialiasing (Kurt)
- Advanced texturing and shading (Pat)
- Programmable shading (Pat)
- Ray tracing (Pat)
- System issues (Kurt)
- The Design of OpenGL (Kurt)
- The Design of RenderMan (Pat)
- Final thoughts
Computer Graphics: Image Synthesis Techniques
- The Goals of Rendering
- Ray Tracing I: Basic Algorithm, Ray-Surface Intersection
- Ray Tracing II: Acceleration Techniques
- The Light Field
- Lights and Lighting, Illumination
- Camera and Film
- Sampling and Reconstruction, Aliasing and Antialiasing
- Statistical Sampling
- Reflection Models I: BRDFs, Ideal Specular and Diffuse
- Reflection Models II: Glossy
- Texture
- The Rendering Equation
- Monte Carlo Methods I: Probability, Sampling and Variance Reduction
- Monte Carlo Methods II: Sampling Paths
- Monte Carlo Methods III: Irradiance Caching and Photon Maps
- Radiosity I: Form Factors, Solvers
- Radiosity II: Meshing and Hierarchical Techniques
- Volume Rendering
Image Synthesis Techniques
Three aspects
- Lights and Lighting
Light sources
Illumination algorithms - Materials
Reflection models
Texture models - Camera
Lens and film effects
Fundamentally involves physical modeling and simulation.
‘60-’70’s : Geometric Aspects
Transformation/clipping
- Evans and Sutherland display pipeline
Hidden line and surface algorithms
- Sutherland, Sproull, Shumacker sort taxonomy
- Object vs. Image space
Simple shading and texturing
- Gouraud: interpolating colors
- Phong: interpolating normals
- Blinn, Catmull, Williams texturing
Computer Graphics - cc.gatech.edu
- 2D Raster Graphics Algorithms
Scan Converting Lines
Scan Converting Circles
Scan Converting Polygons
Fillings Rectangles
Fillings Polygons
Clipping Lines
Clipping Polygons
Antialiasing - Geometrical Transformations
Primitive Transformations
Homogeneous Coordinate Systems
Composition of Transformations
Window-to-Viewport Transformation
3-D Transformations
Composition of 3-D Transformations - Viewing in 3D
Projections
Specifying an Arbitrary 3D View
Clipping
Mathmatics
Coordinate Systems - Representing Curves and Surfaces
Polygon Meshes
Modeling Curves
Quadric Surfaces - Visible Surface Determination
Hidden Surface Removal
Algorithms
Visible-surface ray tracing - Illumination and Shading
Illuminations Models
Ray Tracing
Shading Models - Animation
Computer-Assisted Animation
Rules of Animation
Controlling Animation
Computer Graphics - cs.brown.edu
What is Computer Graphics?
- Computer graphics generally means creation, storage and manipulation of models and images
- Such models come from diverse and expanding set of fields including physical, mathematical, artistic, biological, and even conceptual (abstract) structures
- William Fetter coined term “computer graphics”in 1960 to describe new design methods he was pursuing at Boeing
- Created a series of widely reproduced images on pen plotter exploring cockpit design, using 3D model of human body.
- Perhaps the best way to define computer graphics is to find out what it is not. It is not a machine. It is not a computer, nor a group of computer programs. It is not the know-how of a graphic designer, a programmer, a writer, a motion picture specialist, or a reproduction specialist.
- Computer graphics is all these –a consciously managed and documented technology directed toward communicating information accurately and descriptively.”
Computer Graphics, by William A. Fetter, 1966
Click to Download