Viewing & Shading III Pertemuan 14 Hand out Komputer Grafik.

Slides:



Advertisements
Presentasi serupa
Soal No 17 halaman 66 Find a) the coordinates of the foci and vertices for hyperbola whose equations given, b) equation of the asymptotes. Sketch the curve.
Advertisements

Hidden Surface Removal (HSR)
Tugas Besar Input & Transformasi
2. Introduction to Algorithm and Programming
Learning Medium School : SMPN 1 Gotham City Subject : English
K-Map Using different rules and properties in Boolean algebra can simplify Boolean equations May involve many of rules / properties during simplification.
TEKNIK PENGINTEGRALAN
Teorema Green.
1 Angel: Interactive Computer Graphics 4E © Addison-Wesley 2005 Shading Ed Angel Professor of Computer Science, Electrical and Computer Engineering, and.
Pengantar Kuliah: Grafika Komputer
BLACK BOX TESTING.
Presented By : Group 2. A solution of an equation in two variables of the form. Ax + By = C and Ax + By + C = 0 A and B are not both zero, is an ordered.
The steps to work with Power Point click Start> All Programs> Microsoft Office> Microsoft Office PowerPoint2007 klik Start>All Programs>Microsoft.
1 Pertemuan 09 Kebutuhan Sistem Matakuliah: T0234 / Sistem Informasi Geografis Tahun: 2005 Versi: 01/revisi 1.
Mental Ray Materials Pertemuan 02 Matakuliah: U0686 – Modeling & Shading, Lighting, Rendering II Tahun: 2009.
Pertemuan 07 Peluang Beberapa Sebaran Khusus Peubah Acak Kontinu
HAMPIRAN NUMERIK SOLUSI PERSAMAAN NIRLANJAR Pertemuan 3
1 Pertemuan 15 Game Playing Matakuliah: T0264/Intelijensia Semu Tahun: Juli 2006 Versi: 2/1.
1 HAMPIRAN NUMERIK SOLUSI PERSAMAAN LANJAR Pertemuan 5 Matakuliah: K0342 / Metode Numerik I Tahun: 2006 TIK:Mahasiswa dapat meghitung nilai hampiran numerik.
1 Pertemuan 13 Algoritma Pergantian Page Matakuliah: T0316/sistem Operasi Tahun: 2005 Versi/Revisi: 5.
Imam Cholissodin| 10 | Lighting & Shading Imam Cholissodin|
Pertemuan 9 : Pewarnaan graph
COMPUTER GRAPHICS D10K-5C01 GK11: OpenGL Transformasi dan Interaksi Dr. Setiawan Hadi, M.Sc.CS. Program Studi S-1 Teknik Informatika FMIPA Universitas.
9.3 Geometric Sequences and Series. Objective To find specified terms and the common ratio in a geometric sequence. To find the partial sum of a geometric.
Chapter 10 – The Design of Feedback Control Systems PID Compensation Networks.
Electric Field Wenny Maulina. Electric Dipole A pair of equal and opposite charges q separated by a displacement d is called an electric dipole. It has.
Jartel, Sukiswo Sukiswo
EIS (Executive Information Systems)
Linear algebra Yulvi zaika.
VEKTOR VEKTOR PADA BIDANG.
Program Studi Teknologi Game Politeknik Elektronika Negeri Surabaya
GEOMETRI SUDUT DAN BIDANG.
Rekayasa Perangkat Lunak Class Diagram
Proses astrofisika i SENSITIVITY TO INITIAL CONDITIONS
Cartesian coordinates in two dimensions
Konsep pemrograman LOOP
Program Studi S-1 Teknik Informatika FMIPA Universitas Padjadjaran
Technology And Engineering TECHNOLOGY AND ENGINERRING
Cartesian coordinates in two dimensions
Creatif by : Nurlia Enda
CAD READER PERTEMUAN 4.
CLASS DIAGRAM.
Dasar-Dasar Pemrograman
CA113 Pengantar Manajemen Bisnis
Parabola Parabola.
VECTOR VECTOR IN PLANE.
Install wooden scaffolding
FISIKA DASAR By: Mohammad Faizun, S.T., M.Eng.
BILANGAN REAL BILANGAN BERPANGKAT.
Two-and Three-Dimentional Motion (Kinematic)
REAL NUMBERS EKSPONENT NUMBERS.
Persamaan Gelombang bunyi periodik Sifat-sifat Gelombang Bunyi
CA113 Pengantar Manajemen Bisnis
Lighting & Texture Mapping
Program Studi S-1 Teknik Informatika FMIPA Universitas Padjadjaran
EIS (Executive Information Systems)
Master data Management
Pertemuan 4 CLASS DIAGRAM.
Analisis Korelasi dan Regresi Berganda Manajemen Informasi Kesehatan
Magnitude and Vector Physics 1 By : Farev Mochamad Ihromi / 010
How to Set Up AT&T on MS Outlook ATT is a multinational company headquartered in Texas. ATT services are used by many people widely across.
Things You Need to Know Before Running on the Beach.
Don’t Forget to Avail the Timely Offers with Uber
CA113 Pengantar Manajemen Bisnis
Simultaneous Linear Equations
Take a look at these photos.... Also, in case you're wondering where this hotel is, it isn't a hotel at all. It is a house! It's owned by the family of.
Aplikasi Graph Minimum Spaning Tree Shortest Path.
Al Muizzuddin F Matematika Ekonomi Lanjutan 2013
Vector. A VECTOR can describe anything that has both MAGNITUDE and DIRECTION The MAGNITUDE describes the size of the vector. The DIRECTION tells you where.
Draw a picture that shows where the knife, fork, spoon, and napkin are placed in a table setting.
Transcript presentasi:

