22 Nov 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 22 Texturing

Slides:



Advertisements
Presentazioni simili
1 La Standard Template Library vettori, liste, mappe, …. find, replace, reverse, sort, …. puntatori intelligenti La libreria standard STL e una libreria.
Advertisements

Ombre e riflessioni in tempo reale
BUMP MAPPING dott.ing.jun Alex Zupan –
Texture.
Texture Mapping.
Costruzione di Interfacce Lezione 11 Dal Java al C++ parte 2
11 Dicembre 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 27 Xml for dummies Parte 2
Costruzione di Interfacce Lezione 6 Esercitazione Trasformazioni
Sistemi Multimediali II Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 prove.
Costruzione di Interfacce Lezione 4 Sistemi di riferimento e trasformazioni
25 Nov 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 22 Estensioni Opengl, Multitexturing,
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 2005/06 prove generali.
Costruzione di Interfacce Lezione 13 Clipping e HSR
Costruzione di Interfacce Lezione 5 Trasformazioni Affini
Computer Graphics Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2006/07 Lezione.
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 27 Estensioni Opengl, Multitexturing,
Costruzione di Interfacce Lezione 10 Dal Java al C++ parte 1
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 26 XML read e write / Gl Selection e picking
Costruzione di Interfacce Lezione 7 Shading
Costruzione di Interfacce Lezione 4 Nozioni di geometria per la grafica
Costruzione di Interfacce Lezione 4 Geometria per la grafica
Sistemi Multimediali II Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 Lezione.
Costruzione di Interfacce Lezione 19 Qt Tutorial Designer
Costruzione di Interfacce Lezione 5 Trasformazioni Affini
Costruzione di Interfacce Lezione 20 Qt + Opengl
Computer Graphics Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2006/07 Lezione.
Sistemi Multimediali II Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 Lezione.
Costruzione di Interfacce Lezione 12 C++STL
Sistemi Multimediali II Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2004/05 Lezione.
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 24 Scene Graphs e Xml for dummies
6 Dicembre 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 25 anatomia di uno screen saver
Computer Graphics Marco Tarini Università dellInsubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2005/06 Lezione.
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 25 Xml for dummies Parte 2
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 30 MMeditor e collision detection
Costruzione di Interfacce Lezione 15 Rendering Locale e Globale
25 Nov 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 21 Trackball
Costruzione di interfacce Paolo Cignoni
Costruzione di Interfacce Lezione 16 Qt
1 Costruzione di Interfacce Primi passi in OpenGL
2 Dicembre 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 23 Scene Graphs, Object Loading
Costruzione di Interfacce Lezione 8 Rasterizzazione
INFORMATICA GRAFICA – SSD ING-INF/05 Sistemi di elaborazione delle informazioni a.a. 2007/2008 Esercitazione OpenGL.
Corso di Elementi di Grafica Digitale Massimo De March
Bump Mapping & Under-Water Effects
Texturing - Tessiture Daniele Marini.
Smoothing Daniele Marini.
1 Effetti impressionistici Daniele Marini. 2 Tecniche discrete di manipolazione del frame buffer: –Texture mapping –Antialiasing –Compositing –Alpha blending.
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.
Effetti fotorealistici
Daniele Marini, Maurizio Rossi
Texturing - Tessiture Daniele Marini.
Architettura di OGL e pipe-line Daniele Marini Corso Di Programmazione Grafica.
Corso di Programmazione Grafica
Corso Di Programmazione Grafica
Texturing - Tessiture Daniele Marini.
Texturing - Tessiture Daniele Marini.
Texturing Daniele Marini Corso Di Programmazione Grafica aa2007/2008.
Corso di Programmazione Grafica e Laboratorio Daniele Marini
Ombre e riflessioni in tempo reale Daniele Marini Parzialmente tratte de: Haines-M ö ller 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.
Primitive OpenGL Corso di Programmazione Grafica e Laboratorio Daniele Marini.
Titolo Daniele Marini Davide Gadia Marco Ronchetti Davide Selmo Corso Di Programmazione Grafica aa2005/2006.
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 29 ancora MMeditor,
25 Nov 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 21 Trackball, Generazione TexCoords
Computer Graphics Marco Tarini Università dell’Insubria Facoltà di Scienze MFN di Varese Corso di Laurea in Informatica Anno Accademico 2006/07 Lezione.
Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 25 Xml for dummies Parte 2
22 Nov 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 19 Texturing
Transcript della presentazione:

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni1 Costruzione di Interfacce Lezione 22 Texturing

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni2 Texture Mapping Data unimmagine bidimensionale (ad es. una foto) viene ritagliata, stirata o compressa per adattarla esattamente alla forma di un poligono o di una superficie curva e di far sì che vi aderisca sopra come una decalcomania Colorare una primitiva (triangolo) secondo i colori di una bitmap Aggiungere dettagli senza aumentare la complessità della geometria dei modelli

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni3 Texture Mapping Legno Marmo

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni4 Coordinate di texture Per specificare come si colora un porzione di superfice con una texture si definiscono le coordinate di texture che indicano dove ritagliare la bitmap che ci interessa t s 1 1 0

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni5 Coordinate Texture Per ogni vertice si specifica quindi Le sue coordinate 3d effettive: In opengl glVertex3f(x,y,z) e le corrispondenti coordinate di texure In opengl glTexCoord2f(s,t)

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni6 Esempi Ad ogni vertice del triangolo è assegnato un punto sulla texture s 1 1 0

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni7 Esempio Modificando le coordinate di texture cambia che cosa viene disegnato sul triangolo s 1 1 0

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni8 Esempio Modificando la matrice di modelview, loggetto si sposta ma la texture rimane ferma sulloggetto s 1 1 0

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni9 Texture mapping in opengl Per ogni rendering context Caricare le texture creare un nome (glGenTexture) scegliere il nome di texture (glBind) caricare un immagine (glTexImage2d) Per ogni frame: Scegliere una texture corrente glBind(..) Per ogni Vertice: specificare le coordinate di texture glTexCoord(..)

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni10 Texture Objects Ogni texture object ha un nome con cui puo essere richiamata velocemente lo spazio dei nomi delle texture e quello degli unsigned int glGenTextures(n, int *names) crea n nomi di texture memorizzandoli in names[] Per scegliere la texture corrente glBind(GL_TEXTURE2D, texturename)

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni11 Loading an image Si passa ad opengl il blocco di mem che rappresenta la texture. Opengl lo copia nella memoria della scheda e lo formatta come meglio crede. Operazione piuttosto lenta. void glTexImage2D(GL_TEXTURE_2D GLint level, // the mipmap level GLint components, // number of color component (1..4) GLsizei width, // must be 2^n GLsizei height, // must be 2^n GLint border, // width of border GLenum format, // GL_RGB, GL_RGBA, GL_ALPHA ecc GLenum type, // data type of pixel (GL_BYTE, ecc) const GLvoid *pixels // a pointer to the image. );

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni12 Loading a Texture Il problema piu comune è come caricare unimmagine: Generarsi la texture da soli (facile per scacchiere e affini) Scriversi un lettore per un formato di immagini molto semplice (.pbm) Utilizzare una lib tipo glpng, devil o affidarsi a QT.

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni13 glPng Libreria free che permette di caricare come texture unimmagine in formato png #include … pngInfo info; GLuint texture; glGenTextures(1, &texture); glBindTexture(GL_TEXTURE_2D, texture); pngLoad(filename, PNG_NOMIPMAP, PNG_SOLID, &info))

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni14 Parametri Texture glTexParameter permette di settare di come si sceglie quali texel usare per il texturing GL_TEXTURE_MIN_FILTER GL_TEXTURE_MAG_FILTER GL_TEXTURE_WRAP_S GL_TEXTURE_WRAP_T

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni15 Mipmapping Texel e pixel non corripondono: Quando si guarda un oggetto textured da vicino si hanno molti pixel per un texel (oversampling della texture) Quando si guarda un oggetto textured da lontano si hanno molti texel che cadono in uno stesso pixel (subsampling texture)

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni16 Mipmapping Loversampling puo essere gestito Nearest texel Interpolazione lineare texel

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni17 MIPMAPPING Il subsampling puo essere gestito Nearest texel Nearest texel in unaltra texture grande la metà e filtrata bene (mipmapping) Per ogni texture si tiene un insieme di texture prefiltrate ognuna grande la metà della precendente gluBuild2DMipmaps(GL_TEXTURE_2D,... )

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni18 MipMapping Filtrata Non filtrata

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni19 Utilizzare una texture Texture environment: Specificare come si vuole combinare il colore della texture con il colore corrente glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, ???? ); GL_MODULATEmoltiplica il colore della texture per il colore delloggetto dopo lo shading (in questo modo la texture viene ombreggiata) GL_REPLACE il colore viene applicato esattamente. GL_DECAL il colore viene applicato modulato con lalpha. Ci sono anche altri modi supportati un po meno (fanno parte dello standard 1.3 e seg)

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni20 Coordinate di texture Esplicite Occorre salvare nel modello, per ogni vertice, dove va a finire sulla texture Fa parte del lavoro di modellazione fatto dallartista di turno Notare come sono impaccate bene le varie porzioni in cui è suddivisa la mesh.

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni21 Coordinate di texture Implicite Generate automaticament da Opengl in base alle coordinate dei vertici e alla matrice di modellazione corrente Object_Linear Eye_linear Sphere_map Reflection_map* Normal_map*

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni22 Object Linear Si può generare ogni texture coordinate (s,t,…) come funzione lineare delle sue coordinate Ad esempio glTexGeni(GL_S,GL_TEXTURE_GEN_MODE,GL_OBJECT_LINEAR); glTexGeni(GL_T,GL_TEXTURE_GEN_MODE,GL_OBJECT_LINEAR); float planevs[4]={1.0,0,0,0}; float planevt[4]={0,1.0,0,0}; glTexGenfv(GL_S,GL_OBJECT_PLANE,planevs); glTexGenfv(GL_T,GL_OBJECT_PLANE,planevt);

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni23 Sphere map Si generano coordinate texture, per vertice, in base a dove la normale delloggetto colpisce una sfera intorno alloggetto stesso. La superfice della sfera è mappata nello spazio di texture come in figura

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni24 Texture Non solo colore Texture mapping è utilizzato anche per spargere altri tipi di attibuti sulla superficie di un oggetto: Normali (bump/normal mapping) Posizione (displacement mapping) Trasparenza (alpha) Shininess Ombre portate.

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni25 Bump Mapping

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni26 Bump Map

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni27 Bumpmapping Le normali sono codificate nello spazio rgb signed Esiste un texture environment DOT3_RGB La direzione della luce viene passata come colore corrente della mesh

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni28 MultiTexture È possibile specificare più di una texture per una singola primitiva Le varie texture sono applicate in sequenza usando il risultato del precedente texturing per mixarlo con la texture corrente secondo un proprio texture environment

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni29 MultiTexturing Light maps glActiveTexture(GL_TEXTURE0_ARB); glBindTexture(GL_TEXTURE_2D, BASE_TEX_NAME); glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE); glEnable(GL_TEXTURE_2D); glActiveTexture(GL_TEXTURE1_ARB); glBindTexture(GL_TEXTURE_2D, LIGHT_TEX_NAME); glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); glEnable(GL_TEXTURE_2D); * =

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni30 Gloss mapping Base * Diffuse Light + Environment Map * Gloss Map = Result + * = Environment or Specular Map Gloss MapGloss Mapped Object Gouraud * Base Texture

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni31 Per pixel lighting Bump-map model with bump, gloss, & decal skin + Normal map Decal skin (not pre-lit) Gloss skin Interpolated keyframe of model geometry

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni32 ) + ( ( ) = 1 st pass Diffuse 3 rd pass Glossed Specular 2 nd pass Decal Final result! Per pixel lighting Three passes generated diffuse & specular bump mapping

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni33 In Pratica Prendiamo la classe moebius aggiungiamo coordinate texture per vertice passiamo tutto a float…

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni34 myVertex class myVertex { public : myVertex(){} myVertex(Point3f &pp, Point4f &nn,Point3f &tt) {p=pp; n=Point3f(nn[0],nn[1],nn[2]); t=tt;} Point3f p; Point3f n; Point3f t; Point4f n4() {return Point4f(n[0],n[1],n[2],0);} };

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni35 myMesh::Draw() void CIMoebius::myMesh::Draw() { glBegin(GL_TRIANGLES); vector ::iterator fi; for(fi=face.begin();fi!=face.end();++fi){ glNormal( (*fi).v[0]->n); glTexCoord((*fi).v[0]->t); glVertex( (*fi).v[0]->p); glNormal( (*fi).v[1]->n); glTexCoord((*fi).v[1]->t); glVertex( (*fi).v[1]->p); glNormal( (*fi).v[2]->n); glTexCoord((*fi).v[2]->t); glVertex( (*fi).v[2]->p); } glEnd(); }

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni36 CIMoebius::GenerateRing la parte difficile e generare le coord texture dellanello. in realta un anello e un toro che ha un unwrapping semplice in un rettangolo genero le coord di texture mentre genero lanello u = rotazione intorno alla sezione v = rotazione intorno allasse dellanello

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni37 CIMoebius::GenerateRing float angle=-360.0f/step; float angletwist=(twistDeg)/step; perimeter=0; for(j=0;j<s.poly.size();++j) perimeter+=Distance(s.poly[j].p, s.poly[(j+1)%s.poly.size()].p); for(i=0;i<=step;++i) { Matrix44f mm,rr,tt,tw; rr.Rotate(i*angle,Point3f(0,1,0)); tt.Translate(r,0,0); tw.Rotate(i*angletwist,Point3f(0,0,1)); mm=rr*tt*tw; float curlen=0; for(j=0;j<s.poly.size();++j){ m.vert.push_back(myVertex(mm*s.poly[j].p, mm*s.poly[j].n4(), Point3f(float(i)/step, curlen/perimeter, 0))); curlen+=Distance(s.poly[j].p,s.poly[(j+1)%s.poly.size()].p); }...

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni38 CIWidget::initializeGL()... QImage tt; tt.load("Texture.png"); QImage tx = QGLWidget::convertToGLFormat ( tt); int texName; glGenTextures(1, &texName); glBindTexture(GL_TEXTURE_2D, texName); glTexImage2D( GL_TEXTURE_2D, 0, 3, tx.width(), tx.height(), 0, GL_RGBA, GL_UNSIGNED_BYTE, tx.bits() ); glEnable(GL_TEXTURE_2D); glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE ); glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MIN_FILTER,GL_NEAREST); glTexParameteri(GL_TEXTURE_2D,GL_TEXTURE_MAG_FILTER,GL_NEAREST);...

22 Nov 2002Costruzione di Interfacce - Paolo Cignoni39 CIWidget::paintGL() void CIGLWidget::paintGL() { glMatrixMode (GL_TEXTURE); glLoadIdentity(); glScalef(4,4,1); glMatrixMode (GL_MODELVIEW); glClear(GL_COLOR_BUFFER_BIT |GL_DEPTH_BUFFER_BIT ); glLoadIdentity(); gluLookAt(2,5,12,0,0,0,0,1,0); glColor3f(1,.4,.4); glMultMatrix(rot); ring->m.Draw(); }