WebGL: dibujo de un modelo
Después de asociar los búferes con los sombreadores, el paso final es dibujar las primitivas requeridas. WebGL proporciona dos métodos, a saber,drawArrays() y drawElements() dibujar modelos.
drawArrays ()
drawArrays()es el método que se utiliza para dibujar modelos utilizando vértices. Aquí está su sintaxis:
void drawArrays(enum mode, int first, long count)
Este método toma los siguientes tres parámetros:
mode- En WebGL, los modelos se dibujan utilizando tipos primitivos. Al usar el modo, los programadores deben elegir uno de los tipos primitivos proporcionados por WebGL. Los valores posibles para esta opción son: gl.POINTS, gl.LINE_STRIP, gl.LINE_LOOP, gl.LINES, gl.TRIANGLE_STRIP, gl.TRIANGLE_FAN y gl.TRIANGLES.
first- Esta opción especifica el elemento inicial en las matrices habilitadas. No puede ser un valor negativo.
count - Esta opción especifica el número de elementos a renderizar.
Si dibuja un modelo usando drawArrays() , luego WebGL, mientras renderiza las formas, crea la geometría en el orden en que se definen las coordenadas del vértice.
Ejemplo
Si quieres dibujar un solo triángulo usando drawArray() método, entonces tienes que pasar tres vértices y llamar al drawArrays() método, como se muestra a continuación.
var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 3);
Producirá un triángulo como se muestra a continuación.
Suponga que desea dibujar triángulos contiguos, luego debe pasar los siguientes tres vértices en orden en el búfer de vértices y mencionar el número de elementos que se renderizarán como 6.
var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5, 0.0,-0.5, 0.25,0.5, 0.5,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 6);
Producirá un triángulo contiguo como se muestra a continuación.
drawElements ()
drawElements()es el método que se utiliza para dibujar modelos utilizando vértices e índices. Su sintaxis es la siguiente:
void drawElements(enum mode, long count, enum type, long offset)
Este método toma los siguientes cuatro parámetros:
mode- Los modelos WebGL se dibujan utilizando tipos primitivos. Al usar el modo, los programadores deben elegir uno de los tipos primitivos proporcionados por WebGL. La lista de valores posibles para esta opción es: gl.POINTS, gl.LINE_STRIP, gl.LINE_LOOP, gl.LINES, gl.TRIANGLE_STRIP, gl.TRIANGLE_FAN y gl.TRIANGLES.
count - Esta opción especifica el número de elementos a renderizar.
type - Esta opción especifica el tipo de datos de los índices que deben ser UNSIGNED_BYTE o UNSIGNED_SHORT.
offset- Esta opción especifica el punto de partida para la renderización. Suele ser el primer elemento (0).
Si dibuja un modelo usando drawElements(), entonces el objeto de búfer de índice también debe crearse junto con el objeto de búfer de vértice. Si usa este método, los datos de vértice se procesarán una vez y se usarán tantas veces como se mencione en los índices.
Ejemplo
Si desea dibujar un solo triángulo usando índices, debe pasar los índices junto con los vértices y llamar al drawElements() método como se muestra a continuación.
var vertices = [ -0.5,-0.5,0.0, -0.25,0.5,0.0, 0.0,-0.5,0.0 ];
var indices = [0,1,2];
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
Producirá la siguiente salida:
Si quieres dibujar triángulos contagiosos usando drawElements() método, simplemente agregue los otros vértices y mencione los índices de los vértices restantes.
var vertices = [
-0.5,-0.5,0.0,
-0.25,0.5,0.0,
0.0,-0.5,0.0,
0.25,0.5,0.0,
0.5,-0.5,0.0
];
var indices = [0,1,2,2,3,4];
gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);
Producirá la siguiente salida:
Operaciones requeridas
Antes de dibujar una primitiva, debe realizar algunas operaciones, que se explican a continuación.
Limpiar el lienzo
Primero que nada, debes limpiar el lienzo usando clearColor()método. Puede pasar los valores RGBA de un color deseado como parámetro de este método. Luego, WebGL borra el lienzo y lo llena con el color especificado. Por lo tanto, puede utilizar este método para configurar el color de fondo.
Eche un vistazo al siguiente ejemplo. Aquí estamos pasando el valor RGBA del color gris.
gl.clearColor(0.5, 0.5, .5, 1);
Habilitar prueba de profundidad
Habilite la prueba de profundidad usando el enable() método, como se muestra a continuación.
gl.enable(gl.DEPTH_TEST);
Borrar el bit de búfer de color
Borre el color y el búfer de profundidad utilizando el clear() método, como se muestra a continuación.
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
Configurar el puerto de vista
El puerto de visualización representa un área visible rectangular que contiene los resultados de la representación del búfer de dibujo. Puede establecer las dimensiones del puerto de visualización utilizandoviewport()método. En el siguiente código, las dimensiones del puerto de visualización se establecen en las dimensiones del lienzo.
gl.viewport(0,0,canvas.width,canvas.height);