Models and Architectures. Angel and Shreiner: Interactive Computer Graphics 7E Addison-Wesley 2015

Similar documents
Programming with OpenGL Complete Programs Objectives Build a complete first program

Programming with WebGL Part 1: Background. CS 432 Interactive Computer Graphics Prof. David E. Breen Department of Computer Science

Objectives. Programming with WebGL Part 1: Background. Retained vs. Immediate Mode Graphics. Early History of APIs. PHIGS and X.

CS452/552; EE465/505. Image Formation

API Background. Prof. George Wolberg Dept. of Computer Science City College of New York

Introduction to Computer Graphics with WebGL

CS452/552; EE465/505. Overview of Computer Graphics

Models and Architectures

WebGL A quick introduction. J. Madeira V. 0.2 September 2017

Models and Architectures. Ed Angel Professor of Computer Science, Electrical and Computer Engineering, and Media Arts University of New Mexico

Early History of APIs. PHIGS and X. SGI and GL. Programming with OpenGL Part 1: Background. Objectives

Programming with OpenGL Part 1: Background

Introduction to Computer Graphics with WebGL

CS450/550. Pipeline Architecture. Adapted From: Angel and Shreiner: Interactive Computer Graphics6E Addison-Wesley 2012

Introduction to OpenGL Week 1

Objectives. Image Formation Revisited. Physical Approaches. The Programmer s Interface. Practical Approach. Introduction to OpenGL Week 1

Introduction to Computer Graphics with WebGL

Comp 410/510 Computer Graphics Spring Programming with OpenGL Part 2: First Program

CIS 441/541: Introduction to Computer Graphics Lecture 14: OpenGL Basics

OUTLINE. Learn the basic design of a graphics system Introduce pipeline architecture Examine software components for a graphics system

LECTURE 02 OPENGL API

Today s Agenda. Basic design of a graphics system. Introduction to OpenGL

OPEN GL BACKGROUND. Objectives. Early History of APIs. SGI and GL. PHIGS and X. Modified from Angel 6e book slides

CS452/552; EE465/505. Image Processing Frame Buffer Objects

Graphics Programming

Over the past 15 years, OpenGL has become

Programming with OpenGL Part 1: Background

Programming with OpenGL Part 2: Complete Programs Computer Graphics I, Fall

CS452/552; EE465/505. Models & Viewing

CS452/552; EE465/505. Review & Examples

Computer Graphics. Bing-Yu Chen National Taiwan University

Introduction to Computer Graphics with WebGL

Introduction to OpenGL

Lecture 2 CISC440/640 Spring Department of Computer and Information Science

Computer Graphics and Visualization. Graphics Systems and Models

CSE4030 Introduction to Computer Graphics

Ulf Assarsson Department of Computer Engineering Chalmers University of Technology

INTRODUCTION. Slides modified from Angel book 6e

Introduction to OpenGL/GLSL and WebGL GLSL

Ulf Assarsson Department of Computer Engineering Chalmers University of Technology

Shaders. Slide credit to Prof. Zwicker

CS 432 Interactive Computer Graphics

Building Models. Angel and Shreiner: Interactive Computer Graphics 7E Addison-Wesley 2015

Building Models. CS 537 Interactive Computer Graphics Prof. David E. Breen Department of Computer Science

We will use WebGL 1.0. WebGL 2.0 is now being supported by most browsers but requires a better GPU so may not run on older computers or on most cell

We assume that you are familiar with the following:

Computer Graphics (CS 4731) OpenGL/GLUT(Part 1)

Computer Graphics CS 543 Lecture 4 (Part 2) Building 3D Models (Part 2)

Rendering Objects. Need to transform all geometry then

Lecture 4 of 41. Lab 1a: OpenGL Basics

Graphics Pipeline & APIs

C P S C 314 S H A D E R S, O P E N G L, & J S RENDERING PIPELINE. Mikhail Bessmeltsev

Announcement. Homework 1 has been posted in dropbox and course website. Due: 1:15 pm, Monday, September 12

Introduction to Computer Graphics with WebGL

Graphics Programming. Computer Graphics, VT 2016 Lecture 2, Chapter 2. Fredrik Nysjö Centre for Image analysis Uppsala University

An Overview GLUT GLSL GLEW

2D graphics with WebGL

Graphics Pipeline & APIs

