SlideShare une entreprise Scribd logo
1  sur  40
Télécharger pour lire hors ligne
Introduction to
OpenGL Programming
What is OpenGL
   OpenGL is a software API to graphics hardware.
       designed as a streamlined, hardware-independent
        interface to be implemented on many different hardware
        platforms
       Intuitive, procedural interface with c binding
       No windowing commands !
       No high-level commands for describing models of three-
        dimensional objects
       The OpenGL Utility Library (GLU) provides many of the
        modeling features, such as quadric surfaces and NURBS
        curves and surfaces
SGI and GL
 Silicon Graphics (SGI) revolutionized the
  graphics workstation by implementing the
  pipeline in hardware (1982)
 To access the system, application
  programmers used a library called GL
 With GL, it was relatively simple to program
  three dimensional interactive applications
OpenGL
The success of GL lead to OpenGL (1992), a
  platform-independent API that was
    Easy to use
    Close enough to the hardware to get excellent
     performance
    Focus on rendering
    Omitted windowing and input to avoid window
     system dependencies
OpenGL Evolution
 Controlled        by an Architectural Review Board
 (ARB)
    Members include SGI, Microsoft, Nvidia, HP,
     3DLabs, IBM,…….
    Relatively stable (present version 2.0)
        Evolution reflects new hardware capabilities
            3D texture mapping and texture objects
            Vertex and fragment programs
    Allows for platform specific features through
     extensions
OpenGL Libraries
   OpenGL core library
     OpenGL32 on Windows

     GL on most unix/linux systems (libGL.a)

   OpenGL Utility Library (GLU)
     Provides functionality in OpenGL core but avoids
       having to rewrite code
   Links with window system
     GLX for X window systems, WGL for Windows

     Cross-platform GUI libraries: GLUT, SDL, FLTK, QT,
       …
Windowing with OpenGL
 OpenGL  is independent of any specific
  window system
 OpenGL can be used with different window
  systems
    X windows (GLX)
    MFC
    …
 GLUTprovide a portable API for creating
 window and interacting with I/O devices
GLUT
   OpenGL Utility Toolkit (GLUT)
     Provides functionality common to all window systems
           Open a window
           Get input from mouse and keyboard
           Menus
           Event-driven
       Code is portable but GLUT lacks the functionality of a
        good toolkit for a specific platform
           No slide bars, buttons, …
Software Organization

                   application program

     OpenGL Motif
    widget or similar     GLUT
               GLX, AGL
                or WGL             GLU

   X, Win32, Mac O/S                     OpenGL

               software and/or hardware
OpenGL Architecture
        Immediate Mode                           geometry
                                                  pipeline
                              Per Vertex
        Polynomial           Operations &
         Evaluator             Primitive
                              Assembly



      Display                                      Per Fragment   Frame
CPU     List
                                 Rasterization
                                                    Operations    Buffer



                                 Texture
                                 Memory
                  Pixel
                Operations
OpenGL as a state machine
   GL State Variables- can be set and queried by OpenGL. Remains
    unchanged until the next change.
       Projection and viewing matrix
       Color and material properties
       Lights and shading
       Line and polygon drawing modes
       …
   OpenGL functions are of two types
       Primitive generating
           Can cause output if primitive is visible
           How vertices are processed and appearance of primitive are controlled by the
            state
       State changing
           Transformation functions
           Attribute functions
OpenGL Syntax
   Functions have prefix gl and initial capital letters for each word
       glClearColor(), glEnable(), glPushMatrix()            …
   glu for GLU functions
       gluLookAt(), gluPerspective()       …
   Constants begin with GL_, use all capital letters
       GL_COLOR_BUFFER_BIT, GL_PROJECTION, GL_MODELVIEW …
   Extra letters in some commands indicate the number and type of
    variables
       glColor3f(), glVertex3f()       …
   OpenGL data types
       GLfloat, GLdouble, GLint, GLenum,         …
   Underlying storage mode is the same
   Easy to create overloaded functions in C++ but issue is efficiency
OpenGL function format
                        function name
                                          dimensions

                glVertex3f(x,y,z)


                              x,y,z are floats
belongs to GL library


         glVertex3fv(p)

                              p is a pointer to an array
OpenGL #defines
 Most
     constants are defined in the include files
 gl.h, glu.h and glut.h
    Note #include <GL/glut.h> should
     automatically include the others
    Examples
    glBegin(GL_POLYGON)
    glClear(GL_COLOR_BUFFER_BIT)
 include
       files also define OpenGL data types:
 GLfloat, GLdouble,….
GLUT
 Developed  by Mark Kilgard
 Hides the complexities of differing window
  system APIs
     Default user interface for class projects
 Glut   routines have prefix glut
     glutCreateWindow() …
 Has  very limited GUI interface
 Glui is the C++ extension of glut
Glut Routines
   Initialization: glutInit() processes (and removes) command-line
    arguments that may be of interest to glut and the window system and
    does general initialization of Glut and OpenGL
       Must be called before any other glut routines
   Display Mode: The next procedure, glutInitDisplayMode(),
    performs initializations informing OpenGL how to set up the frame
    buffer.
       Display Mode         Meaning
       GLUT_RGB             Use RGB colors
       GLUT_RGBA            Use RGB plus alpha (for transparency)
       GLUT_INDEX           Use indexed colors (not recommended)

       GLUT_DOUBLE          Use double buffering (recommended)
       GLUT_SINGLE          Use single buffering (not recommended)

       GLUT_DEPTH           Use depth-buffer (for hidden surface removal.)
Glut Routines
 Window    Setup
    glutInitWindowSize(int width, int height)
    glutInitWindowPosition(int x, int y)
    glutCreateWindow(char* title)
A Simple Program
Generate a square on a solid background
simple.c
 #include <GL/glut.h>
 void mydisplay(){
      glClear(GL_COLOR_BUFFER_BIT);
         glBegin(GL_POLYGON);
                 glVertex2f(-0.5, -0.5);
                 glVertex2f(-0.5, 0.5);
                 glVertex2f(0.5, 0.5);
                 glVertex2f(0.5, -0.5);
         glEnd();
         glFlush();
 }
 int main(int argc, char** argv){
        glutInit(&argc, argv);
        glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB);
        glutInitWindowSize(500,500);
        glutInitWindowPosition(0,0);
        glutCreateWindow("simple");
        glutDisplayFunc(mydisplay);
        init();
        glutMainLoop();
 }
