Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Slides:



Advertisements
Similar presentations
OPEN GL. Install GLUT Download package di sini Dari devcpp, buka Tools->PackageManager-
Advertisements

Chapter 2: Graphics Programming
Computer Graphics CSCE 441
Informationsteknologi Monday, October 29, 2007Computer Graphics - Class 21 Today’s class Graphics programming Color.
OpenGL (Graphics Library) Software Interface to graphics software Allows to create interactive programs that produce color images of moving 3D objects.
OpenGL (I). What is OpenGL (OGL)? OGL is a 3D graphics & modeling library Can also use it to draw 2D objects.
1 Angel: Interactive Computer Graphics 4E © Addison-Wesley 2005 Programming with OpenGL Part 2: Complete Programs Ed Angel Professor of Computer Science,
1 Angel: Interactive Computer Graphics 4E © Addison-Wesley 2005 Programming with OpenGL Part 1: Background Ed Angel Professor of Computer Science, Electrical.
ITEPC 06 - Workshop on Fractal Creation Chiew-Lan Tai and Oscar Au.
Programming with OpenGL Part 1: Background Mohan Sridharan Based on slides created by Edward Angel CS4395: Computer Graphics 1.
Computer Graphics CS 385 February 7, Fundamentals of OpenGl and Glut Today we will go through the basics of a minimal OpenGl Glut project, explaining.
Reference1. [OpenGL course slides by Rasmus Stenholt]
CS380 LAB I OpenGL Donghyuk Kim Reference1. [OpenGL course slides by Rasmus Stenholt] Reference2. [
Chi-Cheng Lin, Winona State University CS430 Computer Graphics Graphics Programming and OpenGL.
COS 397 Computer Graphics Assoc. Prof. Svetla Boytcheva AUBG 2013 COS 397 Computer Graphics Practical Session №1 Introduction to OpenGL, GLFW and CG.
Basic OpenGL Glenn G. Chappell U. of Alaska Fairbanks CS 381 Lecture Notes Wednesday, September 10, 2003.
Using OpenGL. 2 What is OpenGL? A software interface to graphics hardware It is a Graphics Rendering API (Application Programmer’s Interface) that is.
Drawing Basic Graphics Primitives Lecture 4 Wed, Sep 3, 2003.
Introduction to OpenGL and GLUT GLUT. What is OpenGL? An application programming interface (API) A (low-level) Graphics rendering API Generate high-quality.
Computer Graphics using OpenGL, 3 rd Edition F. S. Hill, Jr. and S. Kelley Chapter 2 Initial Steps in Drawing Figures Ureerat Suksawatchon Faculty of Informatics.
2 COEN Computer Graphics I Introductions n Brad Grantham lecturer lab dude n Dave Shreiner lecturer slave driver.
Programming with OpenGL Part 1: Background
1 Angel: Interactive Computer Graphics 4E © Addison-Wesley 2005 Programming with OpenGL Part 1: Background Ed Angel Professor of Computer Science, Electrical.
Ch 2 Graphics Programming page 1 CSC 367 Coordinate Systems (2.1.2) Device coordinates, or screen coordinates (pixels) put limitations on programmers and.
1. OpenGL/GLU/GLUT  OpenGL v4.0 (latest) is the “core” library that is platform independent  GLUT v3.7 is an auxiliary library that handles window creation,
1 Figures are extracted from Angel's book (ISBN x) The Human Visual System vs The Pinhole camera Human Visual System Visible Spectrum Pinhole.
CD2012 Principles of Interactive Graphics Lecture 01 Introduction Abir Hussain (Rome: 6.33,Tel , Web:
Introduction to GL Geb Thomas. Example Code int main(int argc, char **argv) { glutInit(&argc, argv); glutInitDisplayMode ( GLUT_SINGLE | GLUT_RGB | GLUT_DEPTH);
CA 302 Computer Graphics and Visual Programming Lecture 2: Introduction to OpenGL Aydın Öztürk
Chun-Yuan Lin Introduction to OpenGL 2015/12/19 1 CG.
NoufNaief.net TA: Nouf Al-harbi.
Computer Graphics Lab 1 OpenGL.
NoufNaief.net 1 TA: Nouf Al-Harbi.
Geometric Primitives Used in Open GL Drawing Triangles glBegin(GL_TRIANGELS); glVertex2i(p0); glVertex2i(p1); glVertex2i(p2); glVertex2i(p3); glVertex2i(p4);
CSCE 441: Computer Graphics
1 Programming with OpenGL Part 2: Complete Programs.
OpenGL API 2D Graphic Primitives Angel Angel: Interactive Computer Graphics5E © Addison-Wesley
OpenGL: Introduction #include main() { OpenWindow() ; glClearColor(0.0, 0.0, 0.0, 0.0); glClear(GL_COLOR_BUFFER_BIT); glOrtho(-1.0, 1.0, -1.0, 1.0, -1.0,
CIS 681 Review: OpenGL. CIS 681 Command Syntax OpenGL commands start with a gl. This is followed by the base command such as Color. Followed by the number.
Introduction to OpenGL Muhammad Aamir Khan Lecturer, DCS, UOP.
Introduction to Graphics Programming. Graphics API.
Graphics Graphics Korea University kucg.korea.ac.kr Graphics Programming 고려대학교 컴퓨터 그래픽스 연구실.
Introduction to Graphics Programming. Graphics: Conceptual Model Real Object Human Eye Display Device Graphics System Synthetic Model Synthetic Camera.
Computer Graphics I, Fall Programming with OpenGL Part 2: Complete Programs.
INTRODUCTION TO OPENGL
Computer Graphics (Fall 2003) COMS 4160, Lecture 5: OpenGL 1 Ravi Ramamoorthi Many slides courtesy Greg Humphreys.
Computer Graphics -practical- Lecture 6. (visual c++) open gl library To use open GL with VC++ we add these files:- 1)Glut.h C:\program files\ Microsoft.
CSC Graphics Programming
Introduction to OpenGL (IDE: Eclipse)
The Human Visual System vs The Pinhole camera
Programming with OpenGL Part 1: Background
CS380 Lab Spring Myungbae Son.
“Computer Science is no more about computers than astronomy is about telescopes.” Professor Edsger Dijkstra.
Programming with OpenGL Part 2: Complete Programs
OpenGL API 2D Graphic Primitives
Programming with OpenGL Part 2: Complete Programs
OpenGL (Open Graphics Library) Mr. B.A.Swamy Assistant Professor Dept of CSE.
Lab 3 Geometric Drawing Lab 3 Geometric Drawing.
Starting to draw dealing with Windows which libraries? clipping
גרפיקה ממוחשבת: מבוא ל-OpenGL
Programming with OpenGL Part 1: Background
Drawing in the plane 455.
Computer Graphics, Lee Byung-Gook, Dongseo Univ.
Introduction to OpenGL
Programming with OpenGL Part 2: Complete Programs
Programming with OpenGL Part 2: Complete Programs
Programming with OpenGL Part 1: Background
Starting to draw dealing with Windows which libraries? clipping
Programming with OpenGL Part 2: Complete Programs
University of North Carolina at Greensboro
Presentation transcript:

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 Computer Graphics Lee Byung-Gook 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 OpenGL Most Widely Adopted Graphics Standard High Visual Quality and Performance Industry standard, Reliable and portable Stable, Easy to use and Well-documented 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

OpenGL software libraries 13 January 2019 OpenGL software libraries This course makes use of several popular libraries to help build sophisticated portable graphics applications with minimal effort. The following diagram gives an overview of the packages and how they interact. For the purposes of this course, one can think of the GLU and glut libraries as being part of the OpenGL library or the OpenGL API (application programmer's interface), even though this is not really the case. The Tcl/Tk library will only be used for some assignments and in these cases is used to provide a reasonable command-line interface and graphical interface to the graphics code. It provides easy-to-use scripting functionality and a graphical user interface toolkit 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 Software libraries OpenGL : provides most of the graphics functionality GLU : provides support for some additional operations and primitive types, and is implemented using OpenGL function calls glut : designed specifically to be used with OpenGL and it takes care of things like opening windows, redraw events, and keyboard and mouse input. It effectively hides all the windowing system dependencies for OpenGL 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Installing OpenGL for Windows 13 January 2019 Installing OpenGL for Windows bundled with Win98, Win95, WinNT or download** it look for dynamically-linked libraries (dlls): C:\Winnt\system32\Opengl32.dll on Windows NT C:\Windows\system\Opengl32.dll on Windows 95 look for header files, e.g., for Visual C++: C:\Program Files\Microsoft Visual Studio\VC98\include\gl\*.h OpenGL v1.1 software runtime is included as part of operating system for Windows 2000, Windows 98, Windows 95 (OSR2) and Windows NT. So you only need to download this if you think your copy is somehow missing . The OpenGL v1.1 libraries are also available as the self-extracting archive file from the Microsoft Site via HTTP or FTP. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Installing glut for Windows http://www.opengl.org/developers/documentation/glut.html?glut#first_hit glut.h C:\Program Files\Microsoft Visual Studio\VC98\include\gl\glut.h glut32.lib C:\Program Files\Microsoft Visual Studio\VC98\lib\glut32.lib glut32.dll C:\Windows\system32\glut32.dll on Windows 95, 98 C:\WINNT\system32\glut32.dll on Windows 2000, NT 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Compiling with Visual C++ 13 January 2019 Compiling with Visual C++ Start Visual C++ Choose File  new, then from the Projects tab select Win32 Console Application Assign the project a name (`lab00' for example), and choose a directory where the project files will be stored Choose File  new, then from the Files tab select  C++ Source File Assign the file a name, ‘lab00' for example. The .cpp extension will be added for you. Fill in the file lab00.cpp Now, Let’s begin OpenGL program. The following steps describe how to write and compile a simple OpenGL application in the Visual C++ environment. They assume that the OpenGL and glut libraries have been properly installed. The example was tested with Microsoft Visual C++ v5.0, although I expect that any version after and including v4.0 to work identically. The following example code draws a barney purple rectangle on a light gray background. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 lab00.cpp // lab00.cpp, Computer Graphics, lbg@dongseo.ac.kr #include <GL/glut.h> void myDisplay(void) { glClearColor (.75, .75, .75, 0.0); glMatrixMode(GL_PROJECTION); glOrtho(0, 500, 0, 500, -1, 1); glMatrixMode(GL_MODELVIEW); glClear(GL_COLOR_BUFFER_BIT); glColor3f(0.60, .40, .70); glBegin(GL_POLYGON); glVertex2i(450, 250); glVertex2i(412, 367); glVertex2i(312, 440); glVertex2i(188, 440); glVertex2i(88, 368); glVertex2i(50, 250); glVertex2i(88, 132); glVertex2i(188, 60); glVertex2i(312, 60); glVertex2i(412, 132); glEnd(); glFlush(); } void main(int argc, char** argv) { glutInit(&argc,argv); glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB); glutInitWindowSize(500,500); glutInitWindowPosition(0,0); glutCreateWindow("lab00"); glutDisplayFunc(myDisplay); glutMainLoop(); } 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Compiling with Visual C++ 13 January 2019 Compiling with Visual C++ Choose Project  Settings and select the C/C++ panel. Enable Generate browse info. Select the Link panel. At the beginning (or anywhere) of the Object/library modules entry, add the libraries opengl32.lib and glut32.lib. Accept all the project setting changes by choosing OK. This will later enable you to easily track where functions are defined and where they are referenced, much like the `tags' feature in emacs.  Leave the other entries in the panel as they are. Don't hit OK just yet. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Compiling with Visual C++ Choose Build  Build lab00.exe, or simply hit the F7 key in order to compile and link. A successful compilation would have produced the following output in your 'build' window: ------------Configuration: lab00 - Win32 Debug----------- Compiling... lab00.cpp Linking... lab00.exe - 0 error(s), 0 warning(s) 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Compiling with Visual C++ If there are errors, hitting F4 will take you to the location of the first error message in the code, and thereafter always take you to the next error message.  Or, one can double click on any error message to jump to the relevant source code. Once the code has successfully compiled and linked, Build-Execute or Ctrl-F5 will run the code, as will double-clicking on the test.exe icon (found in the Debug directory) from a file browsing window. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Basic drawing OpenGL is a "state" machine : Once it is in a state, it stays in that state until the state is changed. Basic commands glClearColor(red, green, blue, 0.0); // sets background color glClear(GL_COLOR_BUFFER_BIT); // clears the window to the background color glColor3f(red, green, blue); // values between 0.0 (no color) & 1.0 (full color) glBegin(*); // determines how vertices are interpreted 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Basic drawing glVertex2i(412, 367); glVertex2i(312, 440); glVertex2i(188, 440); glVertex2i(88, 368); glVertex2i(50, 250); glVertex2i(88, 132); glVertex2i(188, 60); glVertex2i(312, 60); glVertex2i(412, 132); glEnd(); // clears the state initiated by 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 Colors {1.0f, 0.0f, 0.0f} //red {0.0f, 1.0f, 0.0f} //green {0.0f, 0.0f, 1.0f} //blue {1.0f, 1.0f, 0.0f} //yellow {1.0f, 0.0f, 1.0f} //magenta {0.0f, 1.0f, 1.0f} //cyan {1.0f, 1.0f, 1.0f} //white {.25f, .25f, .25f} //dark gray {.75f, .75f, .75f} //light gray {.60f, .40f, .12f} //brown {.60f, .40f, .70f} //barney purple {.98f, .625f, .12f} //pumpkin orange {.98f, .04f, .70f} //pastel pink This is famous color values. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 Drawing primitives OpenGL supports several basic primitive types, including points, lines, quadrilaterals, and general polygons. All of these primitives are specified using a sequence of vertices. glBegin and glEnd delimit the vertices that define a primitive or a group of like primitives. GL_POINTS Treats each vertex as a single point. Vertex n defines point n. N points are drawn. glBegin accepts a single argument that specifies in which of ten ways the vertices are interpreted. Taking n as an integer count starting at one, and N as the total number of vertices specified, the interpretations are as follows: 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Drawing primitives GL_LINES Treats each pair of vertices as an independent line segment. Vertices 2n-1 and 2n define line n. N/2 lines are drawn. GL_LINE_STRIP Draws a connected group of line segments from the first vertex to the last. Vertices n and n+1 define line n. N-1 lines are drawn. GL_LINE_LOOP Draws a connected group of line segments from the first vertex to the last, then back to the first. Vertices n and n+1 define line n. The last line, however, is defined by vertices N and 1. N lines are drawn. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Drawing primitives GL_TRIANGLES Treats each triplet of vertices as an independent triangle. Vertices 3n-2, 3n-1, and 3n define triangle n. N/3 triangles are drawn. GL_TRIANGLE_STRIP Draws a connected group of triangles. One triangle is defined for each vertex presented after the first two vertices. For odd n, vertices n, n+1, and n+2 define triangle n. For even n, vertices n+1, n, and n+2 define triangle n. N-2 triangles are drawn. GL_TRIANGLE_FAN Draws a connected group of triangles. One triangle is defined for each vertex presented after the first two vertices. Vertices 1, n+1, and n+2 define triangle n. N-2 triangles are drawn. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Triangle 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Drawing primitives GL_QUADS Treats each group of four vertices as an independent quadrilateral. Vertices 4n-3, 4n-2, 4n-1, and 4n define quadrilateral n. N/4 quadrilaterals are drawn. GL_QUAD_STRIP Draws a connected group of quadrilaterals. One quadrilateral is defined for each pair of vertices presented after the first pair. Vertices 2n-1, 2n, 2n+2, and 2n+1 define quadrilateral n. N/2-1 quadrilaterals are drawn. Note that the order in which vertices are used to construct a quadrilateral from strip data is different from that used with independent data. GL_POLYGON Draws a single, convex polygon. Vertices 1 through N define this polygon. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Quad 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 Basic primitives GL_LINES, GL_LINE_STRIP All of the closed primitives shown below are solid-filled, with the exception of GL_LINE_LOOP, which only draws lines connecting the vertices. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Basic primitives GL_LINE_LOOP, GL_TRIANGLES 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Basic primitives GL_TRIANGLE_STRIP, GL_TRIANGLE_FAN 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Basic primitives GL_QUADS, GL_POLYGON 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

OpenGL Naming Convension 13 January 2019 OpenGL Naming Convension gl : gl library Vertex : command 2f : number and type of parameters OpenGL Data Type Presentation C-language GLbyte 8-bit integer signed char b GLshort 16-bit integer short s GLint, GLsizei 32-bit integer long l GLfloat,GLclampf 32-bit float float f GLdouble,GLclampd 64-bit float double d GLubyte,GLboolean 8-bit unsigned unsigned char ub GLushort 16-bit unsigned unsigned short us GLuint,GLenum 32-bit unsigned unsigned long ui GL commands are functions or procedures. Various groups of commands perform the same operation but differ in how arguments are supplied to them. To conveniently accommodate this variation, we adopt a notation for describing commands and their arguments. 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 glVertex[234][b s i f d ub us ui]{v}(*) // allows 2 (x,y), 3 (x,y,z), or 4 (x,y,z,w) values // allows the following data types // b signed char; 8 bit integer // s short; 16 bit integer // i integer; 32 bit integer // f float; 32 bits // d double; 64 bits // ub unsigned byte; 8 bits // us unsigned short; 16 bits // ui unsigned int; 32 bits // optional v  defined in an array (vector) GL commands are formed from a name followed, depending on the particular command, by up to 4 characters. The first character indicates the number of values of the indicated type that must be presented to the command. The second character or character pair indicates the specific type of the arguments: 8-bit integer, 16-bit integer, 32-bit integer, single-precision floating-point, or double-precision floating-point. The final character, if present, is v, indicating that the command takes a pointer to an array (a vector) of values rather than a series of individual arguments. Two specific examples come from the Vertex command to sends a vertex to be drawn void Vertex3f( float x, float y, float z ); and void Vertex2sv( short v[2] ); 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 lab01.cpp // lab01.cpp, Computer Graphics, lbg@dongseo.ac.kr #include <stdio.h> #include <stdlib.h> #include <GL/glut.h> GLint windowWidth, windowHeight, N=4; void myAxis(void) { int i; glColor3f(0.98, .04, .70); glBegin(GL_LINES); for(i=1; i<N; i++) { glVertex2i(i*windowWidth/N, 0); glVertex2i(i*windowWidth/N, windowHeight); glVertex2i(0, i*windowHeight/N); glVertex2i(windowWidth, i*windowHeight/N); } glEnd(); void myDraw(void) { glColor3f(0.60, .40, .70); glBegin(GL_POLYGON); glVertex2i(windowWidth/N, windowHeight/N); glVertex2i(3*windowWidth/N, windowHeight/N); glVertex2i(3*windowWidth/N, 3*windowHeight/N); glVertex2i(windowWidth/N, 3*windowHeight/N); glEnd(); } void myDisplay(void) glClear(GL_COLOR_BUFFER_BIT); myAxis(); myDraw(); glFlush(); 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. 13 January 2019 lab01.cpp void myReshape(int width, int height) { glClearColor (.75, .75, .75, 0.0); glViewport(0,0,width,height); glMatrixMode(GL_PROJECTION); glLoadIdentity(); glOrtho(0, width, 0, height, -1, 1); windowWidth=width; windowHeight=height; glMatrixMode(GL_MODELVIEW); } void main(int argc, char** argv) glutInit(&argc,argv); glutInitDisplayMode (GLUT_SINGLE | GLUT_RGB); glutInitWindowSize(500,500); glutInitWindowPosition(0,0); glutCreateWindow("lab01"); glutReshapeFunc(myReshape); glutDisplayFunc(myDisplay); glutMainLoop(); 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Lab 01 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Lab 0101, 0102 Homework1 : in two weeks 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Lab 0103, 0104 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Lab 0105, 0106 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Lab 0107, 0108 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.

Computer Graphics, Lee Byung-Gook, Dongseo Univ. Lab 0109 13 January 2019 Computer Graphics, Lee Byung-Gook, Dongseo Univ.