Bartosz Bazyluk Oświetlenie Zaawansowane techniki oświetlenia, c.d.

Podobne dokumenty
Bartosz Bazyluk Oświetlenie Zaawansowane techniki oświetlenia, c.d. Gry komputerowe, Informatyka N1, III Rok

Bartosz Bazyluk OpenGL Programowalny potok renderowania, buforowanie geometrii (VBO, IBO, VAO).

Grafika Komputerowa Wykład 5. Potok Renderowania Oświetlenie. mgr inż. Michał Chwesiuk 1/38

GRAFIKA CZASU RZECZYWISTEGO Podstawy syntezy grafiki 3D i transformacji geometrycznych

GRK 4. dr Wojciech Palubicki

3 Przygotował: mgr inż. Maciej Lasota

Plan wykładu. Akcelerator 3D Potok graficzny

Julia 4D - raytracing

Zatem standardowe rysowanie prymitywów wygląda następująco:

8 Przygotował: mgr inż. Maciej Lasota

Bartosz Bazyluk DEFINIOWANIE GEOMETRII Sposoby opisu geometrii brył w OpenGL. Grafika Komputerowa, Informatyka, I Rok

RENDERING W CZASIE RZECZYWISTYM. Michał Radziszewski

Oświetlenie obiektów 3D

Grafika realistyczna. Oświetlenie globalne ang. global illumination. Radosław Mantiuk

Oświetlenie. Modelowanie oświetlenia sceny 3D. Algorytmy cieniowania.

Grafika Komputerowa Wykład 4. Synteza grafiki 3D. mgr inż. Michał Chwesiuk 1/30

Grafika Komputerowa Wykład 6. Teksturowanie. mgr inż. Michał Chwesiuk 1/23

Laboratorium grafiki komputerowej i animacji. Ćwiczenie V - Biblioteka OpenGL - oświetlenie sceny

Bartosz Bazyluk SYNTEZA GRAFIKI 3D Grafika realistyczna i czasu rzeczywistego. Pojęcie sceny i kamery. Grafika Komputerowa, Informatyka, I Rok

Model oświetlenia. Radosław Mantiuk. Wydział Informatyki Zachodniopomorski Uniwersytet Technologiczny w Szczecinie

Śledzenie promieni w grafice komputerowej

Zjawisko widzenia obrazów

Animowana grafika 3D. Opracowanie: J. Kęsik.

6 Przygotował: mgr inż. Maciej Lasota

Bartosz Bazyluk POTOK RENDEROWANIA Etapy renderowania w grafice czasu rzeczywistego. Grafika Komputerowa, Informatyka, I Rok

Gry komputerowe, Informatyka N1, III Rok

1. Prymitywy graficzne

Programowanie gier komputerowych Tomasz Martyn Wykład 6. Materiały informacje podstawowe

OpenGL oświetlenie. Bogdan Kreczmer. Katedra Cybernetyki i Robotyki Wydziału Elektroniki Politechnika Wrocławska

Gry komputerowe: efekty specjalne cz. 2

Oświetlenie w OpenGL. Oprogramowanie i wykorzystanie stacji roboczych. Wykład 8. Światło otaczajace. Światło rozproszone.

Synteza i obróbka obrazu. Algorytmy oświetlenia globalnego

Grafika komputerowa. Model oświetlenia. emisja światła przez źródła światła. interakcja światła z powierzchnią. absorbcja światła przez sensor

RENDERING W CZASIE RZECZYWISTYM. Michał Radziszewski

Efekty dodatkowe w rasteryzacji

Wykład 5. Rendering (2) Geometria

Podstawy programowania. Wykład 7 Tablice wielowymiarowe, SOA, AOS, itp. Krzysztof Banaś Podstawy programowania 1

Sphere tracing: integracja z klasycznymi metodami symulacji i renderingu

Modelowanie i wstęp do druku 3D Wykład 1. Robert Banasiak

Algorytmy oświetlenia globalnego

Grafika Komputerowa. Wykład 8. Przygotowanie do egzaminu. mgr inż. Michał Chwesiuk 1/32

Światło. W OpenGL można rozróżnić 3 rodzaje światła

Architektura Procesorów Graficznych

GRK 5. dr Wojciech Palubicki

GRAFIKA CZASU RZECZYWISTEGO Wprowadzenie do OpenGL

Synteza i obróbka obrazu. Tekstury. Opracowanie: dr inż. Grzegorz Szwoch Politechnika Gdańska Katedra Systemów Multimedialnych

OpenGL : Oświetlenie. mgr inż. Michał Chwesiuk mgr inż. Tomasz Sergej inż. Patryk Piotrowski. Szczecin, r 1/23

Grafika 3D OpenGL część II

Światła i rodzaje świateł. Dorota Smorawa

0. OpenGL ma układ współrzędnych taki, że oś y jest skierowana (względem monitora) a) w dół b) w górę c) w lewo d) w prawo e) w kierunku do

Programowanie Procesorów Graficznych

GRAFIKA KOMPUTEROWA 7: Kolory i cieniowanie

Temat: Transformacje 3D

GRK 5. dr Wojciech Palubicki

Ustawienia materiałów i tekstur w programie KD Max. MTPARTNER S.C.

Materiały. Dorota Smorawa

Scena 3D. Cieniowanie (ang. Shading) Scena 3D - Materia" Obliczenie koloru powierzchni (ang. Lighting)