Closer Look at the main()
 #include <GL/glut.h>                    includes gl.h
 int main(int argc, char** argv)
 {
   glutInit(&argc,argv);
   glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB);
   glutInitWindowSize(500,500);
   glutInitWindowPosition(0,0);
   glutCreateWindow("simple");
   glutDisplayFunc(mydisplay);   define window     properties

     init();                         display callback
                        set OpenGL state
     glutMainLoop();
 }
                            enter event loop
init.c
                                black clear color
void init()                                opaque window
{
  glClearColor (0.0, 0.0, 0.0, 1.0);

    glColor3f(1.0, 1.0, 1.0);         fill/draw with white

    glMatrixMode (GL_PROJECTION);
    glLoadIdentity ();
    glOrtho(-1.0, 1.0, -1.0, 1.0, -1.0, 1.0);
}

                                viewing volume
Event Handling
   Virtually all interactive graphics programs are even
    driven
   GLUT uses callbacks to handle events
       Windows system invokes a particular procedure when an
        event of particular type occurs.
       MOST IMPORTANT: display event
         Signaled when window first displays and whenever portions
          of the window reveals from blocking window
         glutDisplayFunc(void (*func)(void)) registers
          the display callback function
   Running the program: glutMainLoop()
       Main event loop. Never exit()
More Callbacks
   glutReshapeFunc(void (*func)(int w, int h)) indicates
    what action should be taken when the window is resized.
   glutKeyboardFunc(void (*func)(unsigned char key, int
    x, int y)) and glutMouseFunc(void (*func)(int button,
    int state, int x, int y)) allow you to link a keyboard key or a
    mouse button with a routine that's invoked when the key or mouse
    button is pressed or released.
   glutMotionFunc(void (*func)(int x, int y)) registers a
    routine to call back when the mouse is moved while a mouse button is
    also pressed.

   glutIdleFunc(void (*func)(void)) registers a function that's to
    be executed if no other events are pending - for example, when the
    event loop would otherwise be idle
Compilation on Windows
  See  class web site on how to set up a project
   with OpenGL
  Visual C++
      Get glut.h, glut32.lib and glut32.dll from web
      Create a console application
      Add opengl32.lib, glut32.lib, glut32.lib to project
       settings (under link tab)
Simple Animation
 Animation
    Redraw + swap buffers
    What looks like if using single buffer
    Example program
 More   on the glut documentation
    Chapter 2 of textbook
    OpenGL redbook
    Links in the class resources page
OpenGL Drawing
   We have learned how to create a window
   Steps in the display function
       Clear the window
       Set drawing attributes
       Send drawing commands
       Swap the buffers
   OpenGL coordinate system has different origin from
    the window system
       Uses lower left corner instead of upper left corner as origin
Clear the Window
 glClear(GL_COLOR_BUFFER_BIT)
    clears the frame buffer by overwriting it with the
     background color.
    Background color is a state set by
     glClearColor(GLfloat r, GLfloat g,
     GLfloat b, GLfloat a) in the init().
Drawing Attributes: Color
   glColor3f(GLfloat r, GLfloat g, GLfloat b)            sets the
    drawing color
       glColor3d(), glColor3ui() can also be used
       Remember OpenGL is a state machine
       Once set, the attribute applies to all subsequent defined
        objects until it is set to some other value
       glColor3fv() takes a flat array as input
   There are more drawing attributes than color
       Point size: glPointSize()
       Line width: glLinewidth()
       Dash or dotted line: glLineStipple()
       Polygon pattern: glPolygonStipple()
       …
Drawing Commands
   Simple Objects glRectf()
   Complex Objects
       Use construct
        glBegin(mode) and
        glEnd() and a list of
        vertices in between
           glBegin(mode)
              glVertex(v0);
               glVertex(v1);
               ...
            glEnd();
   Some other commands can
    also be used between
    glBegin() and glEnd(), e.g.
    glColor3f().
   Example
Projection and Viewport
Orthographic projection
   Orthographic View
       glOrtho(left,
        right, bottom,
        top, front, back)
           Specifies the
            coordinates of 3D
            region to be projected
                                      z=0
            into the image space.
           Any drawing outside the
            region will be
            automatically clipped
            away.
Viewports
 Do not have use the entire window for the
  image: glViewport(x,y,w,h)
 Values in pixels (screen coordinates)
Window to Viewport mapping


Aspect Ratio: Height/Width
If the aspect ratio of the window
Is different from that of the
viewport, the picture will be
distorted.
Sierpinski Gasket (2D)
   Start with a triangle




   Connect bisectors of sides and remove central
    triangle




   Repeat
Example
 Five   subdivisions
Gasket Program
#include <GL/glut.h>
/* initial triangle */
GLfloat v[3][2]={{-1.0, -0.58},
           {1.0, -0.58}, {0.0, 1.15}};
int n; /* number of recursive steps */
void triangle( GLfloat *a, GLfloat *b, GLfloat *c)
/* display one triangle */
{
      glVertex2fv(a);
      glVertex2fv(b);
      glVertex2fv(c);
}
Triangle Subdivision
void divide_triangle(GLfloat *a, GLfloat *b, GLfloat *c, int
    m)
{
/* triangle subdivision using vertex numbers */
     point2 v0, v1, v2;
     int j;
     if(m>0)
       {
         for(j=0; j<2; j++) v0[j]=(a[j]+b[j])/2;
         for(j=0; j<2; j++) v1[j]=(a[j]+c[j])/2;
         for(j=0; j<2; j++) v2[j]=(b[j]+c[j])/2;
         divide_triangle(a, v0, v1, m-1);
         divide_triangle(c, v1, v2, m-1);
         divide_triangle(b, v2, v0, m-1);
     }
     else(triangle(a,b,c));
  /* draw triangle at end of recursion */
}
Gasket Display Functions
void display()
{
    glClear(GL_COLOR_BUFFER_BIT);
    glBegin(GL_TRIANGLES);
    divide_triangle(v[0], v[1], v[2], n);
    glEnd();
    glFlush();
}

•   By having the glBegin and glEnd in the display callback rather
    than in the function triangle and using GL_TRIANGLES rather
    than GL_POLYGON in glBegin, we call glBegin and glEnd
    only once for the entire gasket rather than once for each triangle
Example: 3D Gasket
    after 5 iterations
Tetrahedron Code
void tetrahedron( int m)
{
    glColor3f(1.0,0.0,0.0);
    divide_triangle(v[0], v[1],   v[2], m);
    glColor3f(0.0,1.0,0.0);
    divide_triangle(v[3], v[2],   v[1], m);
    glColor3f(0.0,0.0,1.0);
    divide_triangle(v[0], v[3],   v[1], m);
    glColor3f(0.0,0.0,0.0);
    divide_triangle(v[0], v[2],   v[3], m);
}

