A apresentação está carregando. Por favor, espere

A apresentação está carregando. Por favor, espere

OpenGL Computação Gráfica. O que é OpenGL? Uma linguagem de programação gráfica de baixo nível Projetada para gráfico interativo 2D e 3D Uma interface.

Apresentações semelhantes


Apresentação em tema: "OpenGL Computação Gráfica. O que é OpenGL? Uma linguagem de programação gráfica de baixo nível Projetada para gráfico interativo 2D e 3D Uma interface."— Transcrição da apresentação:

1 OpenGL Computação Gráfica

2 O que é OpenGL? Uma linguagem de programação gráfica de baixo nível Projetada para gráfico interativo 2D e 3D Uma interface para o hardware gráfico Descendente do GL Céticos dizem que é GL com variáveis de nomes mais longos e sem gerenciamento de janela

3

4

5

6

7 Implementações Mesa: implementação para Sun Sparcs e Linux PCs (disponível livremente) SGIs tem implementações SGIs ~ 1500% mais rápidas (acesso direto ao hardware). –Não passa pelo SO

8 Como funciona o Open GL? Um conjunto de variáveis de estado –cor, parâmetros de visualização corrente (matrizes de transformações), largura de linha, final de linha, propriedades de objetos etc... Altere o valor das variáveis –Aplica-se a todo comando de desenho seguinte. Algumas variáveis possuem valores default no início (ex: Shading = FLAT).

9 Máquina de estados Habilitar ou desabilitar um estado ou predicado –glEnable() or glDisable(). Saber o estado corrente de uma variável: –glGetBooleanv(), glGetDoublev(), glGetFloatv(), glGetIntegerv(), glGetPointerv(), ou glIsEnabled() Mais específicas (parâmetros de iluminação) –glGetLight*()

10 O que OpenGL cobre? Primitivas OpenGL são pontos, linhas e polígonos Não faz windowing (gerenciamento de janelas e menus). –Use Xforms, Python, FLTK, TCL-TK, QT4 ou... Use a biblioteca Glut que formalmente não faz parte do OpenGL, mas vem com o pacote; ela pode ser usada para gerenciamento de janelas, menus, sliders, controle de mouse, teclado, etc.

11 Pipeline de renderização

12 Pipeline Dados geométricos (vertices, lines, e polygons) seguem o caminho que inclui evaluators e per- vertex Dados raster (pixels, images, e bitmaps) são tratados de forma diferente. Ambos tipos seguem os mesmos passos finais (rasterization e per-fragment operations) antes que os dados raster finais sejam escritos no frame- buffer.

13 Display Lists Todos os dados (descrição de geometria ou de pixels) podem ser salvos numa display list para ser usada instantaneamente ou futuramente. Facilita cálculos (aplicação de transformações, textura, etc). Quando pronto para renderizar, envia tudo de uma vez.

14 Evaluators Provêem uma maneitra de derivar vértices usados para representar superfícies a partir de pontos de controle (Splines). Mapeamento polinomial que produz normal à superfície, coordenadas de textura, cores e coordenadas espaciais a partir de valores em pontos pré-definidos.

15 Per Vertex Operation Converte Vértices em Primitivas (pontos, linhas, polígonos) Multiplicação por matrizes para gerar projeção Textura Iluminação (lighting)

16 Primitive Assembly Clipping Resultado: vértices transformados e cortados (clipped) com a respectiva cor, profundidade (Z-Buffer), e, eventualmente, o valor da coordenada de textura associada e outros parâmetros para renderização.

17 Pixel Operations Empacotar no formato devido Escalar, guiar, e processar por um pixmap Resultado escrito em memória de textura ou enviado para a rasterização

18 Texture assembly Aplicação de texturas Resultado é a montagem da textura na cena

19 Rasterização Conversão de ambos dados (geometria e pixels) em fragments. Cada fragmento quadrado corresponde a um pixel no framebuffer Valores de cor e profundidade são dados a cada fragmento quadrado.

20 Fragment Operations Texturização Cálculo de fog (neblina, refração, etc) Scissor test, alpha test, stencil test, depth- buffer (Z-Buffer) test Blending, dithering, operações lógicas e masking com uma máscara de bits Resultado é o pixel a ser finalmente escrito

21 Acertando uma janela de trabalho Coordenadas para os extremos glOrtho(left, right, bottom, top, near, far); e.g., glOrtho(0, 100, 0, 100, -1, 1); near & far devem ser sempre -1 & 1 (pelo menos por enquanto)

22 Limpando uma janela glClearColor(r, g, b, a); a é o canal alpha; coloque em 0. glClear(GL_COLOR_BUFFER_BIT); glClear pode limpar outros buffers assim também, mas usamos por enquanto apenas o buffer de cor

23 Estabelecendo uma cor Todas as primitivas subsequentes serão desta cor. Modelo de cor Red, Green & Blue Components são 0-1 (normalizados) –glColor4f(r,g,b,a);

24 Sintaxes dos comandos Nota: convenção de nomes OpenGL é: –gl [234][sifd][v] (args... ) –s - short, i - integer, f - float, d- double –v – ponteiro para um array Constantes: começam com GL_

25 Sufixos SufTypeC-Language TypeOpenGL Type b8-bit integersigned charGLbyte s16-bit integershortGLshort i32-bit integerint or longGLint, GLsizei f32-bit fpfloatGLfloat, GLclampf d64-bit fpdoubleGLdouble, GLclampd

26 Sufixo ub8-bit unsigned integer unsigned charGLubyte, GLboolean us16-bit unsigned integer unsigned shortGLushort ui32-bit unsigned integer unsigned int or unsigned long GLuint, GLenum, GLbitfield

27 Desenhando um polígono glBegin(GL_POLYGON); Envie então os pontos construindo o polígono glVertex2f(x0, y0); glVertex2f(x1, y1); glVertex2f(x2, y2)... Diga que o polígono terminou glEnd(); Thats it.

28 Truques especiais No lugar de GL_POLYGON: –GL_POINTS: plot points –GL_LINES: draw lines –GL_LINE_LOOP: framed polygon Gouraud Shading: –Mude a cor entre cada comando e GL fará um shading suave entre as cores dos diferentes vértices. Fazendo Flush do pipeline : glFlush();

29 Desenhando uma caixa MakeWindow("Box", 400, 400); /*Sua rotina de criar janela*/ glOrtho(-1, 1, -1, 1, -1, 1); glClearColor(0.5, 0.5, 0.5, 1); glClear(GL_COLOR_BUFFER_BIT); glColor3f(1.0, 0.0, 0.0); glBegin(GL_POLYGON); /* or GL_LINES or GL_POINTS... */ glVertex2f(-0.5, -0.5); glVertex2f( 0.5, -0.5); glVertex2f( 0.5, 0.5); glVertex2f(-0.5, 0.5); glEnd();

30 Trabalho de Laboratório Implementar diretamente os exemplos, sem modificar, e ver seus efeitos. Tempo estimado: 15 minutos. Comente sucintamente no relatório cada função ou bloco de comandos que voce entender (consulte o manual do red book para isso). Example 1-2 : Simple OpenGL Program Using GLUT: hello.c Example 1-3 : Double-Buffered Program: double.c Modificar exemplo 1-3 de modo que o quadrado gire no sentido oposto (tempo estimado: 5 minutos).


Carregar ppt "OpenGL Computação Gráfica. O que é OpenGL? Uma linguagem de programação gráfica de baixo nível Projetada para gráfico interativo 2D e 3D Uma interface."

Apresentações semelhantes


Anúncios Google