Viewing & Shading III Pertemuan 14 Hand out Komputer Grafik

TIU: Mahasiswa mampu menghasilkan aplikasi Komputer Grafik sederhana (2) Mampu menggunakan aplikasi pengolah grafis 3D untuk membuat animasi 3 dimensi sederhana (C3,P3) (1) Mampu menjelaskan konsep dasar grafika di komputer (C2) Entry Behaviour Memahami konsep pemrograman berorientasi Obyek (3) Mampu menganalisa aplikasi pengolah grafis yang menampilkan gambar 2 dimensi (C4,P3) (4) Mampu menghasilkan aplikasi pengolah grafis yang memiliki kemampuan mentransformasi obyek vektor dan berinteraksi dengan pengguna (C5,P3) (5) Mampu menghasilkan aplikasi pengolah grafis yang memiliki kemampuan mengatur viewing dan shading (C5,P3) Memahami konsep Vektor, Persamaan Linier, Matrik, dan Determinan

Bahasan Pokok: Konsep Viewing dan shading pada OpenGL API Pokok: Konsep Viewing dan shading pada OpenGL API Sub: Sub: Viewing API Viewing API Proyeksi API Proyeksi API Cahaya dan benda Cahaya dan benda Sumber cahaya Sumber cahaya Refleksi Refleksi Polygonal Shading (Flat & Smooth) Polygonal Shading (Flat & Smooth) Sumber cahaya API Sumber cahaya API Material API Material API Tugas Besar 4 Tugas Besar 4

Steps in OpenGL shading 1. Enable shading and select model 2. Specify normals 3. Specify material properties 4. Specify lights

Normals In OpenGL the normal vector is part of the state In OpenGL the normal vector is part of the state Set by glNormal*() Set by glNormal*() glNormal3f(x, y, z); glNormal3f(x, y, z); glNormal3fv(p); glNormal3fv(p); Usually we want to set the normal to have unit length so cosine calculations are correct Usually we want to set the normal to have unit length so cosine calculations are correct Length can be affected by transformations Length can be affected by transformations Note that scaling does not preserved length Note that scaling does not preserved length glEnable(GL_NORMALIZE) allows for autonormalization at a performance penalty glEnable(GL_NORMALIZE) allows for autonormalization at a performance penalty

Normal for Triangle p0p0 p1p1p1p1 p2p2 n plane n ·(p - p 0 ) = 0 n = (p 2 - p 0 ) ×(p 1 - p 0 ) normalize n  n/ |n| p Note that right-hand rule determines outward face

Enabling Shading Shading calculations are enabled by Shading calculations are enabled by glEnable(GL_LIGHTING) glEnable(GL_LIGHTING) Once lighting is enabled, glColor() ignored Once lighting is enabled, glColor() ignored Must enable each light source individually Must enable each light source individually glEnable(GL_LIGHTi) i=0,1….. glEnable(GL_LIGHTi) i=0,1….. Can choose light model parameters Can choose light model parameters glLightModeli(parameter, GL_TRUE) glLightModeli(parameter, GL_TRUE) GL_LIGHT_MODEL_LOCAL_VIEWER do not use simplifying distant viewer assumption in calculation GL_LIGHT_MODEL_LOCAL_VIEWER do not use simplifying distant viewer assumption in calculation GL_LIGHT_MODEL_TWO_SIDED shades both sides of polygons independently GL_LIGHT_MODEL_TWO_SIDED shades both sides of polygons independently