Contenu connexe

Tendances

OpenGL Introduction.
OpenGL Introduction.OpenGL Introduction.
OpenGL Introduction.Girish Ghate
 
Opengl presentation
Opengl presentationOpengl presentation
Opengl presentationelnaqah
 
Computer Graphics - Lecture 01 - 3D Programming I
Computer Graphics - Lecture 01 - 3D Programming IComputer Graphics - Lecture 01 - 3D Programming I
Computer Graphics - Lecture 01 - 3D Programming I💻 Anton Gerdelan
 
Hidden surface removal
Hidden surface removalHidden surface removal
Hidden surface removalAnkit Garg
 
Graphics software and standards
Graphics software and standardsGraphics software and standards
Graphics software and standardsMani Kanth
 
Visible surface determination
Visible  surface determinationVisible  surface determination
Visible surface determinationPatel Punit
 
illumination model in Computer Graphics by irru pychukar
illumination model in Computer Graphics by irru pychukarillumination model in Computer Graphics by irru pychukar
illumination model in Computer Graphics by irru pychukarsyedArr
 
Game Engine Overview
Game Engine OverviewGame Engine Overview
Game Engine OverviewSharad Mitra
 
Understaing Android EGL
Understaing Android EGLUnderstaing Android EGL
Understaing Android EGLSuhan Lee
 
OpenGL 3.2 and More
OpenGL 3.2 and MoreOpenGL 3.2 and More
OpenGL 3.2 and MoreMark Kilgard
 
NVIDIA OpenGL in 2016
NVIDIA OpenGL in 2016NVIDIA OpenGL in 2016
NVIDIA OpenGL in 2016Mark Kilgard
 
Computer Graphics - Lecture 00 - Introduction
Computer Graphics - Lecture 00 - IntroductionComputer Graphics - Lecture 00 - Introduction
Computer Graphics - Lecture 00 - Introduction💻 Anton Gerdelan
 
openGL basics for sample program (1).ppt
openGL basics for sample program (1).pptopenGL basics for sample program (1).ppt
openGL basics for sample program (1).pptHIMANKMISHRA2
 
Computer Graphics Project on Sinking Ship using OpenGL
Computer Graphics Project on Sinking Ship using OpenGLComputer Graphics Project on Sinking Ship using OpenGL
Computer Graphics Project on Sinking Ship using OpenGLSharath Raj
 

Tendances (20)

OpenGL Introduction.
OpenGL Introduction.OpenGL Introduction.
OpenGL Introduction.
 
OpenGL ES 3.2 Reference Guide
OpenGL ES 3.2 Reference GuideOpenGL ES 3.2 Reference Guide
OpenGL ES 3.2 Reference Guide
 
Opengl presentation
Opengl presentationOpengl presentation
Opengl presentation
 
OpenGL ES 3.1 Reference Card
OpenGL ES 3.1 Reference CardOpenGL ES 3.1 Reference Card
OpenGL ES 3.1 Reference Card
 
Computer Graphics - Lecture 01 - 3D Programming I
Computer Graphics - Lecture 01 - 3D Programming IComputer Graphics - Lecture 01 - 3D Programming I
Computer Graphics - Lecture 01 - 3D Programming I
 
Hidden surface removal
Hidden surface removalHidden surface removal
Hidden surface removal
 
Graphics software and standards
Graphics software and standardsGraphics software and standards
Graphics software and standards
 
Visible surface determination
Visible  surface determinationVisible  surface determination
Visible surface determination
 
EGL 1.4 Reference Card
EGL 1.4 Reference CardEGL 1.4 Reference Card
EGL 1.4 Reference Card
 
OpenGL SC 2.0 Quick Reference
OpenGL SC 2.0 Quick ReferenceOpenGL SC 2.0 Quick Reference
OpenGL SC 2.0 Quick Reference
 
illumination model in Computer Graphics by irru pychukar
illumination model in Computer Graphics by irru pychukarillumination model in Computer Graphics by irru pychukar
illumination model in Computer Graphics by irru pychukar
 
Game Engine Overview
Game Engine OverviewGame Engine Overview
Game Engine Overview
 
Understaing Android EGL
Understaing Android EGLUnderstaing Android EGL
Understaing Android EGL
 
OpenGL 3.2 and More
OpenGL 3.2 and MoreOpenGL 3.2 and More
OpenGL 3.2 and More
 
NVIDIA OpenGL in 2016
NVIDIA OpenGL in 2016NVIDIA OpenGL in 2016
NVIDIA OpenGL in 2016
 
Computer Graphics - Lecture 00 - Introduction
Computer Graphics - Lecture 00 - IntroductionComputer Graphics - Lecture 00 - Introduction
Computer Graphics - Lecture 00 - Introduction
 
OpenGL Texture Mapping
OpenGL Texture MappingOpenGL Texture Mapping
OpenGL Texture Mapping
 
openGL basics for sample program (1).ppt
openGL basics for sample program (1).pptopenGL basics for sample program (1).ppt
openGL basics for sample program (1).ppt
 
Depth Buffer Method
Depth Buffer MethodDepth Buffer Method
Depth Buffer Method
 
Computer Graphics Project on Sinking Ship using OpenGL
Computer Graphics Project on Sinking Ship using OpenGLComputer Graphics Project on Sinking Ship using OpenGL
Computer Graphics Project on Sinking Ship using OpenGL
 

En vedette

Introduction of openGL
Introduction  of openGLIntroduction  of openGL
Introduction of openGLGary Yeh
 
OpenGL Introduction
OpenGL IntroductionOpenGL Introduction
OpenGL IntroductionYi-Lung Tsai
 
Flying machine Business Profile
Flying machine Business ProfileFlying machine Business Profile
Flying machine Business ProfileSandeep Malkar
 
Protein structure by Pauling & corey
Protein structure by Pauling & coreyProtein structure by Pauling & corey
Protein structure by Pauling & coreyCIMAP
 
Opengl lec 3
Opengl lec 3Opengl lec 3
Opengl lec 3elnaqah
 
3 d graphics with opengl part 2
3 d graphics with opengl  part 23 d graphics with opengl  part 2
3 d graphics with opengl part 2Sardar Alam
 
Web gl game development
Web gl game developmentWeb gl game development
Web gl game developmentwebglgame
 