Building Models. Prof. George Wolberg Dept. of Computer Science City College of New York

OpenGL/GLUT Intro. Week 1, Fri Jan 12

Basic Graphics Programming

ERKELEY DAVIS IRVINE LOS ANGELES RIVERSIDE SAN DIEGO SAN FRANCISCO EECS 104. Fundamentals of Computer Graphics. OpenGL

Programming using OpenGL: A first Introduction

OpenGL refresher. Advanced Computer Graphics 2012

Introduction to Shaders.

Comp 410/510 Computer Graphics Spring Programming with OpenGL Part 3: Shaders

CSC Graphics Programming. Budditha Hettige Department of Statistics and Computer Science

CHAPTER 1 Graphics Systems and Models 3

To Do. Computer Graphics (Fall 2008) Course Outline. Course Outline. Methodology for Lecture. Demo: Surreal (HW 3)

BCA611 Video Oyunları için 3B Grafik

CS475/CS675 - Computer Graphics. OpenGL Drawing

Teacher Assistant : Tamir Grossinger Reception hours: by - Building 37 / office -102 Assignments: 4 programing using

Basic Graphics Programming

Computer Graphics (Basic OpenGL)

Real-Time Rendering (Echtzeitgraphik) Michael Wimmer

CS 543 Lecture 1 (Part 3) Prof Emmanuel Agu. Computer Science Dept. Worcester Polytechnic Institute (WPI)

Interactive Computer Graphics A TOP-DOWN APPROACH WITH SHADER-BASED OPENGL

Information Coding / Computer Graphics, ISY, LiTH. OpenGL! ! where it fits!! what it contains!! how you work with it 11(40)

SHADER PROGRAMMING. Based on Jian Huang s lecture on Shader Programming

11/1/13. Basic Graphics Programming. Teaching Assistant. What is OpenGL. Course Producer. Where is OpenGL used. Graphics library (API)

WebGL (Web Graphics Library) is the new standard for 3D graphics on the Web, designed for rendering 2D graphics and interactive 3D graphics.

Lectures OpenGL Introduction

GL_COLOR_BUFFER_BIT, GL_PROJECTION, GL_MODELVIEW

Pipeline Operations. CS 4620 Lecture Steve Marschner. Cornell CS4620 Spring 2018 Lecture 11

WebGL: Hands On. DevCon5 NYC Kenneth Russell Software Engineer, Google, Inc. Chair, WebGL Working Group

Comp 410/510 Computer Graphics Spring Programming with OpenGL Part 4: Three Dimensions

Programming with OpenGL Part 3: Shaders. Ed Angel Professor of Emeritus of Computer Science University of New Mexico

Computer Graphics (CS 543) Lecture 1 (Part 2): Introduction to OpenGL/GLUT (Part 1)

Orthogonal Projection Matrices. Angel and Shreiner: Interactive Computer Graphics 7E Addison-Wesley 2015

OpenGL pipeline Evolution and OpenGL Shading Language (GLSL) Part 2/3 Vertex and Fragment Shaders

Lecture 5 Vertex and Fragment Shaders-1. CITS3003 Graphics & Animation

Precept 2 Aleksey Boyko February 18, 2011

CS230 : Computer Graphics Lecture 4. Tamar Shinar Computer Science & Engineering UC Riverside

Three Main Themes of Computer Graphics

Lecture 3. Programming with OpenGL GLUT + GLEW. CS 354 Computer Graphics Sunday, January 20, 13

Computer Graphics, Chapt 08

CS452/552; EE465/505. Texture Mapping in WebGL

Computer Graphics. OpenGL

Computer Graphics (CS 543) Lecture 3b: Shader Setup & GLSL Introduction

COMP371 COMPUTER GRAPHICS

Transcription:

Models and Architectures 1

Objectives Learn the basic design of a graphics system Introduce pipeline architecture Examine software components for an interactive graphics system 2

Image Formation Revisited Can we mimic the synthetic camera model to design graphics hardware software? Application Programmer Interface (API) Need only specify Objects Materials Viewer Lights But how is the API implemented? 3

Physical Approaches Ray tracing: follow rays of light from center of projection until they either are absorbed by objects or go off to infinity Can handle global effects Multiple reflections Translucent objects Slow Must have whole data base available at all times Radiosity: Energy based approach Very slow 4