WSTĘP DO GRAFIKI KOMPUTEROWEJ

Podstawy Processingu. Diana Domańska. Uniwersytet Śląski

System graficzny. Potok graficzny 3D. Scena 3D Zbiór trójwymiarowych danych wejściowych wykorzystywanych do wygenerowania obrazu wyjściowego 2D.

Karty graficzne możemy podzielić na:

a. Czym różni się sposób liczenia odbicia zwierciadlanego zaproponowany przez Phonga od zaproponowanego przez Blinna?

Grafika Komputerowa Wykład 1. Wstęp do grafiki komputerowej Obraz rastrowy i wektorowy. mgr inż. Michał Chwesiuk 1/22

RENDERING W CZASIE RZECZYWISTYM. Michał Radziszewski

Zaawansowana Grafika Komputerowa

Animowana grafika 3D. Opracowanie: J. Kęsik.

OpenGL Światło (cieniowanie)

Inventor 2016 co nowego?

Synteza i obróbka obrazu. Modelowanie obiektów 3D

GRAKO: ŚWIATŁO I CIENIE. Modele barw. Trochę fizyki percepcji światła. OŚWIETLENIE: elementy istotne w projektowaniu

Teksturowanie (ang. texture mapping)

GRAFIKA KOMPUTEROWA. Plan wykładu. 1. Początki grafiki komputerowej. 2. Grafika komputerowa a dziedziny pokrewne. 3. Omówienie programu przedmiotu

Wykład 4. Rendering (1) Informacje podstawowe

OpenGL Światło (cieniowanie)

Nowoczesna OpenGL - rendering wielokątów Rendering wielokątów w kontekście biblioteki SFML

Bartosz Bazyluk OpenGL Współczesne podejście do programowania grafiki Część II: Programy cieniujące (shadery)

Ćwiczenie 4 - Podstawy materiałów i tekstur. Renderowanie obrazu i animacji

Gry Komputerowe Laboratorium 4. Teksturowanie Kolizje obiektów z otoczeniem. mgr inż. Michał Chwesiuk 1/29. Szczecin, r

SYMULACJA OPADÓW ATMOSFERYCZNYCH I POKRYWY ŚNIEŻNEJ W GENERATORZE OBRAZU JASKIER IG

Wprowadzenie. Artur Staszczyk Bartłomiej Filipek

Wyświetlanie terenu. Clipmapy geometrii

Autodesk 3D Studio MAX Teksturowanie modeli 3D

PRZEWODNIK PO PRZEDMIOCIE

Instytut Mechaniki i Inżynierii Obliczeniowej Wydział Mechaniczny Technologiczny Politechnika Śląska

Grafika komputerowa i wizualizacja

Systemy uczące się Lab 4

OpenGL przezroczystość

IX. Wskaźniki.(3 godz.)

Lab 9 Podstawy Programowania

Filtrowanie tekstur. Kinga Laurowska

Wprowadzenie do rysowania w 3D. Praca w środowisku 3D

W naukach technicznych większość rozpatrywanych wielkości możemy zapisać w jednej z trzech postaci: skalara, wektora oraz tensora.

Przegląd architektury PlayStation 3

RENDERING W CZASIE RZECZYWISTYM. Michał Radziszewski

1. Czym jest rendering? a. Komputerowa analiza modelu danej sceny i utworzenie na jej podstawie obrazu 2D. b. Funkcja umożliwiająca kopiowanie obrazu

Struktury Danych i Złożoność Obliczeniowa

Dział I FUNKCJE TRYGONOMETRYCZNE

Transformacje. dr Radosław Matusik. radmat

Techniki animacji komputerowej

Oprogramowanie i wykorzystanie stacji roboczych. Wykład 6

Transkrypt:

Oświetlenie Zaawansowane techniki oświetlenia, c.d. http://bazyluk.net/dydaktyka Grafika Komputerowa i Wizualizacja, Informatyka S1, II Rok

Image Based Lighting (IBL) Źródło obrazu: Panocapture.com, Automotive Pack 2

Image Based Lighting (IBL) Źródło obrazu: Panocapture.com, Automotive Pack 3

Image Based Lighting (IBL) Technika oświetlenia wykorzystująca mapę środowiska rzutowaną na powierzchnię oświetlanego obiektu Najczęściej jest to omnikierunkowe zdjęcie, zwykle HDR Pozyskanie mapy środowiska wymaga ultraszerokokątnego obiektywu lub specjalnego rodzaju kamery. Źródła obrazów: Panocapture.com, Automotive Pack Springer, Davide Scaramuzza. 4

Image Based Lighting (IBL) Technika oświetlenia wykorzystująca mapę środowiska rzutowaną na powierzchnię oświetlanego obiektu Najczęściej jest to omnikierunkowe zdjęcie, zwykle HDR Źródło obrazów: http://www.hdrlabs.com/sibl 5

Mapowanie środowiska Technika IBL wywodzi się z mapowania środowiska, które jest techniką rzutowania otoczenia obiektu pod postacią tekstury na jego powierzchnię Mapowanie sferyczne (ang. sphere mapping) Mapowanie sześcienne (ang. cube mapping) Źródło obrazów: Wikipedia http://escience.anu.edu.au/lecture/cg 6