cloud conference 2013 - Infrastructure as a Service in Amazon Web Services
cloud conference 2013 - Infrastructure as a Service in Amazon Web Servicescloud conference 2013 - Infrastructure as a Service in Amazon Web Services
cloud conference 2013 - Infrastructure as a Service in Amazon Web ServicesVMEngine
 
Getting Started with WebGL
Getting Started with WebGLGetting Started with WebGL
Getting Started with WebGLChihoon Byun
 
CG OpenGL polar curves & input display color-course 4
CG OpenGL polar curves & input display color-course 4CG OpenGL polar curves & input display color-course 4
CG OpenGL polar curves & input display color-course 4fungfung Chen
 
SIGGRAPH 2012: NVIDIA OpenGL for 2012
SIGGRAPH 2012: NVIDIA OpenGL for 2012SIGGRAPH 2012: NVIDIA OpenGL for 2012
SIGGRAPH 2012: NVIDIA OpenGL for 2012Mark Kilgard
 
OpenGL Transformation
OpenGL TransformationOpenGL Transformation
OpenGL TransformationSandip Jadhav
 
Chapter02 graphics-programming
Chapter02 graphics-programmingChapter02 graphics-programming
Chapter02 graphics-programmingMohammed Romi
 

En vedette (20)

Introduction of openGL
Introduction  of openGLIntroduction  of openGL
Introduction of openGL
 
OpenGL Starter L01
OpenGL Starter L01OpenGL Starter L01
OpenGL Starter L01
 
OpenGL L01-Primitives
OpenGL L01-PrimitivesOpenGL L01-Primitives
OpenGL L01-Primitives
 
OpenGL Introduction
OpenGL IntroductionOpenGL Introduction
OpenGL Introduction
 
Flying machine Business Profile
Flying machine Business ProfileFlying machine Business Profile
Flying machine Business Profile
 
Opengl (1)
Opengl (1)Opengl (1)
Opengl (1)
 
Protein structure by Pauling & corey
Protein structure by Pauling & coreyProtein structure by Pauling & corey
Protein structure by Pauling & corey
 
OpenGL (ES) debugging
OpenGL (ES) debuggingOpenGL (ES) debugging
OpenGL (ES) debugging
 
Opengl lec 3
Opengl lec 3Opengl lec 3
Opengl lec 3
 
3 d graphics with opengl part 2
3 d graphics with opengl  part 23 d graphics with opengl  part 2
3 d graphics with opengl part 2
 
Web gl game development
Web gl game developmentWeb gl game development
Web gl game development
 
cloud conference 2013 - Infrastructure as a Service in Amazon Web Services
cloud conference 2013 - Infrastructure as a Service in Amazon Web Servicescloud conference 2013 - Infrastructure as a Service in Amazon Web Services
cloud conference 2013 - Infrastructure as a Service in Amazon Web Services
 
Getting Started with WebGL
Getting Started with WebGLGetting Started with WebGL
Getting Started with WebGL
 
Web Sockets in Java EE 7
Web Sockets in Java EE 7Web Sockets in Java EE 7
Web Sockets in Java EE 7
 
CG OpenGL polar curves & input display color-course 4
CG OpenGL polar curves & input display color-course 4CG OpenGL polar curves & input display color-course 4
CG OpenGL polar curves & input display color-course 4
 
SIGGRAPH 2012: NVIDIA OpenGL for 2012
SIGGRAPH 2012: NVIDIA OpenGL for 2012SIGGRAPH 2012: NVIDIA OpenGL for 2012
SIGGRAPH 2012: NVIDIA OpenGL for 2012
 
OpenGL Transformation
OpenGL TransformationOpenGL Transformation
OpenGL Transformation
 
Chapter02 graphics-programming
Chapter02 graphics-programmingChapter02 graphics-programming
Chapter02 graphics-programming
 
WebGL and three.js
WebGL and three.jsWebGL and three.js
WebGL and three.js
 
OpenGL Starter L02
OpenGL Starter L02OpenGL Starter L02
OpenGL Starter L02
 

Similaire à Open gl

openGL basics for sample program.ppt
openGL basics for sample program.pptopenGL basics for sample program.ppt
openGL basics for sample program.pptHIMANKMISHRA2
 
Computer Graphics Project Report on Sinking Ship using OpenGL
Computer Graphics Project Report on Sinking Ship using OpenGL Computer Graphics Project Report on Sinking Ship using OpenGL
Computer Graphics Project Report on Sinking Ship using OpenGL Sharath Raj
 
OpenGL ES based UI Development on TI Platforms
OpenGL ES based UI Development on TI PlatformsOpenGL ES based UI Development on TI Platforms
OpenGL ES based UI Development on TI PlatformsPrabindh Sundareson
 
01.Opengl_intro-2.ppt
01.Opengl_intro-2.ppt01.Opengl_intro-2.ppt
01.Opengl_intro-2.pptEngrZamaan
 
Intro to Computer Graphics.ppt
Intro to Computer Graphics.pptIntro to Computer Graphics.ppt
Intro to Computer Graphics.pptadil104135
 
Advanced Graphics Workshop - GFX2011
Advanced Graphics Workshop - GFX2011Advanced Graphics Workshop - GFX2011
Advanced Graphics Workshop - GFX2011Prabindh Sundareson
 
Convert Your Legacy OpenGL Code to Modern OpenGL with Qt
Convert Your Legacy OpenGL Code to Modern OpenGL with QtConvert Your Legacy OpenGL Code to Modern OpenGL with Qt
Convert Your Legacy OpenGL Code to Modern OpenGL with QtICS
 
COMPUTER GRAPHICS PROJECT REPORT
COMPUTER GRAPHICS PROJECT REPORTCOMPUTER GRAPHICS PROJECT REPORT
COMPUTER GRAPHICS PROJECT REPORTvineet raj
 
Porting the Source Engine to Linux: Valve's Lessons Learned
Porting the Source Engine to Linux: Valve's Lessons LearnedPorting the Source Engine to Linux: Valve's Lessons Learned
Porting the Source Engine to Linux: Valve's Lessons Learnedbasisspace
 
State of the Art OpenGL and Qt
State of the Art OpenGL and QtState of the Art OpenGL and Qt
State of the Art OpenGL and QtICS
 
1 introduction computer graphics
1 introduction computer graphics1 introduction computer graphics
1 introduction computer graphicscairo university
 
CS 354 Viewing Stuff
CS 354 Viewing StuffCS 354 Viewing Stuff
CS 354 Viewing StuffMark Kilgard
 
OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...
OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...
OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...ICS
 

Similaire à Open gl (20)

