WebGL-모델 그리기
버퍼를 셰이더와 연결 한 후 마지막 단계는 필요한 프리미티브를 그리는 것입니다. WebGL은 두 가지 방법을 제공합니다.drawArrays() 과 drawElements() 모델을 그릴 수 있습니다.
drawArrays ()
drawArrays()정점을 사용하여 모델을 그리는 데 사용되는 방법입니다. 구문은 다음과 같습니다.
void drawArrays(enum mode, int first, long count)
이 방법은 다음 세 가지 매개 변수를 사용합니다.
mode− WebGL에서 모델은 기본 유형을 사용하여 그려집니다. 모드를 사용하여 프로그래머는 WebGL에서 제공하는 기본 유형 중 하나를 선택해야합니다. 이 옵션의 가능한 값은-gl.POINTS, gl.LINE_STRIP, gl.LINE_LOOP, gl.LINES, gl.TRIANGLE_STRIP, gl.TRIANGLE_FAN 및 gl.TRIANGLES입니다.
first−이 옵션은 활성화 된 배열의 시작 요소를 지정합니다. 음수 값이 될 수 없습니다.
count −이 옵션은 렌더링 할 요소의 수를 지정합니다.
사용하여 모델을 그리는 경우 drawArrays() 그런 다음 WebGL은 모양을 렌더링하는 동안 정점 좌표가 정의 된 순서대로 지오메트리를 만듭니다.
예
사용하여 단일 삼각형을 그리려면 drawArray() 메서드를 사용하려면 세 개의 정점을 전달하고 drawArrays() 방법은 아래와 같습니다.
var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 3);
아래와 같이 삼각형이 생성됩니다.
연속 삼각형을 그리려면 정점 버퍼에서 순서대로 다음 세 개의 정점을 전달하고 렌더링 할 요소 수를 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);
아래와 같이 연속 삼각형이 생성됩니다.
drawElements ()
drawElements()정점과 인덱스를 사용하여 모델을 그리는 데 사용되는 방법입니다. 구문은 다음과 같습니다.
void drawElements(enum mode, long count, enum type, long offset)
이 방법은 다음 네 가지 매개 변수를 사용합니다.
mode− WebGL 모델은 기본 유형을 사용하여 그려집니다. 모드를 사용하여 프로그래머는 WebGL에서 제공하는 기본 유형 중 하나를 선택해야합니다. 이 옵션에 사용할 수있는 값 목록은 − gl.POINTS, gl.LINE_STRIP, gl.LINE_LOOP, gl.LINES, gl.TRIANGLE_STRIP, gl.TRIANGLE_FAN 및 gl.TRIANGLES입니다.
count −이 옵션은 렌더링 할 요소의 수를 지정합니다.
type −이 옵션은 UNSIGNED_BYTE 또는 UNSIGNED_SHORT 여야하는 인덱스의 데이터 유형을 지정합니다.
offset−이 옵션은 렌더링 시작점을 지정합니다. 일반적으로 첫 번째 요소 (0)입니다.
사용하여 모델을 그리는 경우 drawElements()메서드를 사용하면 정점 버퍼 개체와 함께 인덱스 버퍼 개체도 만들어야합니다. 이 방법을 사용하면 정점 데이터가 한 번 처리되고 색인에 언급 된대로 여러 번 사용됩니다.
예
인덱스를 사용하여 단일 삼각형을 그리려면 꼭지점과 함께 인덱스를 전달하고 drawElements() 방법은 아래와 같습니다.
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);
다음과 같은 출력이 생성됩니다.
다음을 사용하여 전염성이있는 삼각형을 그리려면 drawElements() 방법을 사용하려면 다른 정점을 추가하고 나머지 정점에 대한 색인을 언급하면됩니다.
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);
다음과 같은 출력이 생성됩니다.
필요한 작업
프리미티브를 그리기 전에 아래에 설명 된 몇 가지 작업을 수행해야합니다.
캔버스 지우기
먼저 캔버스를 지워야합니다. clearColor()방법. 원하는 색상의 RGBA 값을이 메서드에 매개 변수로 전달할 수 있습니다. 그런 다음 WebGL은 캔버스를 지우고 지정된 색상으로 채 웁니다. 따라서이 방법을 사용하여 배경색을 설정할 수 있습니다.
다음 예를 살펴보십시오. 여기에서는 회색의 RGBA 값을 전달합니다.
gl.clearColor(0.5, 0.5, .5, 1);
깊이 테스트 활성화
다음을 사용하여 깊이 테스트를 활성화합니다. enable() 방법은 아래와 같습니다.
gl.enable(gl.DEPTH_TEST);
색상 버퍼 비트 지우기
다음을 사용하여 색상과 깊이 버퍼를 지 웁니다. clear() 방법은 아래와 같습니다.
gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
보기 포트 설정
뷰 포트는 드로잉 버퍼의 렌더링 결과를 포함하는 직사각형보기 가능 영역을 나타냅니다. 다음을 사용하여 뷰포트의 치수를 설정할 수 있습니다.viewport()방법. 다음 코드에서 뷰 포트 차원은 캔버스 차원으로 설정됩니다.
gl.viewport(0,0,canvas.width,canvas.height);