Presentation is loading. Please wait.

Presentation is loading. Please wait.

OpenGL A Brief Overview. What is OpenGL? It is NOT a programming language. It is a Graphics Rendering API consisting of a set of functions with a well.

Similar presentations


Presentation on theme: "OpenGL A Brief Overview. What is OpenGL? It is NOT a programming language. It is a Graphics Rendering API consisting of a set of functions with a well."— Presentation transcript:

1 OpenGL A Brief Overview

2 What is OpenGL? It is NOT a programming language. It is a Graphics Rendering API consisting of a set of functions with a well defined interface. Whenever we say that a program is OpenGL- based or OpenGL applications, we mean that it is written in some programming language (such as C/C++ or Java) that makes calls to one or more of OpenGL libraries.

3 OpenGL & Alternative Based on GL (graphics library) by Silicon Graphics Inc. (SGI) (www.opengl.org)www.opengl.org Advantages: Runs on everything, including smart phones (OpenGL/ES) Alternatives: Microsoft’s Direct3D – limited to MS-Windows (http://windows.microsoft.com/en- us/windows7/products/features/directx-11)http://windows.microsoft.com/en- us/windows7/products/features/directx-11 Sun’s Java3D – slower, implemented on top of OpenGL (http://www.java3d.org/)http://www.java3d.org/

4 Useful Websites and Books Official Site http://www.opengl.org Non official sites http://nehe.gamedev.net/ http://google.com/ BOOKS OpenGL Red Book (http://www.glprogramming.com/red/)http://www.glprogramming.com/red/ & OpenGL Blue Book (http://www.glprogramming.com/blue/)http://www.glprogramming.com/blue/

5 APP GLUT Library Layers OpenGL = GL + GLU – Basic low-level GL routines implemented using OS graphics routines – Time-saving higher-level GLU routines implemented using GL routines GLUT opens and manages OpenGL windows and adds helper functions OpenGL Extensions provide direct device-dependent access to hardware GL GLU OS Driver HW EXT

6 OpenGL API Functions OpenGL contains over 200 functions – Primitive functions: define the elements (e.g. points, lines, polygons, etc.) – Attribute functions: control the appearance of primitives (e.g. colors, line types, light source, textures, etc.) – Viewing functions: determine the properties of camera. Handle transformations. – Windowing functions: not part of core OpenGL (in GLUT) – Other functions

7 Libraries and Headers Library NameLibrary FileHeader FileNote OpenGL opengl32.lib (Win) -lgl (UNIX) gl.h“core” library Auxiliary library glu32.lib (Win) -lglu (UNIX) glu.h handles a variety of accessory functions Utility toolkitglut32.lib (Win) -lglut (UNIX) glut.h glaux.h window management & others

8 Function Naming Conventions glColor3f(…) library name, command name, # of arguments, argument type gl: OpenGL glu: GLU glut: GLUT f: the argument is float type i: the argument is integer type v: the argument requires a vector

9 A Sample Program void main (int argc, char **argv) { glutInit (&argc, argv); glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB); glutInitWindowSize (500, 500); glutCreateWindow (“My First Program"); myinit (); glutDisplayFunc ( display ); glutReshapeFunc ( resize ); glutKeyboardFunc ( key ); glutMainLoop (); } 2 3 4 1 #include

10 1. Initialize & Create Window void main (int argc, char **argv) { glutInit (&argc, argv); // GLUT initialization glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB); // display model glutInitWindowSize (500, 500); // set window size glutCreateWindow (“My First Program”); // create window …… } Initiate a GLUT window…

11 2. Initialize OpenGL State void myinit(void) { glClearColor(1.0, 1.0, 1.0, 1.0); // background color glColor3f(1.0, 0.0, 0.0); // line color glMatrixMode(GL_PROJECTION); // set up viewing: glLoadIdentity(); // load identity matrix gluOrtho2D(0.0, 500.0, 0.0, 500.0);// specify Orthographic view glMatrixMode(GL_MODELVIEW);// go back to MV matrix } Set up the canvas for drawing, including the background color and view

12 3. Register Callback Functions void main (int argc, char **argv) { …… glutDisplayFunc ( display ); // display callback glutReshapeFunc ( resize ); // window resize callback glutKeyboardFunc ( key ); // keyboard callback …… } Event handling

13 (side note) GLUT Callback Functions Contents of window need to be refreshed glutDisplayFunc() Window is resized or moved glutReshapeFunc() Key action glutKeyboardFunc() Mouse button action glutMouseFunc() Mouse moves while a button is pressed glutMotionFunc() Mouse moves regardless of mouse button state glutPassiveMouseFunc() Called when nothing else is going on glutIdleFunc()

14 3.1 Rendering Callback void display( void ) { int k; glClear(GL_COLOR_BUFFER_BIT); for( k=0; k<5000; k++) …… } Here is the place you do the drawing!!!

15 3.2 Window Resize Callback void resize(int w, int h) { …… display(); }

16 3.3 Keyboard Input Callback void key( char mkey, int x, int y ) { switch( mkey ) { case ‘q’ : exit( EXIT_SUCCESS ); break; …… }

17 4. Event Process Loop This is where your application receives events, and schedules when callback functions are called void main (int argc, char **argv) { …… glutMainLoop(); }

18 Viewport Coordinates Physical per-pixel integer coordinates Also called screen or device coordinates glViewport(x,y,w,h) – x,y – lower left pixel (integers) – w – width – h – height Sometimes (0,0) is in the upper left corner (e.g. for mouse input) (0,0)(HRES-1,0) (HRES-1, VRES-1) (0,VRES-1)

19 Window Coordinates Logical, mathematical floating-point coordinates glOrtho(l,r,b,t,n,f) (for 3D) – left, right, bottom, top – near, far: limits depth For 2D use gluOrtho2D(l,r,b,t) calls glOrtho(l,r,b,t,-1,1) To use per-pixel coordinates, call: gluOrtho2D(-.5,-.5,w-.5,h-.5); (-1,-1)(1,-1) (1,1) (-1,1)

20 2D Geometric Primitives Primitives – fundamental entities such as point and polygons Basic types of geometric primitives – Points – Line segments – Polygons

21 GL_POINTS GL_LINES GL_LINE_STRIP GL_POLYGON GL_QUADS GL_TRIANGLES GL_TRIANGLE_FAN All geometric primitives are specified by vertices 2D Geometric Primitives GL_LINE_LOOP

22 glBegin( type ); glVertex*(…); …… glVertex*(…); glEnd(); type determines how vertices are combined Specifying Geometric Primitives

23 An Example void drawSquare (GLfloat *color) { glColor3fv( color ); // sets the color of the square glBegin(GL_POLYGON); glVertex2f ( 0.0, 0.0 ); glVertex2f ( 1.0, 0.0 ); glVertex2f ( 1.1, 1.1 ); glVertex2f ( 0.0, 1.0 ); glEnd(); glFlush(); // force the renderer to output the results }

24 Points glBegin(GL_POINTS); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

25 Lines glBegin(GL_LINES); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

26 Line Strip glBegin(GL_LINE_STRIP); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

27 Line Loop glBegin(GL_LINE_LOOP); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

28 Polygon glBegin(GL_POLYGON); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1) OpenGL only supports convex polygons (and really only triangles)

29 Quads glBegin(GL_QUADS); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

30 Quads glBegin(GL_QUADS); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glEnd(); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.);

31 Quads glBegin(GL_QUADS); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glEnd(); (-1,1) (-1,-1)(1,-1) (1,1) (-1,1)

32 Triangles glBegin(GL_TRIANGLES); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

33 Triangles glBegin(GL_TRIANGLES); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.6,1.); glVertex2f(-.2,.6); glVertex2f(.6,1.); glVertex2f(-.2,.6); glVertex2f(.2,.6); glVertex2f(.6,1.); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); … glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

34 Triangle Strip glBegin(GL_TRIANGLE_STRIP); glVertex2f(-.6,1.); glVertex2f(-.6,.6); glVertex2f(-.2,.6); glVertex2f(-.2,-.6); glVertex2f(-.6,-.6); glVertex2f(-.6,-1.); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glVertex2f(.2,-.6); glVertex2f(.2,.6); glVertex2f(.6,.6); glVertex2f(.6,1.); glEnd(); (-1,-1)(1,-1) (1,1) (-1,1)

35 Triangle Strip glBegin(GL_TRIANGLE_STRIP); glVertex2f(-.6,1.); glVertex2f(.6,1.); glVertex2f(-.2,.6); glVertex2f(.2,.6); glVertex2f(-.2,-.6); glVertex2f(.2,-.6); glVertex2f(.6,-1.); glVertex2f(.6,-.6); glEnd(); … (-1,-1)(1,-1) (1,1) (-1,1) First two vertices prime the pump, then every new vertex creates a triangle connecting it to the previous two vertices

36 Triangle Fan glBegin(GL_TRIANGLE_FAN); glVertex2f(-.2,.6); glVertex2f(-.6,.6); glVertex2f(-.6,1.); glVertex2f(.6,1.); glVertex2f(.2,.6); glVertex2f(.2,-.6); glVertex2f(-.2,-.6); glEnd(); … (-1,-1)(1,-1) (1,1) (-1,1) First two vertices prime the pump, then every new vertex creates a triangle connecting it to the previous vertex and the first vertex

37 Assigning Color glColor3f(0,0,1); glBegin(GL_POLYGON); glVertex2f(-1,1); glVertex2f(-1,-1); glVertex2f(1,-1); glEnd(); glColor3f(1,0,0); glBegin(GL_POLYGON); glVertex2f(-1,1); glVertex2f(-1,-1); glVertex2f(1,-1); glEnd(); glColor3f(0,0,0); glBegin(GL_LINE_LOOP); glVertex2f(-1,1); glVertex2f(-1,-1); glVertex2f(1,-1); glEnd(); glBegin(GL_POLYGON); glColor3f(0,1,0); glVertex2f(-1,1); glColor3f(0,0,1); glVertex2f(-1,-1); glColor3f(1,0,0); glVertex2f(1,-1); glEnd();

38 Graphics Pipeline of OpenGL Homogeneous Divide Model Coords Model Xform World Coords Viewing Xform Still Clip Coords Clipping Window Coordinates Window Coordinates Window to Viewport Window to Viewport Coordinates Viewport Coordinates Clip Coords Viewing Coords Perspective Distortion

39 Coordinate Systems and Transformation Identify which matrix we wish to alter Set the matrix to an identity matrix Alter the matrix to form the desired matrix glMatrixMode(GL_PROJECTION); glLoadIdentity(); gluOrtho2D(-1.0, 1.0, -1.0, 1.0);

40 glMatrixMode(GLenum mode); – Identify which matrix we wish to alter – The mode is usually GL_MODELVIEW, GL_PROJECTION glLoadIdentity(); – Set the current matrix to an identity matrix Coordinate Systems and Transformation

41 Transformations and Camera Analogy Modeling transformation – Positioning and moving the model. Viewing transformation – Positioning and aiming camera in the world. Projection transformation – Adjusting the lens of the camera. Viewport transformation – Enlarging or reducing the physical photograph.

42 Transformations in OpenGL Transformations are specified by matrix operations. Desired transformation can be obtained by a sequence of simple transformations that can be concatenated together. Transformation matrix is usually represented by 4x4 matrix (homogeneous coordinates). Provides matrix stacks for each type of supported matrix to store matrices.

43 Specifying Operations (1) Translation glTranslate {fd} (TYPE x, TYPE y, TYPE z) Multiplies the current matrix by a matrix that translates an object by the given x, y, z.

44 Specifying Operations (2) Scaling glScale {fd} (TYPE x, TYPE y, TYPE z) Multiplies the current matrix by a matrix that scales an object by the given x, y, z.

45 Specifying Operations (3) Rotation glRotate {fd} (TYPE angle, TYPE x, TYPE y, TYPE z) Multiplies the current matrix by a matrix that rotates an object in a counterclockwise direction about the ray from origin through the point by the given x, y, z. The angle parameter specifies the angle of rotation in degrees.

46 Order of Transformations The transformation matrices appear in reverse order to that in which the transformations are applied. In OpenGL, the transformation specified most recently is the one applied first.

47 Viewing-Modeling Transformation If given an object, and we want to render it from a viewpoint, what information do we have to have? – Viewing position – Which way I am looking at – Which way is “up” …..

48 Default Viewing +X +Z +Y default negative By default, the camera is at the origin, looking down the negative z-axis

49 Where are we and what are we looking at? x y z x y z Eyepoint (eye x, eye y, eye z ) Model View-up vector (up x, up y, up z ) Loot at (at x, at y, at z )

50 Viewing in OpenGL Look-At Function gluLookAt ( eye x, eye y, eye z, at x, at y, at z, up x, up y, up z ) ModelView Defines a viewing matrix and multiplies the current matrix by it. Alters the ModelView matrix.

51 Projection Transformation Projection & Viewing Volume Projection Transformation Viewpoint Transformation

52 Perspective Projection Volume Far-plane: zFar Near-plane: zNear Viewing volume h w aspect ratio = w/h y z x fovy

53 Perspective Projection Commands glFrustum( left, right, bottom, top, zNear, zFar ) Projection Creates a matrix for a perspective viewing frustum and multiplies the current matrix by it. Alters the Projection matrix.

54 gluPerspective( fovy, aspect, zNear, zFar ) Alternative to glFrustum(..). Creates a matrix for an perspective viewing frustum and multiplies the current matrix by it. Alters the Projection matrix. Note: fovy is the field of view (fov) angle between the top and bottom planes of the clipping volume. aspect is the aspect ratio Perspective Projection Commands

55 Enabling GL Features Features – lighting, hidden-surface removal, texture mapping, etc… Each feature will slow down the rendering process. We can enable/disable each feature individually void glEnable(GLenum feature) void glDisable(GLenum feature) E.g. glEnable(GL_LIGHTING);

56 Enabling GL Features GL_ALPHA_TEST If enabled, do alpha testing. GL_AUTO_NORMAL If enabled, generate normal vectors when either GL_MAP2_VERTEX_3 or GL_MAP2_VERTEX_4 is used to generate vertices. See glMap2. GL_BLEND If enabled, blend the incoming RGBA color values with the values in the color buffers.. GL_CLIP_PLANE i If enabled, clip geometry against user-defined clipping plane i.. GL_COLOR_LOGIC_OP If enabled, apply the currently selected logical operation to the incoming RGBA color and color buffer values. GL_COLOR_MATERIAL If enabled, have one or more material parameters track the current color. GL_COLOR_TABLE If enabled, preform a color table lookup on the incoming RGBA color values. GL_CONVOLUTION_1D If enabled, perform a 1D convolution operation on incoming RGBA color values. GL_CONVOLUTION_2D If enabled, perform a 2D convolution operation on incoming RGBA color values. ……

57 Double Buffering Use two buffers: front buffer and back buffer to guarantee the displaying of a fully redrawn buffer image glutSwapBuffers(); – Replace glFlush() by glutSwapBuffer() in the display callback if using double buffering

58 Advanced Topics Lighting Texture Mapping Plotting Implicit Functions Shadows Fog Picking (object selection) GUI (glut pop-up menus, glui library) Reference links given on slide 3

59

60

61 main function

62 OpenGL header files and libraries

63 GLUI interface libraries

64

65 Acknowledgment Thanks for materials from – Dr. John C. Hart – Dr. Eugene Zhang – Dr. Mike Bailey

66 Viewport – The region within the window that will be used for drawing the clipping area – By default, it is set to the entire rectangle of the window that is opened – Measured in the window coordinates, which reflect the position of pixels on the screen related to the lower-left corner of the window

67 Viewport Transformation A viewpoint is defined as the same size as the window A viewpoint is defined as half the size of the window h w h w

68 Viewport Commands glViewport( x, y, width, height ) Defines an area of the window into which the final image is mapped (x, y) specifies the lower-left corner of the viewport (width, height) specifies the size of the viewport rectangle

69 Indexed Face Set Popular file format – VRML, Wavefront “.obj”, etc. Ordered list of vertices – Prefaced by “v” (Wavefront) – Spatial coordinates x,y,z – Index given by order List of polygons – Prefaced by “f” (Wavefront) – Ordered list of vertex indices – Length = # of sides – Orientation given by order v x 1 y 1 z 1 v x 2 y 2 z 2 v x 3 y 3 z 3 v x 4 y 4 z 4 f 1 2 3 f 2 4 3 (x1,y1,z1)(x1,y1,z1) (x2,y2,z2)(x2,y2,z2) (x3,y3,z3)(x3,y3,z3) (x4,y4,z4)(x4,y4,z4)

70 Other Attributes Vertex normals – Prefixed w/ “vn” (Wavefront) – Contains x,y,z of normal – Not necessarily unit length – Not necessarily in vertex order – Indexed as with vertices Texture coordinates – Prefixed with “vt” (Wavefront) – Not necessarily in vertex order – Contains u,v surface parameters Faces – Uses “/” to separate indices – Vertex “/” normal “/” texture – Normal and texture optional – Can eliminate normal with “//” v x 0 y 0 z 0 v x 1 y 1 z 1 v x 2 y 2 z 2 vn a 0 b 0 c 0 vn a 1 b 1 c 1 vn a 2 b 2 c 2 vt u 0 v 0 vt u 1 v 1 vt u 2 v 2 (x 0,y 0,z 0 ) (a 0,b 0,c 0 ) (u 0,v 0 ) (x1,y1,z1)(a1,b1,c1)(u1,v1)(x1,y1,z1)(a1,b1,c1)(u1,v1) (x2,y2,z2)(a2,b2,c2)(u2,v2)(x2,y2,z2)(a2,b2,c2)(u2,v2) f 0/0/0 1/1/1 2/2/2f 0/0/0 1/0/1 2/0/2

71 Three Views of OpenGL Programmer’s view – Specify a set of objects to render – Describe the properties of these objects – Define how these objects should be viewed State machine – States determine how the inputs are processed. – Change a state (such as color) by using state changing functions OpenGL uses Rendering Pipeline Model – Models -> Transformer -> Clipper -> Projector -> Rasterizer -> Image

72 2D Viewing Where do we draw the 2D object? – Assume that we draw objects on an infinite sheet of paper – Then we need to specify clipping region and project these 2D objects to the screen void gluOrtho2D(GLdouble left, GLdouble right, GLdouble bottom, GLdouble top);

73 Saving the State State changing functions – overwrites the state variables We can store previous state values for later use – Matrix stacks void glPushMatrix() void glPopMatrix() – Attribute stacks void glPishAttrib(GLbitfield mask) void glPopAttrib()

74 Saving the State glMatrix(GL_PROJECTION) // set projection matrix // draw scene glPushMatrix(); // change the project matrix //draw scene glPopMatrix();


Download ppt "OpenGL A Brief Overview. What is OpenGL? It is NOT a programming language. It is a Graphics Rendering API consisting of a set of functions with a well."

Similar presentations


Ads by Google