openGL basics for sample program.ppt
openGL basics for sample program.pptopenGL basics for sample program.ppt
openGL basics for sample program.ppt
 
18csl67 vtu lab manual
18csl67 vtu lab manual18csl67 vtu lab manual
18csl67 vtu lab manual
 
Bai 1
Bai 1Bai 1
Bai 1
 
Computer Graphics Project Report on Sinking Ship using OpenGL
Computer Graphics Project Report on Sinking Ship using OpenGL Computer Graphics Project Report on Sinking Ship using OpenGL
Computer Graphics Project Report on Sinking Ship using OpenGL
 
OpenGL ES based UI Development on TI Platforms
OpenGL ES based UI Development on TI PlatformsOpenGL ES based UI Development on TI Platforms
OpenGL ES based UI Development on TI Platforms
 
01.Opengl_intro-2.ppt
01.Opengl_intro-2.ppt01.Opengl_intro-2.ppt
01.Opengl_intro-2.ppt
 
opengl.ppt
opengl.pptopengl.ppt
opengl.ppt
 
Intro to Computer Graphics.ppt
Intro to Computer Graphics.pptIntro to Computer Graphics.ppt
Intro to Computer Graphics.ppt
 
Advanced Graphics Workshop - GFX2011
Advanced Graphics Workshop - GFX2011Advanced Graphics Workshop - GFX2011
Advanced Graphics Workshop - GFX2011
 
Convert Your Legacy OpenGL Code to Modern OpenGL with Qt
Convert Your Legacy OpenGL Code to Modern OpenGL with QtConvert Your Legacy OpenGL Code to Modern OpenGL with Qt
Convert Your Legacy OpenGL Code to Modern OpenGL with Qt
 
Introduction to OpenGL.ppt
Introduction to OpenGL.pptIntroduction to OpenGL.ppt
Introduction to OpenGL.ppt
 
BYO3D 2011: Rendering
BYO3D 2011: RenderingBYO3D 2011: Rendering
BYO3D 2011: Rendering
 
COMPUTER GRAPHICS PROJECT REPORT
COMPUTER GRAPHICS PROJECT REPORTCOMPUTER GRAPHICS PROJECT REPORT
COMPUTER GRAPHICS PROJECT REPORT
 
Open gles
Open glesOpen gles
Open gles
 
Porting the Source Engine to Linux: Valve's Lessons Learned
Porting the Source Engine to Linux: Valve's Lessons LearnedPorting the Source Engine to Linux: Valve's Lessons Learned
Porting the Source Engine to Linux: Valve's Lessons Learned
 
Introduction to 2D/3D Graphics
Introduction to 2D/3D GraphicsIntroduction to 2D/3D Graphics
Introduction to 2D/3D Graphics
 
State of the Art OpenGL and Qt
State of the Art OpenGL and QtState of the Art OpenGL and Qt
State of the Art OpenGL and Qt
 
1 introduction computer graphics
1 introduction computer graphics1 introduction computer graphics
1 introduction computer graphics
 
CS 354 Viewing Stuff
CS 354 Viewing StuffCS 354 Viewing Stuff
CS 354 Viewing Stuff
 
OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...
OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...
OpenGL Fixed Function to Shaders - Porting a fixed function application to “m...
 

Plus de ch samaram

Syllabus r10-ecm-42-network security and cryptography
 Syllabus r10-ecm-42-network security and cryptography Syllabus r10-ecm-42-network security and cryptography
Syllabus r10-ecm-42-network security and cryptographych samaram
 
Restaurant billing application
Restaurant billing applicationRestaurant billing application
Restaurant billing applicationch samaram
 
Spintronics (1)
Spintronics (1)Spintronics (1)
Spintronics (1)ch samaram
 
Computer forensics law and privacy
Computer forensics   law and privacyComputer forensics   law and privacy
Computer forensics law and privacych samaram
 
Javascript sivasoft
Javascript sivasoftJavascript sivasoft
Javascript sivasoftch samaram
 
Basics java scripts
Basics java scriptsBasics java scripts
Basics java scriptsch samaram
 

Plus de ch samaram (17)

Syllabus r10-ecm-42-network security and cryptography
 Syllabus r10-ecm-42-network security and cryptography Syllabus r10-ecm-42-network security and cryptography
Syllabus r10-ecm-42-network security and cryptography
 
Restaurant billing application
Restaurant billing applicationRestaurant billing application
Restaurant billing application
 
Spintronics
SpintronicsSpintronics
Spintronics
 
Spintronics (1)
Spintronics (1)Spintronics (1)
Spintronics (1)
 
Shore
ShoreShore
Shore
 
Presentation
PresentationPresentation
Presentation
 
Computer forensics law and privacy
Computer forensics   law and privacyComputer forensics   law and privacy
Computer forensics law and privacy
 
Blue gene
Blue geneBlue gene
Blue gene
 
Blue gene
Blue geneBlue gene
Blue gene
 
Wearable (1)
Wearable (1)Wearable (1)
Wearable (1)
 
Javascript sivasoft
Javascript sivasoftJavascript sivasoft
Javascript sivasoft
 
Html siva
Html sivaHtml siva
Html siva
 
Css siva
Css sivaCss siva
Css siva
 
Basics java scripts
Basics java scriptsBasics java scripts
Basics java scripts
 
Ajax
AjaxAjax
Ajax
 
Html 5
Html 5Html 5
Html 5
 
Css siva
Css sivaCss siva
Css siva
 

Dernier

Microservices, Docker deploy and Microservices source code in C#
Microservices, Docker deploy and Microservices source code in C#Microservices, Docker deploy and Microservices source code in C#
Microservices, Docker deploy and Microservices source code in C#Karmanjay Verma
 
Bridging Between CAD & GIS: 6 Ways to Automate Your Data Integration
Bridging Between CAD & GIS:  6 Ways to Automate Your Data IntegrationBridging Between CAD & GIS:  6 Ways to Automate Your Data Integration
Bridging Between CAD & GIS: 6 Ways to Automate Your Data Integrationmarketing932765
 
How to Effectively Monitor SD-WAN and SASE Environments with ThousandEyes
How to Effectively Monitor SD-WAN and SASE Environments with ThousandEyesHow to Effectively Monitor SD-WAN and SASE Environments with ThousandEyes
How to Effectively Monitor SD-WAN and SASE Environments with ThousandEyesThousandEyes
 
Accelerating Enterprise Software Engineering with Platformless
Accelerating Enterprise Software Engineering with PlatformlessAccelerating Enterprise Software Engineering with Platformless
Accelerating Enterprise Software Engineering with PlatformlessWSO2
 
