Ombre e riflessioni in tempo reale Daniele Marini Parzialmente tratte de: Haines-M ö ller Corso di Programmazione Grafica aa2006/2007.

Slides:



Advertisements
Presentazioni simili
La gioia di…. essere AIMC Aimc Sicilia 2007.
Advertisements

LItalia nel quadro economico internazionale Fedele De Novellis Firenze, 26 novembre
Ombre e riflessioni in tempo reale
BUMP MAPPING dott.ing.jun Alex Zupan –
09 corso tecniche di rappresentazione dello spazio A.A. 2009/2010 docente Arch. Emilio Di Gristina.
Rendering È quel processo di creazione di un’immagine bidimensionale a partire da un modello tridimensionale Tale immagine deve tendere a rappresentare.
Via Garibaldi Torino - Tel. 011/ Fax 011/ mail: - Convegno del Il progetto Comunicazione Unica.
Corso di Informatica grafica 1 Introduzione Quando si rappresentano modelli di oggetti 3D costituiti da facce poligonali secondo delle proiezioni alcune.
MODELLI LUCE.
Sistemi Multimediali II Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 Lezione.
Computer Graphics Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2006/07 Lezione.
Computer Graphics Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2006/07 Lezione.
Computer Graphics Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 Lezione.
M.Desimoni, F.Formica, L.Bondi
La barca, le vele gli strumenti
Applicazioni progettuali di grafica computerizzata a.a. 2008/2009 Rendering grafico.
Stencil Shadows Daniele Banovaz30 maggio 2006 Elementi di Grafica Digitale, A.A
Corso di Elementi di Grafica Digitale Massimo De March
1 Modelli di Illuminazione Daniele Marini. 2 Obiettivo Visualizzare scene cercando di simulare al meglio la realtà Interazione luce-materiali –Modellare.
Modelli Globali Daniele Marini.
1 Superfici nascoste Daniele Marini. 2 Ray casting adatto a CSG o superfici parametriche dipende dal punto di vista è una sorta di campionamento spaziale.
Smoothing Daniele Marini.
1 Effetti impressionistici Daniele Marini. 2 Tecniche discrete di manipolazione del frame buffer: –Texture mapping –Antialiasing –Compositing –Alpha blending.
1 Modelli Globali Radiosity Daniele Marini. 2 Radiosity Bilancio radiativo in un ambiente chiuso (senza scambio di energia con lesterno) Indipendente.
A cura di L.Pagani - novembre FACOLTA DI SCIENZE MFN FOCUS SULLA RIFORMA: I REQUISITI DM 31/10/07 n. 544.
Infomatica Grafica a.a DICGIM – University of Palermo Dipartimento di Ingegneria Chimica, Gestionale, Informatica e Meccanica Environment Mapping.
11 ottobre 2012 Modelli a poligoni Roberto Pirrone.
Reggio Emilia 5 maggio L audioprotesista e le indicazioni mediche discutibili.
Determinazione delle superfici visibili
Sistemi Multimediali II Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 Lezione.
Illuminamento e Shading
Scuola Secondaria di 1° grado Mario Zippilli via De Vincentiis, 2 TERAMO Anno scolastico 2009/2010 Programma Nazionale Scuole Aperte AREA TEMATICA Potenziamento.
Studente: Banovaz Diego Trieste, 15/12/2008AA: 2008/2009.
Modelli di riflessione della luce
Effetti fotorealistici
Modelli Globali: Ray Tracing
Davide Gadia Davide Selmo
Modelli Globali e metodo di Radiosity
Daniele Marini, Maurizio Rossi
Texturing - Tessiture Daniele Marini.
Daniele Marini Con contributi di Maurizio Rossi
Le ombre proiettate Daniele Marini.
Dal modello alla visualizzazione: Verso il foto realismo Daniele Marini.
Architettura di OGL e pipe-line Daniele Marini Corso Di Programmazione Grafica.
lavoro di scienze sulla luce
ISTITUTO MOLINARI INDUSTRIE DE NORA OHIO, USA
Superfici nascoste Daniele Marini.
Modelli Globali: il metodo di Radiosity
1 Struttura di un sistema grafico e frame buffer Daniele Marini.
La luce E’ una particolare forma di energia detta
Modelli di Illuminazione
1 Ottimizzazione della scena: culling (decimazione) Daniele Marini.
Intersezioni e distanze
Corso di Programmazione Grafica e Laboratorio Daniele Marini
Corso di Programmazione Grafica e Laboratorio Introduzione a OpenGL Prof. Daniele Marini.
Architettura di OGL e pipe-line Daniele Marini Corso Di Programmazione Grafica.
Corso Di Programmazione Grafica aa2006/2007
Architettura di OGL e pipe-line Daniele Marini Davide Gadia Davide Selmo Corso Di Programmazione Grafica aa2005/2006.
Ombre e riflessioni in tempo reale Daniele Marini Parzialmente tratte de: Haines-M ö ller Corso di Programmazione Grafica aa2005/2006.
Modelli di Illuminazione Modelli locali
Ottimizzazione della scena: culling (decimazione) Daniele Marini.
Ottimizzazione della scena: culling (decimazione) Daniele Marini Corso di Programmazione Grafica per il Tempo Reale.
LA SODDISFAZIONE DEGLI UTENTI DEI SERVIZI CATASTALI Sintesi dei risultati dell’indagine del 2007 Roma, ottobre 2007.
L’insegnamento della fisica e delle scienze nella scuola; proposte operative per un approccio laboratoriale low-cost no cost Raggi, Fasci di Luce ed Ombre.
Circonferenza e cerchio
LA SODDISFAZIONE DEGLI UTENTI DI SISTER Sintesi dei risultati dell’indagine del 2007 per l’Agenzia Roma, ottobre 2007.
La propagazione della luce
Policlinico Universitario Agostino Gemelli ©2007
Progetto Lauree Scientifiche-Matematica in Sicilia Seminario Regionale Progetto Lauree Scientifiche Palermo, 4 Giugno 2007.
1 Smoothing Daniele Marini. 2 Calcoli sui vettori Vettore normale equazione del piano: ax+by+cz+d=0; si può anche scrivere come luogo: e p è un qualunque.
Transcript della presentazione:

