[WebGL入門]十二,模型數據和頂點屬性

注:文章譯自http://wgld.org/,原作者杉本雅広(doxas),文章中如果有我的額外說明,我會加上[lufy:],另外,鄙人webgl研究還不夠深入,一些專業詞語,如果翻譯有誤,歡迎大家指正。


頂點屬性的意思

上次的文章中,介紹了一下從着色器的生成,編譯,到程序對象的生成和着色器的連接。這次,簡單的說一下模型數據的定義和頂點屬性的處理。另外,介紹一下根據模型數據生成VBO的方法。
VBO的使用要比生成難理解一些,但是不要擔心,後面會慢慢說明。
接下來看一下頂點屬性。
頂點屬性,說的簡單點,就是頂點包含的各種元素。WebGL中,頂點至少要包含的元素是位置情報,這個之前已經說過很多遍了。
頂點是三維空間中的任意一個點,所以一定要有位置情報,如果沒有位置情報,則無法在三維空間中定義這個點,因爲每個點都不一樣,所以位置情報是必須的。lufy:感覺好羅嗦啊,作者是爲了強調吧,可是真的好羅嗦啊,好羅嗦啊,囉嗦啊,嗦啊,啊.....
但是,頂點裏還有可能包含其他屬性,舉個例子來說的話,比如頂點的顏色等等。根據頂點的顏色屬性,來對多邊形進行着色,或者透明等各種各樣的處理。
另外的,還有頂點的法線,紋理座標等相關的情報,這些都可以在頂點屬性中自由的定義。DirectX中根據所謂的頂點格式來實現這些,但是在WebGL中頂點的各種屬性都可以定義在頂點屬性中。

頂點屬性和VBO

既然頂點屬性是可以自由定義的,那麼具體應該如何來實現呢?
看過以前的文章的話,應該知道頂點屬性的個數和生成VBO的個數是一致的,如果頂點中有三個屬性,那麼就需要三個VBO,因爲頂點屬性必須通過VBO來傳給頂點着色器。VBO也叫做頂點緩存,和它的名字一樣,就是將頂點相關的情報緩存起來。頂點屬性和VBO一對一進行分配,然後傳給頂點着色器。
爲了生成VBO,首先準備好和頂點個數相對應的矩陣,這裏用的就是普通的javascript數組,當然Array對象也可以,但是不可以使用關聯數組,要使用一維數組。
舉個例子,由三個頂點定義多邊形的時候,寫成下面這樣。

>保存模型數據的數組的例子

var vertex_position = [
    // X,   Y,   Z
     0.0, 1.0, 0.0,
     1.0, 0.0, 0.0,
    -1.0, 0.0, 0.0
];
爲了讓大家看的更容易些,中間加了換行,可以看到這是一個一維數組,包含有9個元素,三個頂點都分別包含了X,Y,Z的座標,頂點數x要素的數,就是3x3=9,所以數組中元素的個數是9。

VBO的生成

用矩陣準備好頂點數據之後,就可以使用這個矩陣來生成VBO了,生成VBO的時候使用WebGL的createBuffer函數,這個函數就是用來生成緩存的。但是這個函數並不是用來直接生成VBO的,它只是生成了一個緩存對象,根據它裏面保存的內容不同,用途也是不用的。
要操作緩存,首先必須跟WebGL進行綁定,就是說,要向“緩存”這個“光盤”中寫入數據的時候,必須連接到WebGL這個“光驅”上。
綁定了緩存之後,使用bufferData函數來向緩存中寫入數據,把這些處理寫成一個函數,就是下面這樣。

>生成VBO的函數

function create_vbo(data){
    // 生成緩存對象
    var vbo = gl.createBuffer();
    
    // 綁定緩存
    gl.bindBuffer(gl.ARRAY_BUFFER, vbo);
    
    // 向緩存中寫入數據
    gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(data), gl.STATIC_DRAW);
    
    // 將綁定的緩存設爲無效
    gl.bindBuffer(gl.ARRAY_BUFFER, null);
    
    // 返回生成的VBO
    return vbo;
}
這個函數,接受一個矩陣作爲參數,最後返回生成的VBO。首先使用createBuffer生成緩存對象,接着綁定緩存,然後寫入數據。
綁定緩存的時候使用bindBuffer函數,這個函數有兩個參數,第一個參數是緩存的類型,第二個參數是指定緩存對象。將第一個參數指定爲gl.ARRAY_BUFFER就可以生成VBO。
另外,bufferData函數的第二個參數中出現的Float32Array對象,是javascript的類型數組,和一般的Array對象類似,是處理浮點型小數的時候使用的數組對象。3D世界裏小數的精確度非常重要,所以使用類型數組來傳遞數據。而第三個參數中的gl.STATIC_DRAW這個常量,定義了這個緩存中內容的更新頻率。VBO的話,模型數據基本上就是直接這麼反覆用,所以使用這個常量。
可以綁定WebGL的緩存,一次只能綁定一個,所以要操作其他的緩存的時候,必須要綁定相應的緩存。所以在函數的最後,再次使用bindBuffer函數,設定第二個參數爲null,來將上次的綁定無效化,這是爲了防止WebGL中的緩存一致保留,而出現和預想不一致的情況。

總結

頂點中的屬性是由程序員來自由添加的,需要的VBO的個數就是添加的屬性個數。
頂點屬性的各個數據,使用純粹的一維數組,當然,數組的元素個數要根據想要繪製的頂點個數來定義。
生成VBO的時候,首先要把緩存綁定到WebGL,然後相應的數據,要轉換爲相應的類型,然後使用指定的常量來寫入數據。而爲了避免預想之外的錯誤發生,數據寫入結束之後,要將WebGL中綁定的緩存無效化。
這樣,一連串的處理之後,模型數據就可以被頂點着色器利用了。下一回以後,說一下將VBO傳給着色器的步驟,首先先把VBO的準備部分好好理解一下吧。


下次,說一下如何準備座標變換矩陣。


轉載請註明:轉自lufy_legend的博客http://blog.csdn.net/lufy_legend

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章