Practical Approach Process objects one at a time in the order they are generated by the application Can consider only local lighting Pipeline architecture application program display All steps can be implemented in hardware on the graphics card 5

Vertex Processing Much of the work in the pipeline is in converting object representations from one coordinate system to another Object coordinates Camera (eye) coordinates Screen coordinates Every change of coordinates is equivalent to a matrix transformation Vertex processor also computes vertex colors 6

Projection Projection is the process that combines the 3D viewer with the 3D objects to produce the 2D image Perspective projections: all projectors meet at the center of projection Parallel projection: projectors are parallel, center of projection is replaced by a direction of projection 7

Primitive Assembly Vertices must be collected into geometric objects before clipping and rasterization can take place Line segments Polygons Curves and surfaces 8

Clipping Just as a real camera cannot see the whole world, the virtual camera can only see part of the world or object space Objects that are not within this volume are said to be clipped out of the scene 9

Rasterization If an object is not clipped out, the appropriate pixels in the frame buffer must be assigned colors Rasterizer produces a set of fragments for each object Fragments are potential pixels Have a location in frame bufffer Color and depth attributes Vertex attributes are interpolated over objects by the rasterizer 10

Fragment Processing Fragments are processed to determine the color of the corresponding pixel in the frame buffer Colors can be determined by texture mapping or interpolation of vertex colors Fragments may be blocked by other fragments closer to the camera Hidden-surface removal 11

The Programmer s Interface Programmer sees the graphics system through a software interface: the Application Programmer Interface (API) 12

API Contents Functions that specify what we need to form an image Objects Viewer Light Source(s) Materials Other information Input from devices such as mouse and keyboard Capabilities of system 13

Object Specification Most APIs support a limited set of primitives including Points (0D object) Line segments (1D objects) Polygons (2D objects) Some curves and surfaces Quadrics Parametric polynomials All are defined through locations in space or vertices 14

Example (old style) type of object location of vertex glbegin(gl_polygon) glvertex3f(0.0, 0.0, 0.0); glvertex3f(0.0, 1.0, 0.0); glvertex3f(0.0, 0.0, 1.0); glend( ); end of object definition 15

Example (GPU based) Put geometric data in an array var points = [ vec3(0.0, 0.0, 0.0), vec3(0.0, 1.0, 0.0), vec3(0.0, 0.0, 1.0), ]; Send array to GPU Tell GPU to render as triangle 16

Camera Specification Six degrees of freedom Position of center of lens Orientation Lens Film size Orientation of film plane 17

Lights and Materials Types of lights Point sources vs distributed sources Spot lights Near and far sources Color properties Material properties Absorption: color properties Scattering Diffuse Specular 18

Programming with WebGL Part 1: Background 19

Objectives Development of the OpenGL API OpenGL Architecture OpenGL as a state machine OpenGL as a data flow machine Functions Types Formats Simple program 20

Early History of APIs IFIPS (1973) formed two committees to come up with a standard graphics API Graphical Kernel System (GKS) 2D but contained good workstation model Core Both 2D and 3D GKS adopted as IS0 and later ANSI standard (1980s) GKS not easily extended to 3D (GKS-3D) Far behind hardware development 21

PHIGS and X Programmers Hierarchical Graphics System (PHIGS) Arose from CAD community Database model with retained graphics (structures) X Window System DEC/MIT effort Client-server architecture with graphics PEX combined the two Not easy to use (all the defects of each) 22

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 23

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 24

OpenGL Evolution Originally controlled by an Architectural Review Board (ARB) Members included SGI, Microsoft, Nvidia, HP, 3DLabs, IBM,. Now Kronos Group Was relatively stable (through version 2.5) Backward compatible Evolution reflected new hardware capabilities 3D texture mapping and texture objects Vertex and fragment programs Allows platform specific features through extensions 25

Modern OpenGL Performance is achieved by using GPU rather than CPU Control GPU through programs called shaders Application s job is to send data to GPU GPU does all rendering 26

Immediate Mode Graphics Geometry specified by vertices Locations in space( 2 or 3 dimensional) Points, lines, circles, polygons, curves, surfaces Immediate mode Each time a vertex is specified in application, its location is sent to the GPU Old style uses glvertex Creates bottleneck between CPU and GPU Removed from OpenGL 3.1 and OpenGL ES 2.0 27