The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...
The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...
The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...Wes McKinney
 
4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector
4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector
4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sectoritnewsafrica
 
A Framework for Development in the AI Age
A Framework for Development in the AI AgeA Framework for Development in the AI Age
A Framework for Development in the AI AgeCprime
 
Generative Artificial Intelligence: How generative AI works.pdf
Generative Artificial Intelligence: How generative AI works.pdfGenerative Artificial Intelligence: How generative AI works.pdf
Generative Artificial Intelligence: How generative AI works.pdfIngrid Airi González
 
Infrared simulation and processing on Nvidia platforms
Infrared simulation and processing on Nvidia platformsInfrared simulation and processing on Nvidia platforms
Infrared simulation and processing on Nvidia platformsYoss Cohen
 
Landscape Catalogue 2024 Australia-1.pdf
Landscape Catalogue 2024 Australia-1.pdfLandscape Catalogue 2024 Australia-1.pdf
Landscape Catalogue 2024 Australia-1.pdfAarwolf Industries LLC
 
2024 April Patch Tuesday
2024 April Patch Tuesday2024 April Patch Tuesday
2024 April Patch TuesdayIvanti
 
Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...
Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...
Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...Alkin Tezuysal
 
[Webinar] SpiraTest - Setting New Standards in Quality Assurance
[Webinar] SpiraTest - Setting New Standards in Quality Assurance[Webinar] SpiraTest - Setting New Standards in Quality Assurance
[Webinar] SpiraTest - Setting New Standards in Quality AssuranceInflectra
 
JET Technology Labs White Paper for Virtualized Security and Encryption Techn...
JET Technology Labs White Paper for Virtualized Security and Encryption Techn...JET Technology Labs White Paper for Virtualized Security and Encryption Techn...
JET Technology Labs White Paper for Virtualized Security and Encryption Techn...amber724300
 
Decarbonising Buildings: Making a net-zero built environment a reality
Decarbonising Buildings: Making a net-zero built environment a realityDecarbonising Buildings: Making a net-zero built environment a reality
Decarbonising Buildings: Making a net-zero built environment a realityIES VE
 
Zeshan Sattar- Assessing the skill requirements and industry expectations for...
Zeshan Sattar- Assessing the skill requirements and industry expectations for...Zeshan Sattar- Assessing the skill requirements and industry expectations for...
Zeshan Sattar- Assessing the skill requirements and industry expectations for...itnewsafrica
 
Connecting the Dots for Information Discovery.pdf
Connecting the Dots for Information Discovery.pdfConnecting the Dots for Information Discovery.pdf
Connecting the Dots for Information Discovery.pdfNeo4j
 
Testing tools and AI - ideas what to try with some tool examples
Testing tools and AI - ideas what to try with some tool examplesTesting tools and AI - ideas what to try with some tool examples
Testing tools and AI - ideas what to try with some tool examplesKari Kakkonen
 
Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...
Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...
Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...BookNet Canada
 
Genislab builds better products and faster go-to-market with Lean project man...
Genislab builds better products and faster go-to-market with Lean project man...Genislab builds better products and faster go-to-market with Lean project man...
Genislab builds better products and faster go-to-market with Lean project man...Farhan Tariq
 

Dernier (20)

Microservices, Docker deploy and Microservices source code in C#
Microservices, Docker deploy and Microservices source code in C#Microservices, Docker deploy and Microservices source code in C#
Microservices, Docker deploy and Microservices source code in C#
 
Bridging Between CAD & GIS: 6 Ways to Automate Your Data Integration
Bridging Between CAD & GIS:  6 Ways to Automate Your Data IntegrationBridging Between CAD & GIS:  6 Ways to Automate Your Data Integration
Bridging Between CAD & GIS: 6 Ways to Automate Your Data Integration
 
How to Effectively Monitor SD-WAN and SASE Environments with ThousandEyes
How to Effectively Monitor SD-WAN and SASE Environments with ThousandEyesHow to Effectively Monitor SD-WAN and SASE Environments with ThousandEyes
How to Effectively Monitor SD-WAN and SASE Environments with ThousandEyes
 
Accelerating Enterprise Software Engineering with Platformless
Accelerating Enterprise Software Engineering with PlatformlessAccelerating Enterprise Software Engineering with Platformless
Accelerating Enterprise Software Engineering with Platformless
 
The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...
The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...
The Future Roadmap for the Composable Data Stack - Wes McKinney - Data Counci...
 
4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector
4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector
4. Cobus Valentine- Cybersecurity Threats and Solutions for the Public Sector
 
A Framework for Development in the AI Age
A Framework for Development in the AI AgeA Framework for Development in the AI Age
A Framework for Development in the AI Age
 
Generative Artificial Intelligence: How generative AI works.pdf
Generative Artificial Intelligence: How generative AI works.pdfGenerative Artificial Intelligence: How generative AI works.pdf
Generative Artificial Intelligence: How generative AI works.pdf
 
Infrared simulation and processing on Nvidia platforms
Infrared simulation and processing on Nvidia platformsInfrared simulation and processing on Nvidia platforms
Infrared simulation and processing on Nvidia platforms
 
Landscape Catalogue 2024 Australia-1.pdf
Landscape Catalogue 2024 Australia-1.pdfLandscape Catalogue 2024 Australia-1.pdf
Landscape Catalogue 2024 Australia-1.pdf
 
2024 April Patch Tuesday
2024 April Patch Tuesday2024 April Patch Tuesday
2024 April Patch Tuesday
 
Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...
Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...
Unleashing Real-time Insights with ClickHouse_ Navigating the Landscape in 20...
 
[Webinar] SpiraTest - Setting New Standards in Quality Assurance
[Webinar] SpiraTest - Setting New Standards in Quality Assurance[Webinar] SpiraTest - Setting New Standards in Quality Assurance
[Webinar] SpiraTest - Setting New Standards in Quality Assurance
 
JET Technology Labs White Paper for Virtualized Security and Encryption Techn...
JET Technology Labs White Paper for Virtualized Security and Encryption Techn...JET Technology Labs White Paper for Virtualized Security and Encryption Techn...
JET Technology Labs White Paper for Virtualized Security and Encryption Techn...
 
Decarbonising Buildings: Making a net-zero built environment a reality
Decarbonising Buildings: Making a net-zero built environment a realityDecarbonising Buildings: Making a net-zero built environment a reality
Decarbonising Buildings: Making a net-zero built environment a reality
 