Ombre e riflessioni in tempo reale Daniele Marini Parzialmente tratte de: Haines-M ö ller Corso di Programmazione Grafica aa2006/2007

Programmazione Grafica aa2006/20072 Perchè Dare maggiore realismo Creare ”un’atmosfera” Neverwinter Nights Blade of Darkness

Programmazione Grafica aa2006/20073 Cosa si ottiene Più indizi per comprendere la profondità e la forma Più facile l’orientamento

Programmazione Grafica aa2006/20074 Ricevitore Sorgenti di luce Creatori d’ombra, ricevitori d’ombra Sorgente Creatore Creatore e ricevitore Definizioni

Programmazione Grafica aa2006/20075 Tipi di sorgenti Point light ombra area light ombrapenombra Tipologie

Programmazione Grafica aa2006/20076 Ombre nette, ombre sfumate (penombre)

Programmazione Grafica aa2006/20077 Come considerare le ombre Come oggetti separati (l’ombra di Peter Pan) Come volumi di spazio buio Come posizioni da cui la luce di una sorgente non è visibile Notare che sono in ombra facce rivolte in senso opposto alla sorgente

Programmazione Grafica aa2006/20078 Ombre piane Un oggetto proietta un’ombra su una superficie piana Il meccanismo è simile a una proiezione prospettica: si tratta di individuare la matrice di proiezione

Programmazione Grafica aa2006/20079 Proiezione dell’ombra l v ombra y=0 y p Matrice di proiezione:

Programmazione Grafica aa2006/ Proiezione su un piano qualsiasi v p n l Equazione del piano: Equazione del punto proiettato Matrice di proiezione

Programmazione Grafica aa2006/ Memorizzare ombre pre- computate in texture

