OpenGL
OpenGL (Open Graphics Library) è una specifica che definisce una API per più linguaggi e per più piattaforme per scrivere applicazioni che producono computer grafica 3D. L'interfaccia consiste in circa 250 diverse chiamate di funzione che si possono usare per disegnare complesse scene tridimensionali a partire da semplici primitive. Sviluppato nel 1992 dalla Silicon Graphics Inc., è ampiamente usato nell'industria dei videogiochi (nella quale compete con DirectX su Microsoft Windows), per applicazioni di CAD, realtà virtuale, e CAE. È lo standard de facto per la computer grafica 3D in ambiente Unix. SpecificaA livello più basso OpenGL è una specifica, ovvero si tratta semplicemente di un documento che descrive un insieme di funzioni ed il comportamento preciso che queste devono avere. Da questa specifica, i produttori di hardware creano implementazioni, ovvero librerie di funzioni create rispettando quanto riportato sulla specifica OpenGL, facendo uso dell'accelerazione hardware dove possibile. I produttori devono comunque superare dei test specifici per poter fregiare i loro prodotti della qualifica di implementazioni OpenGL. Esistono implementazioni efficienti di OpenGL (che sfruttano in modo più o meno completo le GPU) per Microsoft Windows, Linux, molte piattaforme Unix, PlayStation 3 e macOS. Queste implementazioni vengono normalmente fornite dai costruttori di dispositivi video e si affidano pesantemente sull'hardware fornito. Esistono realizzazioni software che portano OpenGL su piattaforme che non hanno il supporto dei costruttori hardware. La più nota è la libreria open source Mesa, un'API grafica basata solamente su librerie software che è compatibile con OpenGL. Tuttavia, a causa della licenza, può solo sostenere di essere un'API "molto simile". La specifica di OpenGL è stata inizialmente supervisionata dall'OpenGL Architecture Review Board (ARB), formatosi nel 1992. L'ARB era composto da un gruppo di aziende interessate a creare un'API coerente e ampiamente disponibile. I membri fondatori dell'ARB comprendevano aziende del calibro di 3Dlabs, Apple, ATI Technologies, Dell, IBM, Intel, NVIDIA, SGI, Sun Microsystems e Microsoft, che però ha abbandonato il gruppo nel marzo del 2003. Il coinvolgimento di così tante aziende con interessi molto diversificati, ha portato OpenGL a diventare nel tempo una API ad uso generico, con un ampio ventaglio di capacità. Il controllo di OpenGL è passato, ad inizio 2007, al consorzio Khronos Group, nel tentativo di migliorarne il marketing e di rimuovere le barriere tra lo sviluppo di OpenGL e OpenGL ES[1] StrutturaOpenGL assolve a due compiti fondamentali:
Il compito di OpenGL è quello di ricevere primitive come punti, linee e poligoni, e di convertirli in pixel (rasterizing o rasterizzazione). Ciò è realizzato attraverso una pipeline grafica nota come OpenGL state machine[2]. La maggior parte dei comandi OpenGL forniscono primitive alla pipeline grafica o istruiscono la pipeline su come elaborarle. Prima dell'introduzione di OpenGL 2.0, ogni stadio della pipeline realizzava una funzione fissa ed era configurabile solo entro certi limiti, ma dalla versione 2.0 molti stadi sono totalmente programmabili attraverso il linguaggio GLSL. OpenGL è una API procedurale che opera a basso livello, che richiede al programmatore i passi precisi per disegnare una scena. Questo approccio si pone in contrasto con le API descrittive ad alto livello le quali, operando su struttura dati ad albero (scene graph), richiedono al programmatore solo una descrizione generica della scena, occupandosi dei dettagli più complessi del rendering. La natura di OpenGL obbliga quindi i programmatori ad avere una buona conoscenza della pipeline grafica stessa, ma al contempo lascia una certa libertà per implementare complessi algoritmi di rendering. Storicamente, OpenGL ha esercitato una notevole influenza sullo sviluppo degli acceleratori 3D, promuovendo un livello base di funzionalità che è oggi comune nelle schede video destinate al grande pubblico:
Una delle caratteristiche più apprezzate in ambito professionale è la retrocompatibilità tra le diverse versioni di OpenGL: programmi scritti per la versione 1.0 della libreria devono funzionare senza modifiche su implementazioni che seguono la versione 2.1. VersioniRevisioni 1OpenGL 1 è un'evoluzione di (ed ha uno stile molto simile a) IRIS GL, l'interfaccia 3D di SGI. Una delle restrizioni di IRIS GL era che forniva accesso solamente alle caratteristiche supportate dall'hardware soggiacente. Se l'hardware grafico non supportava una caratteristica, allora l'applicazione non poteva usarla. OpenGL ha superato questo problema fornendo supporto via software per le caratteristiche non supportate dall'hardware, permettendo alle applicazioni di usare della grafica avanzata su sistemi di potenza relativamente bassa. Il progetto Fahrenheit fu uno sforzo congiunto fra Microsoft, SGI, e Hewlett-Packard con l'obiettivo di unificare le interfacce OpenGL e Direct3D. Inizialmente ha mostrato qualche promessa di portare ordine nel mondo delle API di computer grafica 3D interattiva, ma a causa dei vincoli finanziari in SGI e alla generale carenza di supporto nell'industria, è stato poi abbandonato. OpenGL 1.0Pubblicato nel 1992. La prima specifica di OpenGL fu pubblicata da Mark Segal e Kurt Akeley. OpenGL 1.1Pubblicato nel gennaio 1997. OpenGL 1.1 si prefigge di supportare funzioni texture e formati texture su GPU hardware.
OpenGL 1.2Pubblicato il 16 marzo 1998. OpenGL 1.2 si prefigge di supportare funzioni di volume textures, packed pixels, normal rescaling, clamped/edge texture sampling e image processing.
OpenGL 1.2.1Pubblicato il 14 ottobre 1998. OpenGL 1.2.1 è una pubblicazione intermedia che aggiunge funzioni di multi-texture, o anche texture units, al rendering pipeline. Ciò permette di mescolare textures multiple sulla base di pixel, durante la rasterizzazione.
OpenGL 1.3Pubblicato il 14 agosto 2001. OpenGL 1.3 aggiunge il supporto per funzioni di cubemap texture, multi-texturing, multi-sampling, e funzioni di texture unit combine operations (come: add, combine, dot3 e border clamp).
OpenGL 1.4Pubblicato il 24 luglio 2002. OpenGL 1.4 introduce il supporto hardware per funzioni di shadowing, fog coordinates, automatic mipmap generation, e funzioni addizionali di texture.
OpenGL 1.5Pubblicato il 29 luglio 2003. OpenGL 1.5 aggiunge supporto per: vertex buffer objects (VBOs), occlusion queries, e extended shadowing.
Revisioni 2Le schede pubblicate con OpenGL 2.0 sono le prime ad offrire shaders programmabili. OpenGL 2 è stato concepito da 3Dlabs per soddisfare le preoccupazioni che OpenGL fosse stagnante e mancasse di una forte direzione. 3Dlabs ha proposto alcune grosse aggiunte allo standard, la più significativa delle quali fu GLSL (da OpenGL Shading Language, cioè il linguaggio di shading di OpenGL). Questo consentirebbe ai programmatori di sostituire il codice prefissato di OpenGL per le pipeline di elaborazione dei vertici e dei frammenti con gli shader scritti in un linguaggio simile al C. GLSL era notevole per il fatto di non adeguarsi all'hardware allora disponibile; questo era un ritorno alla tradizione di OpenGL di porsi degli obiettivi ambiziosi e proiettati al futuro per nuovi acceleratori 3D, invece di limitarsi a inseguire lo stato dell'hardware attualmente disponibile. La specifica finale di OpenGL 2.0[3] comprendeva il supporto a GLSL, ma ometteva molte delle altre caratteristiche originalmente proposte - queste sono state differite a versioni future di OpenGL, sebbene alcune siano già disponibili come estensioni. OpenGL 2.0Pubblicato il 7 settembre 2004. OpenGL 2.0 aggiunge il supporto per un vero linguaggio assembly, basato sulle GPU, chiamato ARB (perché ideato dal Architecture Review Board), che si prefigge di divenire lo standard per tutte le funzioni di vertex and fragment shaders.
OpenGL 2.1Pubblicato il 2 luglio 2006. OpenGL 2.1 introduce un supporto per i pixel buffer objects (PBOs), sRGB textures (gamma-corrected textures), e per matrici non-quadre, oltre alla revisione 1.20 dello Shading Language GLSL[4].
Revisioni 3OpenGL 3.0 aggiunge un meccanismo di semplificazione per le API delle future revisioni. OpenGL 3.0Pubblicato l'11 luglio 2008. OpenGL 3.0 introduce il supporto per funzioni di geometry shader, frame buffer objects, hardware instancing, vertex array objects (VAOs), e sRGB framebuffers (gamma 2.2)[5].
OpenGL 3.1Pubblicato il 28 maggio 2009. OpenGL 3.1 aggiunge una serie di features per rendere le API più convenienti all'uso, oltre ad uno spettro di features orientate alla performance[6]; introduce anche una revisione 1.40 del linguaggio OpenGL Shading Language. Con la pubblicazione di OpenGL 3.1 è stata introdotta un'estensione di compatibilità che permette agli sviluppatori di accedere alle funzionalità deprecate di OpenGL 1.X/2.X e rimosse in OpenGL 3.1. Le funzionalità deprecate e rimosse in core profile includono:
OpenGL 3.2Pubblicato il 3 agosto 2009 ed aggiornato il 7 dicembre 2009.
OpenGL 3.3Pubblicato l'11 marzo 2010. Questa versione ha lo scopo di permettere alle GPU delle generazioni precedenti di usufruire di parte delle funzionalità di OpenGL 4.0. Pensato anche nell'ottica dello sviluppo di OpenGL ES (API dedicata ai dispositivi mobili come quelli basati su Android, webOS e iPhone OS).[7] Introduce la revisione 3.30 del linguaggio OpenGL Shading Language. Revisioni 4OpenGL 4.0Pubblicato l'11 marzo 2010. Questa versione include il supporto per la tessellation (tassellatura), e la virgola mobile a 64 bit con precisione doppia (per migliorare la qualità) per gli shader. Migliora inoltre il supporto per lo standard OpenCL, dedicato al GPGPU, cioè la possibilità di sfruttare la GPU per un maggior tipo di utilizzi.[7] OpenGL 4.1Pubblicato il 26 luglio 2010. Questa versione migliora l'interoperabilità con OpenCL e introduce la compatibilità con OpenGL ES 2.0. OpenGL 4.2Pubblicato l'8 agosto 2011.[8] OpenGL 4.3Pubblicato il 6 agosto 2012.[9] Questa versione introduce, tra le altre cose, la versione 4.30 del linguaggio di shading GLSL, il nuovo metodo di compressione delle texture ETC2/EAC, le texture views e la piena compatibilità con OpenGL ES 3.0.
OpenGL 4.4Pubblicato il 22 luglio 2013. OpenGL 4.5Pubblicato l'11 agosto 2014, viene introdotto il Flush Control che permette maggiori performance in applicazioni multithread, il DSA (Direct State Access) permette il controllo indipendente dei vari oggetti, inoltre viene ottimizzato il motore di rendering WebGL[10]. OpenGL 4.6Pubblicato il 31 Luglio 2017, oltre a molte estensioni e ottimizzazioni, introduce il supporto a SPIR-V. EstensioniLo standard OpenGL permette ai produttori individuali di fornire funzionalità aggiuntive tramite le estensioni man mano che vengono create nuove tecnologie. Un'estensione viene poi distribuita in due parti: come file di intestazione che contiene i prototipi di funzione dell'estensione, e come driver del produttore.
Ogni produttore ha un'abbreviazione alfabetica che viene usata nel denominare le loro nuove funzioni e costanti.
Per esempio, l'abbreviazione di NVIDIA (NV) viene usata nel definire la loro funzione proprietaria In tal caso, si usa l'abbreviazione EXT.
Può anche accadere che l'ARB approvi l'estensione.
Allora essa diventa nota come una estensione standard, e si usa l'abbreviazione ARB.
La prima estensione ARB è stata la Varie librerie sono state costruite sopra OpenGL per fornire funzionalità non disponibili in OpenGL stesso: In particolare, la libreria OpenGL Performer, sviluppata da SGI e disponibile per IRIX, Linux, e varie versioni di Microsoft Windows, si appoggia a OpenGL per abilitare la creazione di applicazioni di simulazione visuale in sistema real-time. BindingsAl fine di imporre le sue caratteristiche multi-linguaggio e multi-piattaforma, vari binding e port sono stati sviluppati per OpenGL in molti linguaggi. Tra i più notevoli, la libreria Java 3D può appoggiarsi su OpenGL per sfruttare l'accelerazione hardware. Molto recentemente, Sun ha pubblicato le versioni beta del sistema JOGL, che fornisce binding ai comandi OpenGL in C, diversamente da Java 3D che non fornisce tale supporto a basso livello. La pagina OpenGL ufficiale elenca vari bindings per i linguaggi Java, Fortran 90, Perl, Pike, Python, Ada, e Visual Basic. Funziona nativamente con C++ e possiede wrappers per C#. Funzionalità ad alto livelloOpenGL è stato progettato per essere di solo output: fornisce solamente funzioni di rendering. L'API di base non contempla la gestione di finestre, l'audio, la stampa, la tastiera, il mouse, né altri dispositivi di input. Per quanto questo possa sembrare restrittivo, permette al codice di rendering di essere completamente indipendente dal sistema operativo su cui funziona, permettendo lo sviluppo di codice indipendente dalla piattaforma. Tuttavia, per consentire un'interazione con il sistema ospitante, è necessario integrare il software con il sistema a finestre nativo. Ciò viene effettuato tramite le seguenti API aggiuntive:
In aggiunta le librerie GLUT e SDL forniscono funzionalità per una gestione elementare delle finestre con OpenGL, in maniera portabile. macOS ha tre API per ottenere il supporto di OpenGL: AGL per Carbon, NSOpenGL per Cocoa e Core OpenGL (CGL) per l'accesso diretto. Esempio di codice sorgenteDi seguito un semplice programma in C che disegna un triangolo utilizzando le primitive OpenGL. Si noti che questo programma fa uso di funzionalità deprecate a partire da OpenGL 3.0. /*************************************************************
* Per compilare con gcc su Linux: *
* gcc file.c -lglut *
* oppure: *
* gcc file.c -L/usr/X11R6/lib -lglut -lXmu -lGL -lGLU -lXi *
*************************************************************/
#include <GL/gl.h> // File header per la libreria OpenGL
#include <GL/glut.h> // File header per la libreria GLUT
#include <stdlib.h> // File header per usare 'exit()'
/* Funzione invocata quando la finestra viene ridimensionata (anche quando viene creata) */
void
resize (int width, int height)
{
glViewport (0, 0, width, height); // Usiamo tutta finestra
glMatrixMode (GL_PROJECTION); // Seleziona di usare la matrice 'PROJECTION'
glLoadIdentity (); // Resetta la matrice 'PROJECTION'
glMatrixMode (GL_MODELVIEW); // Seleziona di usare la matrice 'MODELVIEW'
glLoadIdentity (); // Resetta la matrice 'MODELVIEW'
}
/* Funzione di disegno */
void
draw ()
{
glClearColor (0.0f, 0.0f, 0.0f, 0.0f); // Sfondo nero
glClear (GL_COLOR_BUFFER_BIT); // Cancella la scena
glBegin (GL_TRIANGLES); // Disegna un triangolo
glColor3f (1.0f, 0.0f, 0.0f); // Impostiamo il colore rosso
glVertex3f ( 0.0f, 0.5f, 0.0f); // Angolo in alto
glColor3f (0.0f, 1.0f, 0.0f); // Imposta il colore verde
glVertex3f (-0.5f, -0.5f, 0.0f); // Angolo basso sinistro
glColor3f (0.0f, 0.0f, 1.0f); // Imposta il colore blu
glVertex3f (0.5f, -0.5f, 0.0f); // Angolo basso destro
glEnd (); // Fine triangolo
glutSwapBuffers (); // Disegna!
}
/* Funzione invocata ogni volta che viene premuto un tasto */
void
keyPressed (unsigned char key, int x, int y)
{
if (key == 'q') // Se il tasto premuto e` q,
exit (0); // esce
}
/* Main */
int
main (int argc, char **argv)
{
glutInit (&argc, argv); // Inizializza la libreria GLUT
glutInitDisplayMode (GLUT_RGB|GLUT_DOUBLE); // Seleziona il modo di visualizzazione: usa RGB e double buffer
glutInitWindowSize (640, 480); // Imposta la dimensione della finestra a 640x480
glutInitWindowPosition (0, 0); // Imposta la posizione dell'angolo alto sinistro della finestra
glutCreateWindow ("Esempio uso OpenGL"); // Crea la finestra
glutDisplayFunc (draw); // Imposta la funzione di disegno
glutReshapeFunc (resize); // Imposta la funzione di ridimensionamento
glutKeyboardFunc (keyPressed); // Imposta la funzione per gli eventi della tastiera
glutMainLoop (); // Inizio
return (1);
}
Il futuro in Microsoft WindowsIl 6 agosto 2005, quelle che in principio erano le intenzioni di Microsoft riguardo al supporto di OpenGL in Windows Vista vennero rivelate in annuncio di notizie su Opengl.org[12]. «I piani attuali di Microsoft per OpenGL su Windows Vista sono di appoggiare OpenGL sopra Direct3D al fine di usare OpenGL su un desktop composito per ottenere l'esperienza Aeroglass. Se si esegue un ICD OpenGL - il desktop compositor si spegnerà - degradando significativamente l'esperienza dell'utente. In pratica, per OpenGL sotto Aeroglass, ciò significa: Le prestazioni di OpenGL verranno significativamente ridotte - forse fino al 50%. OpenGL su Windows verrà portata ad una versione base di OpenGL 1.4. Nessuna estensione sarà possibile per esporre future innovazioni hardware. Sarebbe tecnicamente immediato fornire un ICD OpenGL (installable client driver, cioè un driver specifico per OpenGL) all'interno dell'intera esperienza Aeroglass senza compromettere la stabilità o la sicurezza del sistema operativo. Appoggiare OpenGL su Direct3D è una decisione più strategica che tecnica.» Allora, il futuro di OpenGL come libreria principale per i videogiochi sembrava precario. Microsoft aveva preso la decisione di non pubblicare le informazioni necessarie per permettere a terze parti (come NVIDIA, ATI o gli altri grandi costruttori di schede) di sviluppare i driver di sostituzione, non lasciando modo di evitare il calo di velocità del 50%. Forse proprio a seguito delle pressioni che giungevano dal mondo dell'industria del software e dagli stessi produttori hardware, Microsoft ha in seguito rivisto questa politica e sono oggi disponibili ICD in grado di funzionare senza problemi in unione al sottosistema Aeroglass, senza calo di prestazioni. Si veda a tal proposito la presentazione relativa ad OpenGL su Windows Vista pubblicata da NVIDIA al SIGGRAPH 2006[13]. Così come per il predecessore Windows XP, anche il CD di installazione di Windows Vista non include alcun ICD (Installable Client Driver), che dovrà essere installato a cura dell'utente. In mancanza di un ICD, Vista fornisce comunque funzionalità OpenGL 1.4 senza estensioni, attraverso uno strato di emulazione basato su Direct3D. Il futuro di OpenGL in ambito videoludico è quindi ora nelle mani dei produttori di videogiochi, i quali non sembrano comunque molto propensi all'utilizzo di questa API, come dimostrerebbe anche una decisione di uno dei suoi più illustri sostenitori in questo ambito, ovvero John Carmack di id Software. Quest'ultimo ha infatti affermato[14] al QuakeCon 2005 che la sua principale piattaforma di sviluppo sarà Xbox 360, che infatti si appoggia a DirectX. Note
Bibliografia
Voci correlateAltri progetti
Collegamenti esterni
Risorse per programmatori
|
Portal di Ensiklopedia Dunia