Retained Mode Graphics Put all vertex attribute data in array Send array to GPU to be rendered immediately Almost OK but problem is we would have to send array over each time we need another render of it Better to send array over and store on GPU for multiple renderings 28

OpenGL 3.1 Totally shader-based No default shaders Each application must provide both a vertex and a fragment shader No immediate mode Few state variables Most 2.5 functions deprecated Backward compatibility not required Exists a compatibility extension 29

Other Versions OpenGL ES Embedded systems Version 1.0 simplified OpenGL 2.1 Version 2.0 simplified OpenGL 3.1 Shader based WebGL Javascript implementation of ES 2.0 Supported on newer browsers OpenGL 4.1, 4.2,.. Add geometry, tessellation, compute shaders 30

A OpenGL Simple Program Generate a square on a solid background 33

It used to be easy #include <GL/glut.h> void mydisplay(){ glclear(gl_color_buffer_bit); glbegin(gl_quad; glvertex2f(-0.5, -0.5); glvertex2f(-0,5, 0,5); glvertex2f(0.5, 0.5); glvertex2f(0.5, -0.5); glend() } int main(int argc, char** argv){ glutcreatewindow("simple"); glutdisplayfunc(mydisplay); glutmainloop(); } 34

What happened? Most OpenGL functions deprecated immediate vs retained mode make use of GPU Makes heavy use of state variable default values that no longer exist Viewing Colors Window parameters However, processing loop is the same 35

Execution in Browser 36

Event Loop Remember that the sample program specifies a render function which is a event listener or callback function Every program should have a render callback For a static application we need only execute the render function once In a dynamic application, the render function can call itself recursively but each redrawing of the display must be triggered by an event 37

Lack of Object Orientation All versions of OpenGL are not object oriented so that there are multiple functions for a given logical function Example: sending values to shaders gl.uniform3f gl.uniform2i gl.uniform3dv Underlying storage mode is the same 38

WebGL function format function name dimension gl.uniform3f(x,y,z) belongs to WebGL canvas x,y,z are variables gl.uniform3fv(p) p is an array 39

WebGL constants Most constants are defined in the canvas object In desktop OpenGL, they were in #include files such as gl.h Examples desktop OpenGL glenable(gl_depth_test); WebGL gl.enable(gl.depth_test) gl.clear(gl.color_buffer_bit) 40

WebGL and GLSL WebGL requires shaders and is based less on a state machine model than a data flow model Most state variables, attributes and related pre 3.1 OpenGL functions have been deprecated Action happens in shaders Job of application is to get data to GPU 41

GLSL OpenGL Shading Language C-like with Matrix and vector types (2, 3, 4 dimensional) Overloaded operators C++ like constructors Similar to Nvidia s Cg and Microsoft HLSL Code sent to shaders as source code WebGL functions compile, link and get information to shaders 42

Programming with OpenGL Part 2: Complete Programs

Objectives Build a complete first program Introduce shaders Introduce a standard program structure Simple viewing Two-dimensional viewing as a special case of threedimensional viewing Initialization steps and program structure

Square Program

WebGL Five steps Describe page (HTML file) request WebGL Canvas read in necessary files Define shaders (HTML file) could be done with a separate file (browser dependent) Compute or specify data (JS file) Send data to GPU (JS file) Render data (JS file)

square.html <!DOCTYPE html> <html> <head> <script id="vertex-shader" type="x-shader/x-vertex"> attribute vec4 vposition; void main() { gl_position = vposition; } </script> <script id="fragment-shader" type="x-shader/x-fragment"> precision mediump float; void main() { gl_fragcolor = vec4( 1.0, 1.0, 1.0, 1.0 ); } </script>

Shaders We assign names to the shaders that we can use in the JS file These are trivial pass-through (do nothing) shaders that which set the two required built-in variables gl_position gl_fragcolor Note both shaders are full programs Note vector type vec2 Must set precision in fragment shader

square.html (cont) <script type="text/javascript" src="../common/webgl-utils.js"></script> <script type="text/javascript" src="../common/initshaders.js"></script> <script type="text/javascript" src="../common/mv.js"></script> <script type="text/javascript" src="square.js"></script> </head> <body> <canvas id="gl-canvas" width="512" height="512"> Oops... your browser doesn't support the HTML5 canvas element </canvas> </body> </html>