Defining a Point Light Source For each light source, we can set an RGBA for the diffuse, specular, and ambient components, and for the position For each light source, we can set an RGBA for the diffuse, specular, and ambient components, and for the position GL float diffuse0[]={1.0, 0.0, 0.0, 1.0}; GL float ambient0[]={1.0, 0.0, 0.0, 1.0}; GL float specular0[]={1.0, 0.0, 0.0, 1.0}; Glfloat light0_pos[]={1.0, 2.0, 3,0, 1.0}; glEnable(GL_LIGHTING); glEnable(GL_LIGHT0); glLightv(GL_LIGHT0, GL_POSITION, light0_pos); glLightv(GL_LIGHT0, GL_AMBIENT, ambient0); glLightv(GL_LIGHT0, GL_DIFFUSE, diffuse0); glLightv(GL_LIGHT0, GL_SPECULAR, specular0);

Distance and Direction The source colors are specified in RGBA The source colors are specified in RGBA The position is given in homogeneous coordinates The position is given in homogeneous coordinates If w =1.0, we are specifying a finite location If w =1.0, we are specifying a finite location If w =0.0, we are specifying a parallel source with the given direction vector If w =0.0, we are specifying a parallel source with the given direction vector The coefficients in the distance terms are by default a=1.0 (constant terms), b=c=0.0 (linear and quadratic terms ). Change by The coefficients in the distance terms are by default a=1.0 (constant terms), b=c=0.0 (linear and quadratic terms ). Change by a= 0.80; glLightf(GL_LIGHT0, GLCONSTANT_ATTENUATION, a);

Spotlights Use glLightv to set Use glLightv to set Direction GL_SPOT_DIRECTION Direction GL_SPOT_DIRECTION Cutoff GL_SPOT_CUTOFF Cutoff GL_SPOT_CUTOFF Attenuation GL_SPOT_EXPONENT Attenuation GL_SPOT_EXPONENT Proportional to cos   Proportional to cos     

Global Ambient Light Ambient light depends on color of light sources Ambient light depends on color of light sources A red light in a white room will cause a red ambient term that disappears when the light is turned off A red light in a white room will cause a red ambient term that disappears when the light is turned off OpenGL also allows a global ambient term that is often helpful for testing OpenGL also allows a global ambient term that is often helpful for testing glLightModelfv(GL_LIGHT_MODEL_AMBIENT, global_ambient) glLightModelfv(GL_LIGHT_MODEL_AMBIENT, global_ambient)

Moving Light Sources Light sources are geometric objects whose positions or directions are affected by the model- view matrix Light sources are geometric objects whose positions or directions are affected by the model- view matrix Depending on where we place the position (direction) setting function, we can Depending on where we place the position (direction) setting function, we can Move the light source(s) with the object(s) Move the light source(s) with the object(s) Fix the object(s) and move the light source(s) Fix the object(s) and move the light source(s) Fix the light source(s) and move the object(s) Fix the light source(s) and move the object(s) Move the light source(s) and object(s) independently Move the light source(s) and object(s) independently

Material Properties Material properties are also part of the OpenGL state and match the terms in the modified Phong model Material properties are also part of the OpenGL state and match the terms in the modified Phong model Set by glMaterialv() Set by glMaterialv() GLfloat ambient[] = {0.2, 0.2, 0.2, 1.0}; GLfloat diffuse[] = {1.0, 0.8, 0.0, 1.0}; GLfloat specular[] = {1.0, 1.0, 1.0, 1.0}; GLfloat shine = glMaterialf(GL_FRONT, GL_AMBIENT, ambient); glMaterialf(GL_FRONT, GL_DIFFUSE, diffuse); glMaterialf(GL_FRONT, GL_SPECULAR, specular); glMaterialf(GL_FRONT, GL_SHININESS, shine);

Front and Back Faces The default is shade only front faces which works correctly for convex objects The default is shade only front faces which works correctly for convex objects If we set two sided lighting, OpenGL will shade both sides of a surface If we set two sided lighting, OpenGL will shade both sides of a surface Each side can have its own properties which are set by using GL_FRONT, GL_BACK, or GL_FRONT_AND_BACK in glMaterialf Each side can have its own properties which are set by using GL_FRONT, GL_BACK, or GL_FRONT_AND_BACK in glMaterialf back faces not visibleback faces visible