Ambient Occlusion Dla każdego punktu obierana jest półsfera. W jej obrębie wysyłane są promienie. To, ile z nich i w jakiej odległości trafi w inne obiekty, sugeruje ile światła ze środowiska może dotrzeć do tego punktu. Kolejna, tym razem dokładniejsza niż phongowski komponent ambient, aproksymacja oświetlenia niebezpośredniego Estymacja tego, jak bardzo dane miejsce narażone jest na działanie oświetlenia pochodzącego ze środowiska (ang. ambient light) Rezultat może np. wpłynąć na wartość komponentu ambient w modelu Phonga Źródło obrazu: http://ucbugg.github.io/learn.ucbugg 7

Ambient Occlusion Technika ta nie bierze pod uwagę źródeł światła! Uwzględnia jedynie geometrię obiektów sceny i ich względne położenie oraz odległości Jest to technika nastawiona na rednerowanie offline Bazuje na koncepcji próbkowania / śledzenia promieni, jest więc bardzo kosztowna Im mniej próbek, tym większe zaszumienie Źródło obrazów: Nikki Ferchland, http://animationdynamics.com/ https://realtimeillumination.wordpress.com/ 8

Ambient Occlusion Źródło obrazów: Andrew Kramer 9

Ambient Occlusion Screen Space Ambient Occlusion (SSAO) Metody monte carlo pozwalają przyspieszyć działanie algorytmu. Operuje nie na geometrii, ale na zawartości bufora klatki dużo szybsze! Porównuje względne odległości blisko oddalonych od siebie pikseli korzysta z bufora Z Powoduje artefakty polegające na zmiennym oświetleniu obiektów zależnie od miejsca i kierunku, z którego je oglądamy Źródła obrazów: https://realtimeillumination.wordpress.com/ http://media.moddb.com/ 10

Deferred Shading Problem: W jaki sposób efektywnie obliczyć dynamiczne oświetlenie dla dużej liczby świateł i bardzo złożonej geometrii? Źródło obrazu: http://www.learnopengl.com 11

Deferred Shading Metoda odraczająca obliczenie oświetlenia do momentu, gdy będzie gotowa zawartość bufora klatki Dzieli proces renderowania klatki na dwa etapy: Obliczenie na podstawie geometrii sceny wartości, które będą niezbędne dla obliczenia oświetlenia Obliczenie właściwego oświetlenia z pomienięciem geometrii, już w przestrzeni ekranu Screen z UE3, prezentuje technikę Deferred Shading ze 123 dynamicznymi światłami (rok 2011) Źródła obrazów: Anton Lindeström Epic Games, UDK 12

Wynik obliczeń z pierwszego etapu przechowywany jest w tzw. G-Buffer. Zawartość G-Buffer: Deferred Shading Dopiero na podstawie jego zawartości obliczane jest faktyczne oświetlenie. Źródła obrazów: http://www.learnopengl.com 13

Deferred Shading Zalety Deferred Shading: Złożoność obliczeń związanych z oświetleniem jest w dużo mniejszym stopniu zależna od złożoności geometrii sceny Tym samym możliwość wprowadzenia znacznie większej liczby źródeł światła Wady Deferred Shading: Problemy z technikami anti-aliasingu Właściwy kolor pikseli jest obliczany dopiero na samym końcu, w obrazie o docelowej rozdzielczości Większe zapotrzebowanie na pamięć Bufor klatki musi przechować wszystkie wartości wyliczone podczas pierwszego etapu jako tzw. G-Buffer Źródło obrazu: http://gamedev.ru 14

Deferred Lighting Modyfikacją techniki Deferred Shading jest podejście nazywane Deferred Lighting Dodatkowy etap pośredni pracujący na geometrii sceny Obliczenie osobno komponentów diffuse i specular, ostatni etap łączy rezultaty Redukcja ilości pamięci potrzebnej do przechowania wyjścia z pierwszego etapu Źródło obrazu: Azkanan, Leadwerks Software 15

Subsurface Scattering Technika subsurface scattering (SSS) polega na symulowaniu podpowierzchniowego rozpraszania światła Bierze pod uwagę światło, które przeszło (nie zostało odbite) przez częściowo przezroczystą powierzchnię Światło jest rozpraszane w głębi obiektu w wielu kierunkach Promienie światła wychodzą w innych miejscach powierzchni obiektu oraz pod innym kątem niż gdyby zostały odbite przez tę powierzchnię Odbicie powierzchniowe Rozproszenie podpowierzchniowe W rezultacie uwzględniona jest grubość przedmiotu, jak i zmiękczenie ostrych krawędzi cieni Materiały i obiekty takie jak: wosk, marmur, ludzka skóra, liście 16

Subsurface Scattering SSS ON Źródło obrazów: MrBluesummers SSS OFF 17

Subsurface Scattering W rzeczywistym świecie ludzka skóra odbija na powierzchni jedynie 6% światła, pozostałe 94% pochodzi z rozproszenia podpowierzchniowego! [Krishnaswamy, Baronoski 2004] Aby realistycznie renderować skórę, konieczne jest więc uwzględnienie SSS. Źródło obrazu: MrBluesummers 18

Subsurface Scattering Symulowanie SSS Podstawowe równanie renderingu obejmuje jedynie powierzchniowe odbicie światła opisane za pomocą BRDF Prosta metoda czasu rzeczywistego pozwalająca na przybliżenie wyglądu obiektu zbudowanego z np. wosku, polega na wyznaczeniu jego grubości w danym miejscu korzystając z bufora głębokości uzyskanego z punktu widzenia światła Odpowiednikiem BRDF uwzględniającym podpowierzchniowe rozproszenie jest BSSRDF Źródło obrazów: Wikipedia 19