Files../Common/webgl-utils.js: Standard utilities for setting up WebGL context in Common directory on website../common/initshaders.js: contains JS and WebGL code for reading, compiling and linking the shaders../common/mv.js: our matrix-vector package square.js: the application file

square.js var gl; var points; window.onload = function init(){ var canvas = document.getelementbyid( "gl-canvas" ); } gl = WebGLUtils.setupWebGL( canvas ); if (!gl ) { alert( "WebGL isn't available" ); // Four Vertices var vertices = [ vec2( -0.5, -0.5 ), vec2( -0.5, 0.5 ), vec2( 0.5, 0.5 ), vec2( 0.5, -0.5) ];

Notes onload: determines where to start execution when all code is loaded canvas gets WebGL context from HTML file vertices use vec2 type in MV.js JS array is not the same as a C or Java array object with methods vertices.length // 4 Values in clip coordinates

square.js (cont) // Configure WebGL gl.viewport( 0, 0, canvas.width, canvas.height ); gl.clearcolor( 0.0, 0.0, 0.0, 1.0 ); // Load shaders and initialize attribute buffers var program = initshaders( gl, "vertex-shader", "fragment-shader" ); gl.useprogram( program ); // Load the data into the GPU var bufferid = gl.createbuffer(); gl.bindbuffer( gl.array_buffer, bufferid ); gl.bufferdata( gl.array_buffer, flatten(vertices), gl.static_draw ); // Associate out shader variables with our data buffer var vposition = gl.getattriblocation( program, "vposition" ); gl.vertexattribpointer( vposition, 2, gl.float, false, 0, 0 ); gl.enablevertexattribarray( vposition );

Notes initshaders used to load, compile and link shaders to form a program object Load data onto GPU by creating a vertex buffer object on the GPU Note use of flatten() to convert JS array to an array of float32 s Finally we must connect variable in program with variable in shader need name, type, location in buffer

square.js (cont) }; render(); function render() { gl.clear( gl.color_buffer_bit ); gl.drawarrays( gl.triangle_fan, 0, 4 ); } 1 2 0 3

Triangles, Fans or Strips gl.drawarrays( gl.triangles, 0, 6 ); // 0, 1, 2, 0, 2, 3 gl.drawarrays( gl.triangle_fan, 0, 4 ); // 0, 1, 2, 3 1 2 1 2 0 3 0 3 gl.drawarrays( gl.triangle_strip, Angel and Shreiner: Interactive 0, 4 Computer ); // Graphics 0, 1, 7E 3, 2

Program Execution WebGL runs within the browser complex interaction among the operating system, the window system, the browser and your code (HTML and JS) Simple model Start with HTML file files read in asynchronously start with onload function event driven input

Coordinate Systems The units in points are determined by the application and are called object, world, model or problem coordinates Viewing specifications usually are also in object coordinates Eventually pixels will be produced in window coordinates WebGL also uses some internal representations that usually are not visible to the application but are important in the shaders Most important is clip coordinates

Coordinate Systems and Shaders Vertex shader must output in clip coordinates Input to fragment shader from rasterizer is in window coordinates Application can provide vertex data in any coordinate system but shader must eventually produce gl_position in clip coordinates Simple example uses clip coordinates

WebGL Camera WebGL places a camera at the origin in object space pointing in the negative z direction The default viewing volume is a box centered at the origin with sides of length 2

Orthographic Viewing In the default orthographic view, points are projected forward along the z axis onto the plane z=0 z=0 z=0

Viewports Do not have to use the entire window for the image: gl.viewport(x,y,w,h) Values in pixels (window coordinates)

Transformations and Viewing In WebGL, we usually carry out projection using a projection matrix (transformation) before rasterization Transformation functions are also used for changes in coordinate systems Pre 3.1 OpenGL had a set of transformation functions which have been deprecated Three choices in WebGL Application code GLSL functions MV.js

First Assignment: Tessellation and Twist Consider rotating a 2D point about the origin x' = y' = x cosθ xsinθ + y sinθ y cosθ Now let amount of rotation depend on distance from origin giving us twist x'= x cos(dθ) y sin(dθ) y'= x sin(dθ) + y cos(dθ) 2 d x + y 2

Example triangle tessellated triangle twist without tessellation twist after tessellation