Emissive Term We can simulate a light source in OpenGL by giving a material an emissive component We can simulate a light source in OpenGL by giving a material an emissive component This component is unaffected by any sources or transformations This component is unaffected by any sources or transformations GLfloat emission[] = 0.0, 0.3, 0.3, 1.0); glMaterialf(GL_FRONT, GL_EMISSION, emission);

Transparency Material properties are specified as RGBA values Material properties are specified as RGBA values The A value can be used to make the surface translucent The A value can be used to make the surface translucent The default is that all surfaces are opaque regardless of A The default is that all surfaces are opaque regardless of A Later we will enable blending and use this feature Later we will enable blending and use this feature

Efficiency Because material properties are part of the state, if we change materials for many surfaces, we can affect performance Because material properties are part of the state, if we change materials for many surfaces, we can affect performance We can make the code cleaner by defining a material structure and setting all materials during initialization We can make the code cleaner by defining a material structure and setting all materials during initialization We can then select a material by a pointer We can then select a material by a pointer typedef struct materialStruct { GLfloat ambient[4]; GLfloat diffuse[4]; GLfloat specular[4]; GLfloat shineness; } MaterialStruct;

Polygonal Shading Shading calculations are done for each vertex Shading calculations are done for each vertex Vertex colors become vertex shades Vertex colors become vertex shades By default, vertex shades are interpolated across the polygon By default, vertex shades are interpolated across the polygon glShadeModel(GL_SMOOTH); glShadeModel(GL_SMOOTH); If we use glShadeModel(GL_FLAT); the color at the first vertex will determine the shade of the whole polygon If we use glShadeModel(GL_FLAT); the color at the first vertex will determine the shade of the whole polygon

Polygon Normals Polygons have a single normal Polygons have a single normal Shades at the vertices as computed by the Phong model can be almost same Shades at the vertices as computed by the Phong model can be almost same Identical for a distant viewer (default) or if there is no specular component Identical for a distant viewer (default) or if there is no specular component Consider model of sphere Consider model of sphere Want different normals at Want different normals at each vertex even though this concept is not quite correct mathematically

Smooth Shading We can set a new normal at each vertex We can set a new normal at each vertex Easy for sphere model Easy for sphere model If centered at origin n = p If centered at origin n = p Now smooth shading works Now smooth shading works Note silhouette edge Note silhouette edge

Mesh Shading The previous example is not general because we knew the normal at each vertex analytically The previous example is not general because we knew the normal at each vertex analytically For polygonal models, Gouraud proposed we use the average of the normals around a mesh vertex For polygonal models, Gouraud proposed we use the average of the normals around a mesh vertex n = (n 1 +n 2 +n 3 +n 4 )/ |n 1 +n 2 +n 3 +n 4 |

Gouraud and Phong Shading Gouraud Shading Gouraud Shading Find average normal at each vertex (vertex normals) Find average normal at each vertex (vertex normals) Apply modified Phong model at each vertex Apply modified Phong model at each vertex Interpolate vertex shades across each polygon Interpolate vertex shades across each polygon Phong shading Phong shading Find vertex normals Find vertex normals Interpolate vertex normals across edges Interpolate vertex normals across edges Interpolate edge normals across polygon Interpolate edge normals across polygon Apply modified Phong model at each fragment Apply modified Phong model at each fragment

Comparison If the polygon mesh approximates surfaces with a high curvatures, Phong shading may look smooth while Gouraud shading may show edges If the polygon mesh approximates surfaces with a high curvatures, Phong shading may look smooth while Gouraud shading may show edges Phong shading requires much more work than Gouraud shading Phong shading requires much more work than Gouraud shading Until recently not available in real time systems Until recently not available in real time systems Now can be done using fragment shaders (see Chapter 9) Now can be done using fragment shaders (see Chapter 9) Both need data structures to represent meshes so we can obtain vertex normals Both need data structures to represent meshes so we can obtain vertex normals