Materiały wielowarstwowe Szczególnym przypadkiem powiązanym z SSS jest renderowanie materiałów wielowarstwowych (ang. layered material) Przykładowe zastosowanie: wizualizacja metalicznego lakieru samochodowego Przykład wyrenderowanego, kilkuwarstwowego materiału imitującego lakier samochodowy. Źródła obrazów: MrBluesummers D M Multimedia 20

Kaustyki Zjawisko polegające na trafianiu wielu odbitych lub załamanych fal światła w pobliżu jednego miejsca nazywamy kaustyką (ang. caustic) Najczęściej mamy do czynienia z takim zjawiskiem np. przy wklęsłych zwierciadłach i powierzchniach przepuszczających światło lub przy falujących powierzchniach płynów Szklanka wody powoduje załamanie fal światła w taki sposób, że powstają kaustyki Źródła obrazów: LuxRender Wikipedia 21

Kaustyki Realistyczne renderowanie polega na śledzeniu załamywanych lub odbijanych promieni światła Szczególnie dobrze widoczne przy technice mapowania fotonów (ang. photon mapping) Metody czasu rzeczywistego polegają m.in. na próbkowaniu powierzchni, operacjach per-fragment i nakładaniu tekstur imitujących obszary skupienia promieni Źródło obrazów: FXGuide.com, Mike Seymour. The State of Rendering - Part 2. 22

Definicja Geometrii Wstęp do syntezy trójwymiarowej grafiki komputerowej http://bazyluk.net/dydaktyka Grafika Komputerowa i Wizualizacja, Informatyka S1, II Rok

Renderowanie geometrii Wierzchołki Przetwarzanie wierzchołków Łączenie w prymitywy Geometria jest opisana przede wszystkim pozycjami wierzchołków Podczas procesu renderowania powierzchnie obiektów rysowane są za pomocą tzw. prymitywów Prymitywy to figury geometryczne odpowiadające za to, jak informacja o kolejnych pozycjach zostanie wykorzystana podczas rysowania Mogą to być np. punkty, linie, łamane, trójkąty, pasy trójkątów, czworokąty, wielokąty, itp. Rasteryzacja prymitywów Operacje na fragmentach Operacje na pikselach Bufor klatki Źródło obrazu: GPU Design 24

Renderowanie geometrii Prymitywy obsługiwane przez OpenGL: Źródło obrazu: http://www.opengl.org 25

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Myślimy o punktach w przestrzeni 3D, nie na płaszczyźnie 26

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu punkty (ang. points) 27

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu linie (ang. lines) 28

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu łamana (ang. line strip) 29

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu łamana zamknięta (ang. line loop) 30

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu trójkąty (ang. triangles) 31

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu wachlarz (ang. triangle fan) 32

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Użycie prymitywu pas trójkątów (ang. triangle strip) 33

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Dwa ostatnie wierzchołki nie są wykorzystane - aby powstał kolejny quad, potrzebne byłyby dwa następne! Użycie prymitywu czworokąty (ang. quads) 34

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Ten czworokąt jest niepoprawny ( zdegenerowany ) nie jest wypukły! Użycie prymitywu pas czworokątów (ang. quad strip) 35

Renderowanie geometrii Przykład: Mamy dane 6 wierzchołków o następujących położeniach: v4 v5 Ten wielokąt jest niepoprawny ( zdegenerowany ) nie jest wypukły! Użycie prymitywu wielokąt (ang. polygon) 36

Face culling Rozpatrzmy przypadek: scena zawiera sześcian Ile jego ścian jest widocznych na danej klatce animacji? Ile ścian jest renderowanych podczas rysowania klatki? W którym momencie potoku pomijane są tylne ściany? 37

Face culling Technika face culling pozwala na pominięcie ścian widocznych z określonej strony jeszcze przed rozpoczęciem ich rasteryzacji O odrzuceniu decyduje kolejność wierzchołków po ich projekcji (ang. winding order) Zgodnie z ruchem wskazówek zegara (ang. clockwise) Przeciwnie do wskazówek zegara (ang. counter-clockwise) Konieczne jest więc ustalenie w jakiej kolejności definiowane są wierzchołki ścian gdy patrzymy na ich przednią stronę, a potem konsekwentne trzymanie się ustalonej kolejności podczas opisywania geometrii obiektów. CCW 38

Face culling Jeśli po przejściu do współrzędnych kamery kolejność wierzchołków zgadza się z tą uznaną za przednią, to znaczy że widzimy przednią stronę ściany i należy ją poddać rasteryzacji Jeśli kolejność jest odwrotna, to widzimy tylną stronę ściany i możemy ją pominąć (jeśli używamy techniki back face culling) Źródło obrazu: http://www.learningopengl.com 39

Face culling Jak karta graficzna porównuje kolejność wierzchołków? Czy kąt pomędzy wektorem normalnym ściany, a wektorem obserwacji jest mniejszy lub równy 90 stopni? Wektor normalny obliczamy za pomocą iloczynu wektorowego trzech kolejnych wierzchołków w kolejności ich zdefiniowania Równoważne pytanie: Czy iloczyn skalarny między tymi wektorami jest większy lub równy zero? Jeśli tak, to kolejność jest różna od początkowej ścianę należy pominąć! N=(v 1 v 0 ) ( v 2 v 0 ) V 0 N 0 N V0 - - 40

