Tìm hiểu WebGL Phần 3: Đi sau vào cách code WebGL appication - các ví dụ
https://viblo.asia/p/tim-hieu-webgl-phan-3-di-sau-vao-cach-code-webgl-appication-cac-vi-du-BMvRpNYrzwY
Tìm hiểu WebGL Phần 3: Đi sau vào cách code WebGL appication - các ví dụ
Bài đăng này đã không được cập nhật trong 2 năm
Lời Nói Đầu
Ở phần này chúng ta tiếp tục tìm hiểu cách lập trình WebGL: liên kết các attribute với các buffer object, sử dụng các hàm để vẽ các mô hình từ dữ liệu truyền vào. Sau đó là các ví dụ đơn giản về vẽ các điểm, mô hình 2D, 3D
Lập Trình WebGL (tiếp)
Liên kết các attribute và buffer object.
Mỗi attrubute trong vertex shader program trỏ tới một vertex buffer object. Sau khi tạo vertex buffer object, coder cần liên kết chúng với các attribute của vertex shader program. Mỗi attribute chỉ trỏ tới một vertex buffer object mà từ đó chúng lấy dữ liệu và sau đó các attributes được truyền cho shader program. Để liên kết các vertext buffer object với các attribute của vertex shader program ta cần làm theo các bước sau:
1. Lấy vị trí của attribute bằng phương thức getAttrubLocation():
Cú pháp:
Tham số đầu tiên là vertex shader program object Tham số thứ hai là attrubte của shader program.
2 Trỏ attribute tới vertex buffer object.
Để gán buffer object cho một biến attribute, ta dùng phương thức vertexAttrubPointer(). Cú pháp
Các tham số bao gồm:
Location: Vị trí của biến attribute. Ta sẽ truyền vào giá trị trả về của getAttribLocation().
Size: Số thành phần của mỗi đỉnh trong buffer object.
Type: kiểu dữ liệu.
Normalized: có chuẩn hóa dữ liệu hay không, nếu có dữ liệu được chuẩn hóa về [0, 1], còn không nó sẽ được chuẩn hóa về [-1, 1]
Stride: nó chỉ ra số byte giữa các thành phần dữ liệu các đỉnh khác nhau.
Offset: nó chỉ ra offset trong buffer object xác định byte nào được dùng để bắt đầu lưu trữ data.
3 Kích hoạt attribute.
Kích hoạt vertex shader program attribute để truy cập buffer object trong vertex shader sử dụng phương thức enableVertexAttribArray(). Cú pháp:
Tham số truyền vào là tên của attribute.
Vẽ các mô hình.
Sau khi liên kết buffer với shader, bước cuối cùng là vẽ các hình. Ta sử dụng hai phương thức drawArrays() và drawElements().
1. drawArrays()
Được dùng để vẽ các mô hình sử dụng các đỉnh.
Có 3 tham số của phương thức này:
mode: được dùng để chỉ ra kiểu sẽ được vẽ mà WebGL đã định sẵn: gl.POINTS - vẽ điểm, gl.LINES - vẽ đường thẳng, gl.TRIANGLES - vẽ tam giác ...
first: chỉ ra phần tử bắt đầu để vẽ trong mảng dữ liệu.
count: chỉ ra số phần tử được render.
Ví dụ với dữ liệu đầu vào gồm tọa độ 3D của 3 đỉnh:
Ta vẽ hình tam giác như sau:
2. drawElements()
Được dùng để vẽ các mô hình sử dụng đỉnh và các chỉ số.
Các tham số:
mode: được dùng để chỉ ra kiểu sẽ được vẽ mà WebGL đã định sẵn.
count: chỉ ra số phân tử được render.
type: chỉ ra kiểu dữ liệu của các chỉ số là UNSIGNED_BYTE hoặc UNSIGNED_SHORT.
offset: chỉ ra điểm bắt đầu để render.
Ví dụ với dữ liệu đầu vào gồm tọa độ 3D của 3 đỉnh cùng với chỉ số 3 đỉnh:
Ta vẽ hình tam giác như sau:
3.Các yêu cầu khác khi làm việc với WebGL.
Dọn dep Canvas: sử dụng phương thức clearColor():
Kích hoạt depth test.
Dọn dẹp color buffer bit.
Thiết lập view port. View port là vùng hình chữ nhật chứa các hình là kết quả của việc rendering, và được thiết lập sử dụng phương thức viewport().
Như vậy để làm một ứng dụng WebGL ta cần các bước sau:
Chuẩn bị WebGL context.
Chuẩn bị dữ liệu cho mô hình cần vẽ dưới dạng mảng javascript và lưu chúng vào các buffer object.
Tạo các vertex shader và fragment shader, biên dịch và liên kết chúng với nhau.
Liên kết các attributes của shader program với các buffer object để từ đó khai thác dữ liệu và truyền chúng vào các shader program.
Sử dụng các phương thức cần thiết để vẽ các hình.
Các ví dụ về tạo các ứng dụng WebGL.
Vẽ các điểm
Ta sẽ thực hiện thoe các bước đã nêu ở trên.
Chuẩn bị canvas và WebGL context.
Tạo dữ liệu hình học cho điểm và lưu trữ vào các buffer object. Các điểm như là các vertex ta có thể định nghĩa nó trong tọa độ 3D hoặc 2D. Dưới đây là định nghĩa các đỉnh trong tọa độ 3D và lưu vào vertex buffer.
Tạo và biên dịch các shader program.
Để xử lý dữ liệu về vị trí của các đỉnh (vertex) ta định nghĩa vertex shader program. Trong vertex shader program ta định một vector attribute để lưu trữ tạo độ 3D và gán nó cho biến gl_Position. Ngoài ra để các điểm có thể nhìn được rõ ta thiết lập kích thước cho điển thông qua biến gl_PointSize.
Để xử lý màu sắc cho các điểm ta định nghĩa fragment shader program. Trong fragment shader program ta thiết lập màu bằng việc gán giá trị cho biến gl_FragColor.
Sau khi tạo và biên dịch các shader program cần thiết ta sẽ liên kết chúng lại.
Liên kết các shader program với các buffer object.
Vẽ các điểm Ở đây ta sẽ sử dụng drawArrays() để vẽ các điểm.
Kết Luận
Bài viết vừa giới thiệu hai bước cuối dùng để lập trình một ứng dụng WebGL, cùng với một ví dụ cơ bản là vẽ ba đểm sử dụng WebGL. Ở phần tiếp theo của bài báo cáo sẽ là các ví dụ phức tạp hơn như mô hình 3D, tương tác với các mô hình.
Last updated