Tugas Besar 4 Buat program OpenGL: Menampilkan 3 digit terakhir NRP anda dalam format 3 dimensi. Menampilkan 3 digit terakhir NRP anda dalam format 3 dimensi. Pertama kali dijalankan, NRP berputar pada sumbu Z. Pertama kali dijalankan, NRP berputar pada sumbu Z. Klik tombol mouse kiri, NRP berputar pada sumbu X Klik tombol mouse kiri, NRP berputar pada sumbu X Klik tombol mouse tengah, NRP berputar pada sumbu Y Klik tombol mouse tengah, NRP berputar pada sumbu Y Klik tombol mouse kanan, NRP berputar pada sumbu Z Klik tombol mouse kanan, NRP berputar pada sumbu Z Tekan tombol x, kamera bergerak 1 poin ke sumbu X negatif Tekan tombol x, kamera bergerak 1 poin ke sumbu X negatif Tekan tombol X, kamera bergerak 1 poin ke sumbu X positif Tekan tombol X, kamera bergerak 1 poin ke sumbu X positif Tekan tombol y, kamera bergerak 1 poin ke sumbu Y negatif Tekan tombol y, kamera bergerak 1 poin ke sumbu Y negatif Tekan tombol Y, kamera bergerak 1 poin ke sumbu Y positif Tekan tombol Y, kamera bergerak 1 poin ke sumbu Y positif Tekan tombol z, kamera bergerak 1 poin ke sumbu Z negatif Tekan tombol z, kamera bergerak 1 poin ke sumbu Z negatif Tekan tombol Z, kamera bergerak 1 poin ke sumbu Z positif Tekan tombol Z, kamera bergerak 1 poin ke sumbu Z positif Ukuran, bentuk, dan warna NRP terserah anda. Asal cukup proporsional untuk dilihat. Ukuran, bentuk, dan warna NRP terserah anda. Asal cukup proporsional untuk dilihat.

Tugas Besar 4

Penilaian Tampil digit NRP dalam format 3D50 Tampil digit NRP dalam format 3D50 NRP berputar pada sumbu Z 5 NRP berputar pada sumbu Z 5 Klik kiri mouse membuat NRP berputar pada sumbu x 5 Klik kiri mouse membuat NRP berputar pada sumbu x 5 Klik tengah mouse membuat NRP berputar pada sumbu y 5 Klik tengah mouse membuat NRP berputar pada sumbu y 5 Klik kanan mouse membuat NRP berputar pada sumbu z 5 Klik kanan mouse membuat NRP berputar pada sumbu z 5 Tombol ‘x’, kamera geser ke sumbu x negatif 5 Tombol ‘x’, kamera geser ke sumbu x negatif 5 Tombol ‘X’, kamera geser ke sumbu x positif 5 Tombol ‘X’, kamera geser ke sumbu x positif 5 Tombol ‘y’, kamera geser ke sumbu y negatif 5 Tombol ‘y’, kamera geser ke sumbu y negatif 5 Tombol ‘Y’, kamera geser ke sumbu y positif 5 Tombol ‘Y’, kamera geser ke sumbu y positif 5 Tombol ‘z’, kamera geser ke sumbu z negatif 5 Tombol ‘z’, kamera geser ke sumbu z negatif 5 Tombol ‘Z’, kamera geser ke sumbu z positif 5 Tombol ‘Z’, kamera geser ke sumbu z positif 5

Rangkuman Penambahan shading memberikan efek mempercantik tampilan Penambahan shading memberikan efek mempercantik tampilan

Contoh Soal Soal: Memori Frame Buffer haruslah cukup cepat untuk dibaca isinya. Hal ini dimaksudkan agar jika Monitor CRT butuh me-refresh tampilan terhindar dari tampilnya kedip/flicker. Jika sebuah monitor memiliki resolusi 1280 x 1024 piksel, di-refresh 72 kali per detik, berapa kecepatan baca memori frame buffer? Dalam bahasa lain, berapa waktu maksimum yang dibutuhkan untuk membaca informasi 1 piksel dari frame buffer?

Referensi Edward Angel, “Interactive Computer Graphics Fourth Edition”, Pearson, 2006, ch 5, p 233 – 284, ch 6, p 285 – 322 Edward Angel, “Interactive Computer Graphics Fourth Edition”, Pearson, 2006, ch 5, p 233 – 284, ch 6, p 285 – 322 F. S. Hill, Jr., “Computer Graphics Using OpenGL Second Edition”, Prentice Hall, 2001, ch 5, p 259 – 276, ch 7, p 358 – 407, ch 8, p 408 – 439 F. S. Hill, Jr., “Computer Graphics Using OpenGL Second Edition”, Prentice Hall, 2001, ch 5, p 259 – 276, ch 7, p 358 – 407, ch 8, p 408 – 439