Face culling Kiedy back face culling jest problematyczny? Gdy na scenie są przezroczyste obiekty Gdy występują obiekty o zerowej grubości, w których obie strony ścian są widoczne Do czego dodatkowo może służyć back face culling? Wówczas pomijanie tylnych ścian może być widoczne Usuwanie "niewidocznych" linii w renderowaniu wireframe, pod warunkiem że geometria jest wypukła Do czego mógłby służyć front face culling? Ukrywanie przednich ścian może być przydatne podczas renderowania mapy cieni, by uniknąć efektu self-shadowing gdy sprawdzane jest przysłonięcie sceny z punktu widzenia źródła światła 41

Face culling Jak korzystać z face cullingu w OpenGL? Włączanie: glenable(gl_cull_face); Wybór kolejności definicji przednich ścian: glfrontface(gl_ccw); // przeciwnie do ruchu wskazówek zegara glfrontface(gl_cw); // zgodnie z ruchem wskazówek zegara dotyczy wierzchołków definiowanych po wywołaniu tej funkcji Wybór ścian, które mają być pomijane: glcullface(gl_back); glcullface(gl_front); glcullface(gl_front_and_back); 42

Definicja geometrii w OpenGL Najprostszą metodą definicji i renderowania geometrii jest tzw. immediate mode Definicja własności wszystkich wierzchołków w każdej klatce Podejście którego współcześnie się już nie stosuje Jest nieefektywne W każdej klatce duża ilość danych przekazywana do karty graficznej Współcześnie używa się buforów w pamięci karty graficznej Jest najłatwiejsze w zrozumieniu Prymityw glbegin(gl_quads); glvertex3f(-1.0f, -1.0f, 0.0f); glvertex3f(1.0f, -1.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(-1.0f, 1.0f, 0.0f); glend(); 43

Kolor w OpenGL Częścią stanu OpenGL jest także kolor wierzchołków Kolory określa się za pomocą komponentów RGB(A) Wartości są znormalizowane (0.0-1.0) Czwarty kanał A może określać przezroczystość Przykłady: (1.0, 0.0, 0.0) (0.0, 1.0, 0.0) (0.0, 0.0, 1.0) (0.0, 0.0, 0.0) (1.0, 1.0, 1.0) (0.5, 0.5, 0.5) (1.0, 0.5, 0.5) (0.0, 0.6, 1.0) Używa się do tego celu funkcji: glcolor3f(float r, float g, float b) lub analogicznych (4f, 3fv, 4fv,...) 44

Kolor w OpenGL Przykłady: glcolor3f(1.0f, 0.0f, 0.0f); glbegin(gl_quads); glvertex3f(-1.0f, -1.0f, 0.0f); glvertex3f(1.0f, -1.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(-1.0f, 1.0f, 0.0f); glend(); glbegin(gl_quads); glcolor3f(0.0f, 0.0f, 0.0f); glvertex3f(-1.0f, -1.0f, 0.0f); glcolor3f(1.0f, 0.0f, 0.0f); glvertex3f(1.0f, -1.0f, 0.0f); glcolor3f(0.0f, 1.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glcolor3f(0.0f, 0.0f, 1.0f); glvertex3f(-1.0f, 1.0f, 0.0f); glend(); 45

DEFINICJA GEOMETRII Przykłady będą dotyczyły prostego sześcianu: y Przykładowe dane v4 v7 x v5 v6 z Dla uproszczenia na razie pomijamy wszystko poza pozycjami wierzchołków 46

DEFINICJA GEOMETRII Pozycje wierzchołków: y Przykładowe dane v4 = (0,1,0) = (0,1,1) v7 = (1,1,0) = (1,1,1) x v5 = (0,0,0) = (0,0,1) v6 = (1,0,0) = (1,0,1) z 47

DEFINICJA GEOMETRII Kolejność definicji ścian naszego sześcianu: Zakładamy użycie prymitywu GL_QUADS Przykładowe dane v4 y v7 x z v5 v6 Oczywiście możliwe będzie zyskanie na wydajności np. używając GL_QUAD_STRIP, ale chcemy prosty przypadek GL_QUADS nie jest dostępny we współczesnych wersjach OpenGL, ale pozwala łatwiej zobrazować zagadnienie 48

DEFINICJA GEOMETRII Kolejność definicji wierzchołków: Przykładowe dane -> -> -> -> -> v6 -> v7 v7 -> v6 -> v5 -> v4 v4 -> v5 -> -> -> -> v7 -> v4 -> v5 -> v6 -> Czyli: 24 zestawy po 3 współrzędne po 4 bajty v4 y Pamiętamy o backface cullingu v7 24 3 4 = 288 bajtów zakładamy że front-face'y definiowane są przeciwnie do ruchu wskazówek zegara (CCW) x z v5 v6 49

IMMEDIATE MODE Ogólna charakterystyka Najprostsze podejście polegające na bezpośredniej definicji geometrii Wartości (np. współrzędne wierzchołków) dla każdorazowego żądania renderowania, przekazywane są do serwera od nowa v4 Oznacza to ogromną ilość danych przesyłaną co klatkę od klienta do serwera Oznacza to ogromną liczbę wywołań funkcji OpenGL y v7 x z v5 v6 50

IMMEDIATE MODE Sposób użycia Otwarcie bloku definicji geometrii Definicja geometrii v4 Wierzchołki, wektory normalne, współrzędne tekstur... Zamknięcie bloku y Wskazanie pożądanego prymitywu Zlecenie renderowania, ewentualne buforowanie Przykład dla pierwszego quada: v7 glbegin(gl_quads); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(1.0f, 0.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glend(); x z v5 v6 51

IMMEDIATE MODE Przykład użycia Dla całego sześcianu: glbegin(gl_quads); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(1.0f, 0.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 0.0f, 1.0f); glvertex3f(1.0f, 0.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(1.0f, 0.0f, 0.0f); glvertex3f(0.0f, 0.0f, 0.0f); glvertex3f(0.0f, 1.0f, 0.0f); v4 v7 z Nie zmieniają się po co? Powtarzające się wierzchołki wysyłane są kilkukrotnie Już zostały przesłane po co? glvertex3f(0.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 0.0f); x glvertex3f(0.0f, 1.0f, 0.0f); glvertex3f(0.0f, 0.0f, 0.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(0.0f, 1.0f, 1.0f); y W każdej klatce wysyłamy do serwera pozycje wszystkich wierzchołków v5 v6 glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(0.0f, 0.0f, 0.0f); glvertex3f(1.0f, 0.0f, 0.0f); glvertex3f(1.0f, 0.0f, 1.0f); glend(); 52

DISPLAY LIST Ogólna charakterystyka Skompilowana sekwencja instrukcji zmieniających stan serwera Przechowywana w pamięci karty graficznej Raz utworzona nie może być modyfikowana v4 y v7 Nie nadaje się do animacji bryły Sterownik odpowiada za to, by lista została wykonana efektywnie Każda lista ma przypisany identyfikator, który służy jej późniejszemu wywołaniu (żądaniu renderowania) x z v5 v6 53

DISPLAY LIST Sposób użycia Utworzenie display listy Kompilacja display listy Wierzchołki, wektory normalne, współrzędne tekstur... Można dołączyć inne zmiany stanu serwera Wywołanie display listy v4 y Żądanie identyfikatora Żądanie renderowania z użyciem identyfikatora Przykład dla pierwszego quada: v7 GLuint id = glgenlists(1); glnewlist(id, GL_COMPILE); glbegin(gl_quads); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(1.0f, 0.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glend(); glendlist(); // Renderowanie: glcalllist(id); x z v5 v6 54

DISPLAY LIST Przykład użycia v4 y v7 x z v5 v6 Dla całego sześcianu: GLuint id = glgenlists(1); glnewlist(id, GL_COMPILE); glbegin(gl_quads); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(1.0f, 0.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 0.0f, 1.0f); glvertex3f(1.0f, 0.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(1.0f, 0.0f, 0.0f); glvertex3f(0.0f, 0.0f, 0.0f); glvertex3f(0.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 0.0f); glvertex3f(0.0f, 0.0f, 0.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(0.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 1.0f); glvertex3f(1.0f, 1.0f, 0.0f); glvertex3f(0.0f, 1.0f, 0.0f); glvertex3f(0.0f, 0.0f, 1.0f); glvertex3f(0.0f, 0.0f, 0.0f); glvertex3f(1.0f, 0.0f, 0.0f); glvertex3f(1.0f, 0.0f, 1.0f); glend(); glendlist(); // Pozycje wszystkich wierzchołków wysyłamy tylko raz Podczas renderowania kolejnych klatek korzystamy z danych znajdujących się w pamięci graficznej Możliwości list wykraczają poza zwykłą definicję geometrii Znacząco zyskuje na tym wydajność Możliwość użycia innych instrukcji zmieniających stan Nie ma możliwości modyfikacji listy po jej skompilowaniu // Dla każdej klatki: glcalllist(id); 55

VERTEX ARRAY Ogólna charakterystyka Ciągła tablica po stronie klienta (w pamięci głównej) zawierająca dane wierzchołków Możliwość dowolnej manipulacji zawartości Możliwość wybiórczego renderowania v4 y v7 Rozwiązuje problem redefinicji powtarzających się wierzchołków, co daje oszczędność pamięci Interleaved arrays, czyli łączone tablice dla różnych danych per-vertex Np. pozycja, wektor normalny, kolor, współrzędne tekstury... Wszystko w jednej tablicy (co ma i zalety, i wady) x z v5 v6 56

VERTEX ARRAY Sposób użycia Utworzenie tablicy z wartościami Wskazanie serwerowi miejsca w pamięci, gdzie znajdują się dane Przekazanie adresu tablicy Żądanie renderowania v4 Zwyczajna tablica po stronie klienta Można określić, które z danych i w jakiej kolejności nas interesują y v7 x z v5 v6 57

VERTEX ARRAY Przykład dla pierwszego quada: Sposób użycia (c.d.) GLfloat buffer[] = { 0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, 1.0f }; // Renderowanie: glenableclientstate(gl_vertex_array); glvertexpointer(3, GL_FLOAT, 0, buffer); v4 y gldrawarrays(gl_quads, 0, 4); v7 gldisableclientstate(gl_vertex_array); x z v5 v6 Aby wskazać gdzie przechowywane są wartości innych atrybutów, można posłużyć się funkcjami: glnormalpointer(), gltexcoordpointer(), glvertexattribpointer(),... 58

VERTEX ARRAY Wybiórcze renderowanie Wybiórcze renderowanie można zrealizować na kilka różnych sposobów: Podzakres tablicy od-do: v4 y v7 x z v5 v6 gldrawarrays(primitive, from, to) Wskazanie indeksów wierzchołków: gldrawelements(primitive, num_indices, index_type, indices) Dzięki temu nie musimy redefiniować wierzchołków! Przykład cały sześcian: GLfloat buffer[] = { 0.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, 1.0f, 1.0f, 1.0f, 1.0f, 0.0f, 1.0f, 0.0f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f }; GLubyte indices[] = { 0, 1, 2, 3, 3, 2, 6, 7, 7, 6, 5, 4, 4, 5, 1, 0, 0, 3, 7, 4, 1, 5, 6, 2 }; // Renderowanie: glenableclientstate(gl_vertex_array); glvertexpointer(3, GL_FLOAT, 0, buffer); gldrawelements(gl_quads, 24, GL_UNSIGNED_BYTE, indices); gldisableclientstate(gl_vertex_array); 59

VERTEX ARRAY Wybiórcze renderowanie v4 Wybiórcze renderowanie można zrealizować na kilka różnych sposobów (c.d.): v7 gldrawrangeelements(primitive, start, end, num_indices, index_type, indices) start i end określają zakres wartości elementów z tablicy indeksów (nie zakres tablicy, który zostanie użyty!) Służy to do małej optymalizacji OpenGL będzie wiedział, jakiego zakresu indeksów się spodziewać bez konieczności iterowania po tablicy indeksów. W ten sposób może lepiej zaplanować odczyt z VA. Co cechuje Vertex Arrays? x z y Wskazanie indeksów wierzchołków oraz ich zakresu: v5 v6 Możliwość dowolnej kontroli wartości w trakcie renderowania Przydatne przy animacji bryły Konieczność przesłania tablicy do pamięci karty graficznej Dużo mniej odwołań do funkcji OpenGL 60

WYBIÓRCZE RENDEROWANIE Przykład zastosowania Inny przykład praktycznego wykorzystania selektywnego renderowania geometrii z użyciem indeksów wierzchołków: v4 Level of detail (LOD) dla map wysokości y v7 x z v5 v6 Źródło obrazu: http://windows-tech.info 61

VERTEX ARRAY Dodatkowe atrybuty Przekazywanie wartości dodatkowych atrybutów wierzchołków v4 y v7 Nie tylko pozycja (współrzędne) jest wartością per-vertex Wektory normalne, współrzędne tekstur, wektory styczne, kolor, stopień zniszczenia, wiek, stopień deformacji, zabrudzenie, następna pozycja,... Możemy definiować własne atrybuty, które wykorzystamy w naszych shaderach Są dwa podejścia rozwiązania tej kwestii: Oddzielne tablice dla każdego z atrybutów Jedna tablica zawierająca przeplatające się wartości atrybutów (tzw. interleaved arrays) x z v5 v6 62

INTERLEAVED ARRAYS Interleaved arrays przykład: Sposób działania Współrzędne pozycji (p) Wektor normalny (n) Współrzędne 2D tekstury (t)... v4 y v7 x z v5 v6 Parametry każdego atrybutu: offset odległość w bajtach od początku wierzchołka stride odległość w bajtach pomiędzy wierzchołkami Zakładając, że szerokość każdej wartości to 4B, mamy: offset(p) = 0, stride(p) = 32 offset(n) = 12, stride(n) = 32 offset(t) = 24, stride(t) = 32 63

INTERLEAVED ARRAYS Sposób użycia Reprezentacja interleaved array w pamięci głównej z punktu widzenia programu v4 v7 SVertex buffer[]; x z C++ gwarantuje, że struktura zajmuje ciągły obszar pamięci, a składowe mają zachowaną kolejność typedef struct { GLfloat pos[3]; GLfloat normal[3]; GLfloat tex[2]; } SVertex; y Wygodnym podejściem jest użycie struktur v5 glvertexpointer(3, GL_FLOAT, sizeof(svertex), buffer); glnormalpointer(gl_float, sizeof(svertex), buffer + 3 * sizeof(glfloat)); gltexcoordpointer(2, GL_FLOAT, sizeof(svertex), buffer + 6 * sizeof(glfloat)); v6 Zamiast arytmetyki wskaźników (mogącej doprowadzić do problemów), warto wykorzystać po prostu: &buffer[0].pos, &buffer[0].normal, &buffer[0].tex 64

INTERLEAVED ARRAYS Interleaved arrays dodatkowe informacje: Dodatkowe informacje Jeśli np. planujemy często zmieniać pozycję wierzchołków, pozostawiając pozostałe atrybuty bez zmian, warto użyć oddzielnych tablic Warto dążyć do tego, by stride był równy wielokrotności 32. Wiele kart graficznych potrafi wtedy lepiej organizować odczyt z pamięci v4 y v7 x z v5 Nawet kosztem zwiększonego zużycia pamięci, wprowadzając padding! Możemy określić stride jako 0, jeśli nasze dane są ciasno upakowane (żadnego paddingu) i tablice zawierają wartości tylko pojedynczych atrybutów Jeśli nasz układ danych jest standardowy, można użyć funkcji glinterleavedarrays() w celu wyboru tego układu (oszczędza liczbę wywołań funkcji OpenGL) v6 65

VBO Ogólna charakterystyka v4 y Vertex Buffer Object (VBO) technika pozwalająca na łatwe manipulowanie zawartością pamięci karty graficznej Siostrzana technika do Frame Buffer Object (FBO) i Pixel Buffer Object (PBO) Pozwala zarezerwować, wypełnić, odczytać, modyfikować zawartość bufora Po stronie klienta przechowywany jest jedynie identyfikator bufora v7 Klient x z v5 Serwer id v6 VBO (dane) 66

VBO Sposób użycia Wygenerowanie nowego bufora Bindowanie bufora Wybór bufora, który ma stać się aktywny Określenie rodzaju bufora (GL_ARRAY_BUFFER) Alokacja bufora v4 y v7 Określenie charakteru danych: czy będą często modyfikowane, czy też nie... v5 v6 Wpływa na optymalny przydział pamięci Wskazanie miejsc w pamięci x z Przekazanie danych do pamięci karty graficznej Otrzymujemy id bufora Nie przekazujemy wskaźników (bo ich nie mamy), tylko określamy liczbowo offset i stride dla VBO Żądanie renderowania Można określić, które z danych i w jakiej kolejności nas interesują 67

VBO Przykład użycia Przykład dla pierwszego quada: GLfloat buffer[] = {0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, 1.0f}; GLuint vbo; glgenbuffers(1, &vbo); glbindbuffer(gl_array_buffer, vbo); glbufferdata(gl_array_buffer, sizeof(buffer), buffer, GL_STATIC_DRAW); delete[] buffer; // Oczywiście jest to błędne użycie (alokacja podczas kompilacji) glbindbuffer(gl_array_buffer, 0); v4 // Renderowanie: glbindbuffer(gl_array_buffer, vbo); y v7 glenableclientstate(gl_vertex_array); glvertexpointer(3, GL_FLOAT, 0, 0); gldrawarrays(gl_quads, 0, 4); x z v5 v6 gldisableclientstate(gl_vertex_array); glbindbuffer(gl_array_buffer, 0); // Sprzątanie: gldeletebuffers(1, &vbo); 68

VBO Modyfikacja zawartości Istnieje możliwość modyfikacji zawartości VBO: Ponowna alokacja pamięci i wysłanie danych v4 y v7 z Poprzez zastąpienie części danych glbuffersubdata(target, offset, size, data) Pamięć nie jest realokowana! Warto użyć nawet, jeśli zamieniamy całą zawartość bufora. Poprzez mapowanie pamięci glmapbuffer(target, access) glunmapbuffer(target) Otrzymujemy wskaźnik do pamięci, możemy dowolnie ją czytać i zmieniać Kosztowna synchronizacja z GPU x v5 v6 glbufferdata(target, size, data, usage) Warto zastanowić się nad wydajnością i synchronizacją Wykorzystanie techniki podwójnego buforowania (dwa VBO, które zamieniamy miejscami rysujemy z jednego, drugi uaktualniamy) może rozwiązać problem synchronizacji 69

IBO Indeksowanie VBO Wybiórcze renderowanie z VBO jest jeszcze lepsze v4 Mamy możliwość stworzenia bufora indeksów: Index Buffer Object (IBO) IBO działa analogicznie do VBO: Musimy go stworzyć, wybrać, zaalokować, wypełnić, zwolnić GL_ELEMENT_ARRAY_BUFFER IBO jest przechowywany w pamięci karty graficznej odczyt podczas renderowania nie wymaga przesyłania danych z pamięci głównej! y v7 x z v5 v6 70

IBO Przykład użycia Przykład cały sześcian: GLfloat buffer[] = { 0.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f, 1.0f, 1.0f, 1.0f, 1.0f, 0.0f, 1.0f, 0.0f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, 1.0f, 1.0f, 0.0f }; GLubyte indices[] = { 0, 1, 2, 3, 3, 2, 6, 7, 7, 6, 5, 4, 4, 5, 1, 0, 0, 3, 7, 4, 1, 5, 6, 2 }; GLuint vbo, ibo; glgenbuffers(1, &vbo); glbindbuffer(gl_array_buffer, vbo); glbufferdata(gl_array_buffer, sizeof(buffer), buffer, GL_STATIC_DRAW); delete[] buffer; v4 y glgenbuffers(1, &ibo); glbindbuffer(gl_element_array_buffer, ibo); glbufferdata(gl_element_array_buffer, sizeof(indices), indices, GL_STATIC_DRAW); delete[] indices; v7 x z v5 v6 // Renderowanie: glenableclientstate(gl_vertex_array); glvertexpointer(3, GL_FLOAT, 0, buffer); gldrawelements(gl_quads, 24, GL_UNSIGNED_BYTE, 0); gldisableclientstate(gl_vertex_array); // Sprzątanie: glbindbuffer(gl_array_buffer, 0); glbindbuffer(gl_element_array_buffer, 0); gldeletebuffers(1, &vbo); gldeletebuffers(1, &ibo); 71

Definicja Geometrii Wstęp do syntezy trójwymiarowej grafiki komputerowej http://bazyluk.net/dydaktyka Grafika Komputerowa i Wizualizacja, Informatyka S1, II Rok