Zeshan Sattar- Assessing the skill requirements and industry expectations for...
Zeshan Sattar- Assessing the skill requirements and industry expectations for...Zeshan Sattar- Assessing the skill requirements and industry expectations for...
Zeshan Sattar- Assessing the skill requirements and industry expectations for...
 
Connecting the Dots for Information Discovery.pdf
Connecting the Dots for Information Discovery.pdfConnecting the Dots for Information Discovery.pdf
Connecting the Dots for Information Discovery.pdf
 
Testing tools and AI - ideas what to try with some tool examples
Testing tools and AI - ideas what to try with some tool examplesTesting tools and AI - ideas what to try with some tool examples
Testing tools and AI - ideas what to try with some tool examples
 
Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...
Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...
Transcript: New from BookNet Canada for 2024: BNC SalesData and LibraryData -...
 
Genislab builds better products and faster go-to-market with Lean project man...
Genislab builds better products and faster go-to-market with Lean project man...Genislab builds better products and faster go-to-market with Lean project man...
Genislab builds better products and faster go-to-market with Lean project man...
 

Open gl

  • 2. What is OpenGL  OpenGL is a software API to graphics hardware.  designed as a streamlined, hardware-independent interface to be implemented on many different hardware platforms  Intuitive, procedural interface with c binding  No windowing commands !  No high-level commands for describing models of three- dimensional objects  The OpenGL Utility Library (GLU) provides many of the modeling features, such as quadric surfaces and NURBS curves and surfaces
  • 3. SGI and GL  Silicon Graphics (SGI) revolutionized the graphics workstation by implementing the pipeline in hardware (1982)  To access the system, application programmers used a library called GL  With GL, it was relatively simple to program three dimensional interactive applications
  • 4. OpenGL The success of GL lead to OpenGL (1992), a platform-independent API that was  Easy to use  Close enough to the hardware to get excellent performance  Focus on rendering  Omitted windowing and input to avoid window system dependencies
  • 5. OpenGL Evolution  Controlled by an Architectural Review Board (ARB)  Members include SGI, Microsoft, Nvidia, HP, 3DLabs, IBM,…….  Relatively stable (present version 2.0)  Evolution reflects new hardware capabilities  3D texture mapping and texture objects  Vertex and fragment programs  Allows for platform specific features through extensions
  • 6. OpenGL Libraries  OpenGL core library  OpenGL32 on Windows  GL on most unix/linux systems (libGL.a)  OpenGL Utility Library (GLU)  Provides functionality in OpenGL core but avoids having to rewrite code  Links with window system  GLX for X window systems, WGL for Windows  Cross-platform GUI libraries: GLUT, SDL, FLTK, QT, …
  • 7. Windowing with OpenGL  OpenGL is independent of any specific window system  OpenGL can be used with different window systems  X windows (GLX)  MFC  …  GLUTprovide a portable API for creating window and interacting with I/O devices
  • 8. GLUT  OpenGL Utility Toolkit (GLUT)  Provides functionality common to all window systems  Open a window  Get input from mouse and keyboard  Menus  Event-driven  Code is portable but GLUT lacks the functionality of a good toolkit for a specific platform  No slide bars, buttons, …
  • 9. Software Organization application program OpenGL Motif widget or similar GLUT GLX, AGL or WGL GLU X, Win32, Mac O/S OpenGL software and/or hardware
  • 10. OpenGL Architecture Immediate Mode geometry pipeline Per Vertex Polynomial Operations & Evaluator Primitive Assembly Display Per Fragment Frame CPU List Rasterization Operations Buffer Texture Memory Pixel Operations
  • 11. OpenGL as a state machine  GL State Variables- can be set and queried by OpenGL. Remains unchanged until the next change.  Projection and viewing matrix  Color and material properties  Lights and shading  Line and polygon drawing modes  …  OpenGL functions are of two types  Primitive generating  Can cause output if primitive is visible  How vertices are processed and appearance of primitive are controlled by the state  State changing  Transformation functions  Attribute functions
  • 12. OpenGL Syntax  Functions have prefix gl and initial capital letters for each word  glClearColor(), glEnable(), glPushMatrix() …  glu for GLU functions  gluLookAt(), gluPerspective() …  Constants begin with GL_, use all capital letters  GL_COLOR_BUFFER_BIT, GL_PROJECTION, GL_MODELVIEW …  Extra letters in some commands indicate the number and type of variables  glColor3f(), glVertex3f() …  OpenGL data types  GLfloat, GLdouble, GLint, GLenum, …  Underlying storage mode is the same  Easy to create overloaded functions in C++ but issue is efficiency
  • 13. OpenGL function format function name dimensions glVertex3f(x,y,z) x,y,z are floats belongs to GL library glVertex3fv(p) p is a pointer to an array
  • 14. OpenGL #defines  Most constants are defined in the include files gl.h, glu.h and glut.h  Note #include <GL/glut.h> should automatically include the others  Examples  glBegin(GL_POLYGON)  glClear(GL_COLOR_BUFFER_BIT)  include files also define OpenGL data types: GLfloat, GLdouble,….
  • 15. GLUT  Developed by Mark Kilgard  Hides the complexities of differing window system APIs  Default user interface for class projects  Glut routines have prefix glut  glutCreateWindow() …  Has very limited GUI interface  Glui is the C++ extension of glut
  • 16. Glut Routines  Initialization: glutInit() processes (and removes) command-line arguments that may be of interest to glut and the window system and does general initialization of Glut and OpenGL  Must be called before any other glut routines  Display Mode: The next procedure, glutInitDisplayMode(), performs initializations informing OpenGL how to set up the frame buffer.  Display Mode Meaning  GLUT_RGB Use RGB colors  GLUT_RGBA Use RGB plus alpha (for transparency)  GLUT_INDEX Use indexed colors (not recommended)  GLUT_DOUBLE Use double buffering (recommended)  GLUT_SINGLE Use single buffering (not recommended)  GLUT_DEPTH Use depth-buffer (for hidden surface removal.)
  • 17. Glut Routines  Window Setup  glutInitWindowSize(int width, int height)  glutInitWindowPosition(int x, int y)  glutCreateWindow(char* title)
  • 18. A Simple Program Generate a square on a solid background
  • 19. simple.c #include <GL/glut.h> void mydisplay(){ glClear(GL_COLOR_BUFFER_BIT); glBegin(GL_POLYGON); glVertex2f(-0.5, -0.5); glVertex2f(-0.5, 0.5); glVertex2f(0.5, 0.5); glVertex2f(0.5, -0.5); glEnd(); glFlush(); } int main(int argc, char** argv){ glutInit(&argc, argv); glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB); glutInitWindowSize(500,500); glutInitWindowPosition(0,0); glutCreateWindow("simple"); glutDisplayFunc(mydisplay); init(); glutMainLoop(); }
  • 20. Closer Look at the main() #include <GL/glut.h> includes gl.h int main(int argc, char** argv) { glutInit(&argc,argv); glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB); glutInitWindowSize(500,500); glutInitWindowPosition(0,0); glutCreateWindow("simple"); glutDisplayFunc(mydisplay); define window properties init(); display callback set OpenGL state glutMainLoop(); } enter event loop
  • 21. init.c black clear color void init() opaque window { glClearColor (0.0, 0.0, 0.0, 1.0); glColor3f(1.0, 1.0, 1.0); fill/draw with white glMatrixMode (GL_PROJECTION); glLoadIdentity (); glOrtho(-1.0, 1.0, -1.0, 1.0, -1.0, 1.0); } viewing volume
  • 22. Event Handling  Virtually all interactive graphics programs are even driven  GLUT uses callbacks to handle events  Windows system invokes a particular procedure when an event of particular type occurs.  MOST IMPORTANT: display event  Signaled when window first displays and whenever portions of the window reveals from blocking window  glutDisplayFunc(void (*func)(void)) registers the display callback function  Running the program: glutMainLoop()  Main event loop. Never exit()
  • 23. More Callbacks  glutReshapeFunc(void (*func)(int w, int h)) indicates what action should be taken when the window is resized.  glutKeyboardFunc(void (*func)(unsigned char key, int x, int y)) and glutMouseFunc(void (*func)(int button, int state, int x, int y)) allow you to link a keyboard key or a mouse button with a routine that's invoked when the key or mouse button is pressed or released.  glutMotionFunc(void (*func)(int x, int y)) registers a routine to call back when the mouse is moved while a mouse button is also pressed.  glutIdleFunc(void (*func)(void)) registers a function that's to be executed if no other events are pending - for example, when the event loop would otherwise be idle
  • 24. Compilation on Windows  See class web site on how to set up a project with OpenGL  Visual C++  Get glut.h, glut32.lib and glut32.dll from web  Create a console application  Add opengl32.lib, glut32.lib, glut32.lib to project settings (under link tab)
  • 25. Simple Animation  Animation  Redraw + swap buffers  What looks like if using single buffer  Example program  More on the glut documentation  Chapter 2 of textbook  OpenGL redbook  Links in the class resources page
  • 26. OpenGL Drawing  We have learned how to create a window  Steps in the display function  Clear the window  Set drawing attributes  Send drawing commands  Swap the buffers  OpenGL coordinate system has different origin from the window system  Uses lower left corner instead of upper left corner as origin
  • 27. Clear the Window  glClear(GL_COLOR_BUFFER_BIT)  clears the frame buffer by overwriting it with the background color.  Background color is a state set by glClearColor(GLfloat r, GLfloat g, GLfloat b, GLfloat a) in the init().
  • 28. Drawing Attributes: Color  glColor3f(GLfloat r, GLfloat g, GLfloat b) sets the drawing color  glColor3d(), glColor3ui() can also be used  Remember OpenGL is a state machine  Once set, the attribute applies to all subsequent defined objects until it is set to some other value  glColor3fv() takes a flat array as input  There are more drawing attributes than color  Point size: glPointSize()  Line width: glLinewidth()  Dash or dotted line: glLineStipple()  Polygon pattern: glPolygonStipple()  …
  • 29. Drawing Commands  Simple Objects glRectf()  Complex Objects  Use construct glBegin(mode) and glEnd() and a list of vertices in between  glBegin(mode) glVertex(v0); glVertex(v1); ... glEnd();  Some other commands can also be used between glBegin() and glEnd(), e.g. glColor3f().  Example
  • 31. Orthographic projection  Orthographic View  glOrtho(left, right, bottom, top, front, back)  Specifies the coordinates of 3D region to be projected z=0 into the image space.  Any drawing outside the region will be automatically clipped away.
  • 32. Viewports  Do not have use the entire window for the image: glViewport(x,y,w,h)  Values in pixels (screen coordinates)
  • 33. Window to Viewport mapping Aspect Ratio: Height/Width If the aspect ratio of the window Is different from that of the viewport, the picture will be distorted.
  • 34. Sierpinski Gasket (2D)  Start with a triangle  Connect bisectors of sides and remove central triangle  Repeat
  • 35. Example  Five subdivisions
  • 36. Gasket Program #include <GL/glut.h> /* initial triangle */ GLfloat v[3][2]={{-1.0, -0.58}, {1.0, -0.58}, {0.0, 1.15}}; int n; /* number of recursive steps */ void triangle( GLfloat *a, GLfloat *b, GLfloat *c) /* display one triangle */ { glVertex2fv(a); glVertex2fv(b); glVertex2fv(c); }
  • 37. Triangle Subdivision void divide_triangle(GLfloat *a, GLfloat *b, GLfloat *c, int m) { /* triangle subdivision using vertex numbers */ point2 v0, v1, v2; int j; if(m>0) { for(j=0; j<2; j++) v0[j]=(a[j]+b[j])/2; for(j=0; j<2; j++) v1[j]=(a[j]+c[j])/2; for(j=0; j<2; j++) v2[j]=(b[j]+c[j])/2; divide_triangle(a, v0, v1, m-1); divide_triangle(c, v1, v2, m-1); divide_triangle(b, v2, v0, m-1); } else(triangle(a,b,c)); /* draw triangle at end of recursion */ }
  • 38. Gasket Display Functions void display() { glClear(GL_COLOR_BUFFER_BIT); glBegin(GL_TRIANGLES); divide_triangle(v[0], v[1], v[2], n); glEnd(); glFlush(); } • By having the glBegin and glEnd in the display callback rather than in the function triangle and using GL_TRIANGLES rather than GL_POLYGON in glBegin, we call glBegin and glEnd only once for the entire gasket rather than once for each triangle
  • 39. Example: 3D Gasket after 5 iterations
  • 40. Tetrahedron Code void tetrahedron( int m) { glColor3f(1.0,0.0,0.0); divide_triangle(v[0], v[1], v[2], m); glColor3f(0.0,1.0,0.0); divide_triangle(v[3], v[2], v[1], m); glColor3f(0.0,0.0,1.0); divide_triangle(v[0], v[3], v[1], m); glColor3f(0.0,0.0,0.0); divide_triangle(v[0], v[2], v[3], m); }