Programmazione Grafica aa2006/ Due algoritmi principali per geometrie qualsiasi Shadow mapping e shadow volumes –Considera un volume buio, è il più diffuso e implementato hardware Lavora in tempo reale… Shadow mapping è usato dal software rendering della Pixar Calcola il rendering a partire dalla sorgente (il bianco indica punti più lontani, il nero più vicini)

Programmazione Grafica aa2006/ Shadow Map Quando si calcola il rendering, controlla il punto osservato rispetto allo shadow buffer – Se la profondità del punto è maggiore (epsilon) del valore di shadow buffer l’oggetto è in ombra. shadow depth map Per ogni pixel compara distanza da luce di con Profondità di memorizzata In shadow map

Programmazione Grafica aa2006/ Risultato

Programmazione Grafica aa2006/ Shadow volumes Crea porzioni di volume in ombra da ciasun poligono illuminato (triangolo) Ciascun traingolo crea 3 quadrilateri semi- infiniti proiettati Quelli rivolti verso l’ossrvatore sono frontfacing, gli altri backfacing

Programmazione Grafica aa2006/ Come funziona Per testare un punto incrementa un contatore ogni volta che attraversi un lato frontafcing della piramide ombra e decrementa quando atraversi un backfacing Se il contatore è maggiore di zero allora il pixel è in ombra frontfacing backfacing

Programmazione Grafica aa2006/ Shadow volume usa stencil buffer È un altro buffer di OGL in genere 8 bit per pixel Quando si calcola rendering con stencil buffer si possono eseguire somme, sottrazioni etc. L’immagine ottenuta si può usare come maschera per le fasi successive di rendering Stencil Buffer Mask result Rendered image

Programmazione Grafica aa2006/ Come si implementa shadow volumes con stencil buffer 4 passi [Heidmann91]: – 1st Passo: rendi la scena con solo la luce ambiente – Inibisci l’aggiornamento dello Z-buffer e la scrittura nel color buffer (disegna solo nello stencil). – 2nd pass: rendi nello stencil buffer i poligoni frontfacing rispetto allo shadow volume, incrementa il contatore. – 3rd pass: rendi nello stencil buffer i poligoni backfacing rispetto allo shadow volume, decrementa il contatore. – 4th pass: rendi le luci diffusive e speculari con lo stencil buffer a 0.

Programmazione Grafica aa2006/ Esempio Image courtesy of NVIDIA Inc.

Programmazione Grafica aa2006/ Unire più volumi ombra Uno spigolo condiviso da due poligoni che ostacolano la luce crea quadrilateri che sono simultaneamente front e backfacing Questo spigolo interno genera 2 quadrilateri che si annullano

Programmazione Grafica aa2006/ Cercare gli spigoli di bordo (silhouette) Dalla sorgente le ombre proiettate da spigoli interni non contribuiscono allo shadow volume. Trovare gli spigoli della silhouette elimina molti quadrilateri di shadow volume inutili.

Programmazione Grafica aa2006/ Riflessioni piane Le riflessioni si possono simulare con environment mapping Non è adatto per superfici piane Anche la riflessione piana (specchio piano) aiuta a capire la scena e le forme, accresce il realismo Basato sulla legge della riflessione speculare: –L’angolo di incidenza è uguale all’angolo di riflessione

Programmazione Grafica aa2006/ Riflessioni piane Poniamo il piano in z=0 Applichiamo la trasformazione glScalef(1,1,-1); Il risultato: z

Programmazione Grafica aa2006/ Riflessioni piane Nel calcolo delle ombre il backfacing diventa frontfacing! Anche le luci devoono venire riflesse È necessario applicare il clipping (si usa lo stencil buffer) Esempio di clipping:

Programmazione Grafica aa2006/ Planar reflections Come funziona il rendering? 1) metti nello stencil buffer i poligoni del piano di base 2) calcola il modello scalato con (1,1,-1), ma mascheralo con lo stencil buffer 3) rendi il piano di base (semi-trasparente) 4) rendi il modello non trasformato con la scala

Programmazione Grafica aa2006/ Esempio Invece del trucco della trasformazione di scala si puà riflettere la posizione di camera e la direzione del piano Quindi rendere l’immagine riflessa da quella camera