頂點 (電腦圖學)

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書
圖中的頂點包含了顏色資訊,分別為紅、綠、藍,通過彩現流程後會輸出一個漸變色彩的三角形。

電腦圖學中,頂點是儲存一系列基本繪圖所需屬性的基本元素,例如2D或3D空間中的點、或曲面上的多個點。在著色器中,與頂點相連的元素稱為圖元,圖元內部應上色的區域稱為片段,頂點的集合稱為頂點組或頂點陣列。[1]而在OpenGL中,頂點預設會包含位置、法向量、顏色、第二色彩、紋理座標等屬性[2],而其可以透過著色器編程添加更多屬性。

與幾何學的關聯

電腦圖學中,3D模型通常會表示為以三角形構成的多面體,其中,頂點所包含的資訊不像幾何學中只含有座標資訊,而會額外地包含其彩現所需的資訊,如顏色、反射特性、紋理和表面法線等[3]。電腦圖學中的頂點同樣可以如同幾何學構造與頂點相連的邊,然而多邊形並非由多個邊組成的封閉結構,而是多個頂點依序圍出的結構,並構成面,而以上組合在電腦圖學中有一個專有名詞,稱為圖元。

應用於3D模型

圖中右側可以理解為使用原始頂點資訊繪製出的斯坦福兔子圖象,而左側是透過頂點所提供的彩現資訊內插產生的結果

在電腦圖學中,一般的3D模型通常可以通過曲面細分將非三角形曲面轉換為三角形陣列。而3D模型通常是透過在圖元上依據頂點性質內插出資料以彩現出最後的立體。[4]

頂點屬性

在電腦圖學中,三角形多邊形的頂點不僅與空間位置相關聯,而且也需要提供正確彩現物件所需的其他值或關聯資訊。這些資訊稱為頂點屬性(Vertex attributes)。頂點的大多數屬性表示彩現所需的空間向量。這些向量通常可能是一維(x)、二維(x,y)或三維(x,y,z)的向量,並會包含一個齊次座標的維度(w)。這些值通常可以代表要繪製的物件之材質(material)的描述。這些數據通常會在頂點著色器或頂點處理流程中被使用。[4]

常見的頂點屬性包括:

頂點位置
對應到2D或3D空間的頂點位置資訊[2]
頂點顏色
通常為鏡面反射或漫反射的顏色值,表示物體的表面顏色或預先計算的照明資訊。一般以RGB色彩空間表示。[2]
反射率
例如頂點所處表面的鏡面指數、金屬度、菲涅耳值等資訊。[5]
紋理座標
用於決定如何將紋理正確彩現所需的座標值。[2]
法向量
法向量可以用於定義了頂點位置處近似曲面[6][7],用於光照計算(例如Phong著色法[8][9]、法線貼圖、位移貼圖以及控制曲面細分。[2]
切線向量
與法向量垂直的向量,用於部分的法線貼圖、位移貼圖以及控制曲面細分。[10]
骨架權重
儲存用於繪製骨骼動畫所需的資訊。[11]

用途

頂點包含的資料通常是提供彩現物件所需。在早期版本的OpenGL中,頂點能包含的資料種類是固定的,並且要在起始函式的呼叫以及終止函式的呼叫之間依序傳入每個頂點的資料,在OpenGL 1.0中起始函式為glBegin、終止函式為glEnd[12]。最初電腦圖學中的頂點定義與幾何學類似,只包含空間位置資訊,並且要透過glVertex傳入資料[13]。顏色參數是額外的一個狀態變數,指定一次後後續會沿用先前最後一次給定的顏色[14]。關於其他的頂點屬性則是要在每個頂點定義glVertex之前給出[15]。而後來出現了著色器的概念[16],使得頂點定義能夠直接被程式開發人員決定。頂點的各項屬性被依序存入緩衝器中,並且輸入到頂點著色器中,頂點著色器中定義的每一個被標記為attribute的變數都是一個頂點的屬性,透過客製化這些屬性可以讓一些較複雜的演算法跟隨彩現流程一同完成,例如等值立方搜尋演算法英語Marching cubes[17]

參見

參考文獻

  1. ^ Tomas Akenine-Möller, Eric Haines, Naty Hoffman. Real-Time Rendering. CRC Press. 2016. ISBN 9781498785631. LCCN 2008011580. 
  2. ^ 2.0 2.1 2.2 2.3 2.4 Andrew Garrard. Khronos Data Format Specification (PDF). Khronos Group. 2019-03-31 [2019-09-16]. (原始內容存檔 (PDF)於2022-04-19). 
  3. ^ Christen, Martin. Clockworkcoders Tutorials: Vertex Attributes. Khronos Group. [26 January 2009]. (原始內容存檔於2019-04-12). 
  4. ^ 4.0 4.1 Vertex Shader Introduction (PDF). nvidia. [2019-09-16]. (原始內容存檔 (PDF)於2021-07-28). 
  5. ^ Tan, Ping and Lin, Stephen and Quan, Long and Guo, Baining and Shum, Heung-Yeung, Multiresolution Reflectance Filtering., Rendering Techniques, 2005: 111––116 
  6. ^ RCA Corporation. RCA Electro-optics Handbook. RCA solid State. RCA/Commercial Engineering. 1974: p.18 ff [2021-07-16]. LCCN 75318901. (原始內容存檔於2022-05-31). 
  7. ^ Warren J. Smith. Modern optical engineering. McGraw-Hill. 1966: p.228, 256. 
  8. ^ Watt, Alan H.; Watt, Mark. Advanced Animation and Rendering Techniques: Theory and Practice. Addison-Wesley Professional. 1992: 21–26. ISBN 978-0-201-54412-1. 
  9. ^ Foley, James D.; van Dam, Andries; Feiner, Steven K.; Hughes, John F. Computer Graphics: Principles and Practice. (2nd ed. in C). Addison-Wesley Publishing Company. 1996: 738–739. ISBN 0-201-84840-6. 
  10. ^ Habel, Ralf and Wimmer, Michael, Efficient irradiance normal mapping, Proceedings of the 2010 ACM SIGGRAPH symposium on Interactive 3D Graphics and Games (ACM), 2010: 189––195 
  11. ^ Jacobson, Alec and Sorkine, Olga, Stretchable and twistable bones for skeletal shape deformation, ACM Transactions on Graphics (TOG) 30 (6) (ACM), 2011, 30 (6): 165 
  12. ^ Martz, P. OpenGL Distilled. OpenGL. Pearson Education. 2006: 38. ISBN 9780132701785. 
  13. ^ Bailey, M. and Cunningham, S. Graphics Shaders: Theory and Practice, Second Edition. CRC Press. 2016. ISBN 9781439867754. LCCN 2011031720. 
  14. ^ Guha, S. Computer Graphics Through OpenGL: From Theory to Experiments. CRC Press. 2014. ISBN 9781482258400. 
  15. ^ Shreiner, D. and Group, B.T.K.O.G.L.A.R.B.W. OpenGL Programming Guide: The Official Guide to Learning OpenGL, Versions 3.0 and 3.1. Pearson Education. 2009. ISBN 9780321669278. 
  16. ^ The RenderMan Interface Specification. (原始內容存檔於2019-06-16). 
  17. ^ Goetz, Frank and Junklewitz, Theodor and Domik, Gitta, Real-Time Marching Cubes on the Vertex Shader., Eurographics (Short Presentations), 2005: 5––8