WebGL編程指南(可交互3D圖形編程第一書 國內(nèi)第一社區(qū)、第一商用網(wǎng)站鼎力推薦 Amazon五星暢銷 )
定 價:98 元
- 作者:(美)松田浩一,(美)李 著,謝光磊 譯
- 出版時間:2014/6/1
- ISBN:9787121229428
- 出 版 社:電子工業(yè)出版社
- 中圖法分類:TP393.092-62
- 頁碼:470
- 紙張:膠版紙
- 版次:1
- 開本:16開
WebGL 是一項在網(wǎng)頁上渲染三維圖形的技術,也是HTML5 草案的一部分。
《WebGL編程指南》的主要篇幅講解了WebGL 原生API 和三維圖形學的基礎知識,包括渲染管線、著色器、矩陣變換、著色器編程語言(GLSL ES)等等,也講解了使用WebGL 渲染三維場景的一般技巧,如光照、陰影、霧化等等!禬ebGL編程指南》提供了豐富的示例程序供讀者鉆研,也提供了極具價值的附錄供讀者參考。
《WebGL編程指南》適合有一定前端開發(fā)基礎,希望學習WebGL,但對三維圖形學缺乏了解的程序員們閱讀。
使用WebGL,你可以在瀏覽器中,不依賴任何插件創(chuàng)建出精美的可交互三維圖形。WebGL技術使得創(chuàng)建新一代3D網(wǎng)頁游戲、用戶界面、數(shù)據(jù)可視化方案成為可能,這些程序能夠運行任何支持標準瀏覽器的PC、智能手機、平板電腦、家用游戲機或其他設備上!禬ebGL編程指南》將會幫助你快速入門學習可交互的WebGL 3D編程,即使你還不了解HTML5、javascript、三維圖形學理論、數(shù)學基礎和OpenGL也沒有關系! ∧銓徊揭徊降貙W習真實的示例程序。隨著示例程序從簡單變復雜,你也將逐漸掌握使用WebGL開發(fā)虛擬逼真的網(wǎng)頁和三維圖形的技能。多媒體、三維圖形學和WebGL領域的先驅者Kouichi Matsuda博士和Rodger Lea博士在這本書中提供了易于上手、重點清晰的WebGL教程,以及共計100個可下載的示例程序,每個程序都討論了一個具體的WebGL話題! ∧銓淖罨镜募夹g比如渲染、動畫、為三角形貼上紋理開始,一路學習到高級的WebGL技術,比如霧化、陰影、切換著色器、顯示由Blender等建模工具創(chuàng)建的三維模型。這本書并不僅僅向你傳授最佳的實踐方法,同時也會向你提供一個小型的代碼庫,方便你在學習完本書后,開始編寫自己的程序! ”緯膬(nèi)容包括: √ WebGL的起源、核心概念、特性、優(yōu)勢以及與其他Web標準的結合; √ canvas和基本的WebGL函數(shù)如何協(xié)作以顯示三維圖形; √ 使用OpenGL ES著色器語言(GLSL ES)編寫著色器代碼; √ 三維場景渲染:表示用戶視野、控制可視空間、裁剪、三維對象創(chuàng)建、透視; √ 通過光照和層次結構模型產(chǎn)生更真實的效果; √ 高級技巧:對象操作,HUD、混合、著色器切換等等; √ 極具價值的附錄,涵蓋了從坐標系統(tǒng)到矩陣、從著色器加載到瀏覽器設置等諸多關鍵知識點。
關于作者
Kouichi Matsuda 博士是多媒體產(chǎn)品用戶界面和用戶體驗設計方面的專家。他先后供職于日本電氣(NEC)、索尼(Sony) 研發(fā)中心、索尼(Sony) 計算機科學實驗室,曾經(jīng)做過產(chǎn)品研發(fā),也做過科學研究,最終回到產(chǎn)品研發(fā)的崗位。目前,他是用戶體驗和人機交互領域的首席研究員,負責多款消費類電子產(chǎn)品的設計。他曾經(jīng)設計了社交三維虛擬世界“PAW”,也曾經(jīng)參與過VRML97(ISO/IEC 14772-1:1997) 標準的開發(fā)工作,在VRML和X3D(WebGL 的前身) 社區(qū)中仍然非常活躍。他撰寫過15 本計算機技術的書籍,并翻譯過25 本相關書籍。他專長于用戶體驗、用戶界面、人機交互、自然語言處理和面向娛樂的網(wǎng)絡設備,以及接口代理系統(tǒng)等領域。他不僅對技術領域的新鮮事物充滿熱情,還熱衷于溫泉、夏季的海灘、紅酒和漫畫(為此他已經(jīng)沉迷于繪制插畫一段時間了)。他在東京大學工程系獲得了博士學位,你可以通過WebGL.prog.guide@gmail.com 聯(lián)系他。
Rodger Lea 博士是卑詩大學媒體與圖像跨學科中心的兼職教授,對多媒體和分布式計算等領域很感興趣。他和他帶領的研究小組在學術和工業(yè)領域耕耘超過20 年,參與制定了VRML97 標準,開發(fā)了多媒體操作系統(tǒng)、可交互數(shù)字電視原型,并領導了家用多媒體網(wǎng)絡標準的制定工作。他發(fā)表了60 多篇學術論文,著有3 本技術書籍,并擁有12 項專利。目前,他的研究集中在探索發(fā)展中的互聯(lián)網(wǎng),但他仍然對有關多媒體和圖形學的一切抱有熱情。
關于譯者 關于作者
Kouichi Matsuda 博士是多媒體產(chǎn)品用戶界面和用戶體驗設計方面的專家。他先后供職于日本電氣(NEC)、索尼(Sony) 研發(fā)中心、索尼(Sony) 計算機科學實驗室,曾經(jīng)做過產(chǎn)品研發(fā),也做過科學研究,最終回到產(chǎn)品研發(fā)的崗位。目前,他是用戶體驗和人機交互領域的首席研究員,負責多款消費類電子產(chǎn)品的設計。他曾經(jīng)設計了社交三維虛擬世界“PAW”,也曾經(jīng)參與過VRML97(ISO/IEC 14772-1:1997) 標準的開發(fā)工作,在VRML和X3D(WebGL 的前身) 社區(qū)中仍然非;钴S。他撰寫過15 本計算機技術的書籍,并翻譯過25 本相關書籍。他專長于用戶體驗、用戶界面、人機交互、自然語言處理和面向娛樂的網(wǎng)絡設備,以及接口代理系統(tǒng)等領域。他不僅對技術領域的新鮮事物充滿熱情,還熱衷于溫泉、夏季的海灘、紅酒和漫畫(為此他已經(jīng)沉迷于繪制插畫一段時間了)。他在東京大學工程系獲得了博士學位,你可以通過WebGL.prog.guide@gmail.com 聯(lián)系他。
Rodger Lea 博士是卑詩大學媒體與圖像跨學科中心的兼職教授,對多媒體和分布式計算等領域很感興趣。他和他帶領的研究小組在學術和工業(yè)領域耕耘超過20 年,參與制定了VRML97 標準,開發(fā)了多媒體操作系統(tǒng)、可交互數(shù)字電視原型,并領導了家用多媒體網(wǎng)絡標準的制定工作。他發(fā)表了60 多篇學術論文,著有3 本技術書籍,并擁有12 項專利。目前,他的研究集中在探索發(fā)展中的互聯(lián)網(wǎng),但他仍然對有關多媒體和圖形學的一切抱有熱情。
關于譯者
謝光磊,畢業(yè)于南京大學,目前為中科院在讀碩士,即將成為淘寶UED 的一名前端工程師。因一次偶然的機會接觸WebGL 而對其萌生興趣,并愿意持久深入地研究這項技術。個人站點為 www.xieguanglei.com。
第1 章 WebGL 概述
WebGL 的優(yōu)勢
使用文本編輯器開發(fā)三維應用
輕松發(fā)布三維圖形程序
充分利用瀏覽器的功能
學習和使用WebGL 很簡單
WebGL 的起源
WebGL 程序的結構
總結
第2 章 WebGL 入門
Canvas 是什么?
使用標簽
DrawRectanglejs
最短的WebGL 程序:清空繪圖區(qū)
HTML 文件(HelloCanvashtml)
第1 章 WebGL 概述
WebGL 的優(yōu)勢
使用文本編輯器開發(fā)三維應用
輕松發(fā)布三維圖形程序
充分利用瀏覽器的功能
學習和使用WebGL 很簡單
WebGL 的起源
WebGL 程序的結構
總結
第2 章 WebGL 入門
Canvas 是什么?
使用標簽
DrawRectanglejs
最短的WebGL 程序:清空繪圖區(qū)
HTML 文件(HelloCanvashtml)
JavaScript 程序(HelloCanvasjs)
用示例程序做實驗
繪制一個點(版本1)
HelloPoint1html
HelloPoint1js
著色器是什么?
使用著色器的WebGL 程序的結構
初始化著色器
頂點著色器
片元著色器
繪制操作
WebGL 坐標系統(tǒng)
用示例程序做實驗
繪制一個點(版本2)
使用attribute 變量
示例程序(HelloPoint2js)
獲取attribute 變量的存儲位置
向attribute 變量賦值
glvertexAttrib3f() 的同族函數(shù)
用示例程序做實驗
通過鼠標點擊繪點
示例程序(ClickedPointsjs)
注冊事件響應函數(shù)
響應鼠標點擊事件
用示例程序做實驗
改變點的顏色
示例程序(ColoredPointsjs)
uniform 變量
獲取uniform 變量的存儲地址
向uniform 變量賦值
gluniform4f() 的同族函數(shù)
總結
第3 章 繪制和變換三角形
繪制多個點
示例程序(MultiPointjs)
使用緩沖區(qū)對象
創(chuàng)建緩沖區(qū)對象(glcreateBuffer())
綁定緩沖區(qū)(glbindBuffer())
向緩沖區(qū)對象中寫入數(shù)據(jù)(glbufferData())
類型化數(shù)組
將緩沖區(qū)對象分配給attribute 變量(glvertexAttribPointer())
開啟attribute 變量(glenableVertexAttribArray())
gldrawArrays() 的第2 個和第3 個參數(shù)
用示例程序做實驗
Hello Triangle
示例程序(HelloTrianglejs)
基本圖形
用示例程序做實驗
Hello Rectangle(HelloQuad)
用示例程序做實驗
移動、旋轉和縮放
平移
示例程序(TranslatedTrianglejs)
旋轉
示例程序(RotatedTrianglejs)
變換矩陣:旋轉
變換矩陣:平移
4×4 的旋轉矩陣
示例程序(RotatedTriangle_Matrixjs)
平移:相同的策略
變換矩陣:縮放
總結
第4 章 高級變換與動畫基礎
平移,然后旋轉
矩陣變換庫:cuon-matrixjs
示例程序(RotatedTriangle_Matrix4js)
復合變換
示例程序(RotatedTranslatedTrianglejs)
用示例程序做實驗
動畫
動畫基礎
示例程序(RotatingTrianglejs)
反復調用繪制函數(shù)(tick())
按照指定的旋轉角度繪制三角形(draw())
請求再次被調用(requestAnimationFrame())
更新旋轉角(animate())
用示例程序做實驗
總結
第5 章 顏色與紋理
將非坐標數(shù)據(jù)傳入頂點著色器
示例程序(MultiAttributeSizejs)
創(chuàng)建多個緩沖區(qū)對象
glvertexAttribPointer() 的步進和偏移參數(shù)
示例程序(MultiAttributeSize_Interleavedjs)
修改顏色(varying 變量)
示例程序(MultiAttributeColorjs)
用示例程序做實驗
彩色三角形(ColoredTrianglejs)
幾何形狀的裝配和光柵化
調用片元著色器
用示例程序做實驗
varying 變量的作用和內(nèi)插過程
在矩形表面貼上圖像
紋理坐標
將紋理圖像粘貼到幾何圖形上
示例程序(TexturedQuadjs)
設置紋理坐標(initVertexBuffers())
配置和加載紋理(initTextures())
為WebGL 配置紋理(loadTexture())
圖像Y 軸反轉
激活紋理單元(glactiveTexture())
綁定紋理對象(glbindTexture())
配置紋理對象的參數(shù)(gltexParameteri())
將紋理圖像分配給紋理對象(gltexImage2D())
將紋理單元傳遞給片元著色器(gluniform1i())
從頂點著色器向片元著色器傳輸紋理坐標
在片元著色器中獲取紋理像素顏色(texture2D())
用示例程序做試驗
使用多幅紋理
示例程序(MultiTexturejs)
總結
第6 章 OpenGL ES 著色器語言(GLSL ES)
回顧:基本著色器代碼
GLSL ES 概述
你好,著色器!
基礎
執(zhí)行次序
注釋
數(shù)據(jù)值類型(數(shù)值和布爾值)
變量
GLSL ES 是強類型語言
基本類型
賦值和類型轉換
運算符
矢量和矩陣
賦值和構造
訪問元素
運算符
結構體
賦值和構造
訪問成員
運算符
數(shù)組
取樣器(紋理)
運算符優(yōu)先級
程序流程控制:分支和循環(huán)
if 語句和if-else 語句
for 語句
continue、break 和discard 語句
函數(shù)
規(guī)范聲明
參數(shù)限定詞
內(nèi)置函數(shù)
全局變量和局部變量
存儲限定字
const 變量
Attribute 變量
uniform 變量
varying 變量
精度限定字
預處理指令
總結
第7 章 進入三維世界
立方體由三角形構成
視點和視線
視點、觀察目標點和上方向
示例程序(LookAtTrianglesjs)
LookAtTrianglesjs 與RotatedTriangle_Matrix4js
從指定視點觀察旋轉后的三角形
示例程序(LookAtRotatedTrianglesjs)
用示例程序做實驗
利用鍵盤改變視點
示例程序(LookAtTrianglesWithKeysjs)
獨缺一角
可視范圍(正射類型)
可視空間
定義盒狀可視空間
示例程序(OrthoViewhtml)
示例程序(OrthoViewjs)
JavaScript 修改HTML 元素
頂點著色器的執(zhí)行流程
修改near 和far 值
補上缺掉的角(LookAtTrianglesWithKeys_ViewVolumejs)
用示例程序做實驗
可視空間(透視投影)
定義透視投影可視空間
示例程序(perspectiveviewjs)
投影矩陣的作用
共冶一爐(模型矩陣、視圖矩陣和投影矩陣)
示例程序(PerspectiveView_mvpjs)
用示例程序做實驗
正確處理對象的前后關系
隱藏面消除
示例程序(DepthBufferjs)
深度沖突
立方體
通過頂點索引繪制物體
示例程序(HelloCubejs)
向緩沖區(qū)中寫入頂點的坐標、顏色與索引
為立方體的每個表面指定顏色
示例程序(ColoredCubejs)
用示例程序做實驗
總結
第8 章 光照
光照原理
光源類型
反射類型
平行光下的漫反射
根據(jù)光線和表面的方向計算入射角
法線:表面的朝向
示例程序(LightedCubejs)
環(huán)境光下的漫反射
示例程序(LightedCube_ambientjs)
運動物體的光照效果
魔法矩陣:逆轉置矩陣
示例程序(LightedTranslatedRotatedCubejs)
點光源光
示例程序(PointLightedCubejs)
更逼真:逐片元光照
示例程序(PointLightedCube_perFragmentjs)
總結
第9 章 層次模型
多個簡單模型組成的復雜模型
層次結構模型
單關節(jié)模型
示例程序(JointModejs)
繪制層次模型(draw())
多節(jié)點模型
示例程序(MultiJointModeljs)
繪制部件(drawBox())
繪制部件(drawSegments())
著色器和著色器程序對象:initShaders() 函數(shù)的作用
創(chuàng)建著色器對象(glcreateShader())
指定著色器對象的代碼(glshaderSource())
編譯著色器(glcompileShader())
創(chuàng)建程序對象(glcreateProgram())
為程序對象分配著色器對象(glattachShader())
連接程序對象(gllinkProgram())
告知WebGL 系統(tǒng)所使用的程序對象(gluseProgram())
initShaders() 函數(shù)的內(nèi)部流程
總結
第10 章 高級技術
用鼠標控制物體旋轉
如何實現(xiàn)物體旋轉
示例程序(RotateObjectjs)
選中物體
如何實現(xiàn)選中物體
示例程序(PickObjectjs)
選中一個表面
示例程序(PickFacejs)
HUD(平視顯示器)
如何實現(xiàn)HUD
示例程序(HUDhtml)
示例程序(HUDjs)
在網(wǎng)頁上方顯示三維物體
霧化(大氣效果)
如何實現(xiàn)霧化
示例程序(Fogjs)
使用w 分量(Fog_wjs)
繪制圓形的點
如何實現(xiàn)圓形的點
示例程序(RoundedPointjs)
α 混合
如何實現(xiàn)α 混合
示例程序(LookAtBlendedTrianglesjs)
混合函數(shù)
半透明的三維物體(BlendedCubejs)
透明與不透明物體共存
切換著色器
如何實現(xiàn)切換著色器
示例程序(ProgramObjectjs)
渲染到紋理
幀緩沖區(qū)對象和渲染緩沖區(qū)對象
如何實現(xiàn)渲染到紋理
示例程序(FramebufferObjectjs)
創(chuàng)建幀緩沖區(qū)對象(glcreateFramebuffer())
創(chuàng)建紋理對象并設置其尺寸和參數(shù)
創(chuàng)建渲染緩沖區(qū)對象(glcreateRenderbuffer())
綁定渲染緩沖區(qū)并設置其尺寸(glbindRenderbuffer(),
glrenderbufferStorage())
將紋理對象關聯(lián)到幀緩沖區(qū)對象(glbindFramebuffer(),
glframebufferTexture2D())
將渲染緩沖區(qū)對象關聯(lián)到幀緩沖區(qū)對象(glframebufferRenderbuffer())
檢查幀緩沖區(qū)的配置(glcheckFramebufferStatus())
在幀緩沖區(qū)進行繪圖
繪制陰影
如何實現(xiàn)陰影
示例程序(Shadowjs)
提高精度
示例程序(Shadow_highpjs)
加載三維模型
OBJ 文件格式
MTL 文件格式
示例程序(OBJViewerjs)
自定義類型對象
示例程序(OBJViewerjs 解析數(shù)據(jù)部分)
響應上下文丟失
如何響應上下文丟失
示例程序(RotatingTriangle_contextLostjs)
總結
附錄A WebGL 中無須交換緩沖區(qū)
附錄B GLSL ES 10 內(nèi)置函數(shù)
角度和三角函數(shù)
指數(shù)函數(shù)
通用函數(shù)
幾何函數(shù)
矩陣函數(shù)
矢量函數(shù)
紋理查詢函數(shù)
附錄C 投影矩陣
正射投影矩陣
透視投影矩陣
附錄D WebGL/OpenGL :左手還是右手坐標系?
示例程序(CoordinateSystemjs)
隱藏面消除和裁剪坐標系統(tǒng)
裁剪坐標系和可視空間
什么是對的?
總結
附錄E 逆轉置矩陣
附錄F 從文件中加載著色器
附錄G 世界坐標系和本地坐標系
本地坐標系
世界坐標系
變換與坐標系
附錄H WebGL 的瀏覽器設置
WebGL 是一項用以在瀏覽器中繪制、顯示三維計算機圖形(“三維圖形”),并與之交互的技術。曾經(jīng)只有高端的計算機或專門的游戲終端才能渲染三維圖形,因為這需要大量復雜的編程才能實現(xiàn),然而隨著個人計算機,以及——更重要的——瀏覽器的性能的提高,使用網(wǎng)頁技術渲染三維圖形也已經(jīng)成為可能。本書全面講授了WebGL 技術,帶領讀者一步一個腳印地編寫WebGL 程序。和OpenGL 與Direct3D 不同,WebGL 程序存在于網(wǎng)頁中,可以在瀏覽器里直接執(zhí)行,而不必安裝任何特殊的插件或庫。因此,你只需要最普通的計算機環(huán)境,就可以開始進行開發(fā)或運行示例程序;而且,一切都是基于網(wǎng)頁的,你可以方便地將WebGL 程序作為網(wǎng)頁發(fā)布出去。此外,由于WebGL 是基于網(wǎng)頁的,所以該技術的愿景之一,就是同一個程序能夠通過瀏覽器運行在多種設備上,比如智能手機、平板電腦、游戲終端等。這份遠大的野心,意味著WebGL 技術期望對開發(fā)者社區(qū)產(chǎn)生深遠的影響,并在不久的將來成為圖形開發(fā)的最佳選擇之一。
本書的讀者群
在寫本書時,我希望本書的讀者群主要由兩類人構成:希望在網(wǎng)頁中加入三維圖形的Web 開發(fā)者,以及希望將三維圖形搬上網(wǎng)頁環(huán)境的三維圖形開發(fā)者。如果你是前一類讀者,即Web 開發(fā)者,你可能對標準的Web 技術,如HTML 和JavaScript,已經(jīng)很熟悉了,你希望知道如何向網(wǎng)頁或Web 程序中插入三維圖形,那么WebGL 將會向你提供簡單且強大的解決方案,你可以使用三維圖形來增強Web 程序的用戶界面(UI),或者開發(fā)更復雜的三維程序,比如運行在瀏覽器中的三維網(wǎng)頁游戲。
如果你是第二類目標讀者群中的一員,你可能已經(jīng)具有使用主流三維應用程序接口(API),如Direct3D 或OpenGL 進行開發(fā)的經(jīng)驗,你希望知道如何在網(wǎng)頁環(huán)境中應用這些知識。我想你一定對開發(fā)出能夠在現(xiàn)代瀏覽器中運行的復雜三維程序更感興趣。
然而,這本書也適用于更加廣泛的讀者群。因為本書假定讀者不具有任何關于二維或三維圖形編程的背景,所以幾乎是手把手地向讀者傳授WebGL 的特性。因此,我想以下讀者可能也會對本書感興趣:
y 所有希望了解網(wǎng)頁技術與圖形技術交集的程序員;
y 學習二維或三維圖形學的學生,因為WebGL 只需要一個瀏覽器即可上手,無須
安裝一整套開發(fā)環(huán)境。
y 探索最前沿技術,試圖在安卓手機、iPhone 等移動設備的最新版瀏覽器中有所作
為的Web 開發(fā)者。
本書涵蓋的內(nèi)容
本書涵蓋了WebGL 1.0 API 包含的幾乎所有的JavaScript 方法,你可以學到WebGL、HTML、JavaScript 是如何聯(lián)系的,如何建立和運行WebGL 程序,如何使用JavaScript 控制復雜的三維“著色器”程序。本書詳細講述了如何編寫頂點著色器和片元著色器,如何實現(xiàn)該機的渲染技術,如逐頂點光照、陰影、基本的交互操作(如選中三維物體)等。
本書的每一章將開發(fā)若干個可用的,具有一定功能的WebGL 示例程序,并通過這些示例程序介紹WebGL 的關鍵特性。在讀完本書之后,你就能夠編寫出能夠充分利用瀏覽器的編程能力和圖形硬件的WebGL 程序。
本書的結構
本書一步一步地介紹了WebGL API 以及相關的Web API,以幫助你建立起關于WebGL 的知識結構。
第1 章——WebGL 概述
這一章簡要介紹了WebGL,討論了WebGL 的歷史起源,概括了它的一些關鍵特性和優(yōu)點。這一章還介紹了WebGL 與HTML5 以及 JavaScript 的關系,介紹了我們可以使用哪些瀏覽器開始探索WebGL。
第2 章——WebGL 入門
這一章通過建立幾個示例程序,依次介紹了元素和WebGL 的核心函數(shù)。每個示例都是用JavaScript 編寫的,并使用WebGL 在網(wǎng)頁上繪制一個簡單的形狀。示例程序突出了以下幾點:(1)WebGL 如何使用元素并在其上繪圖;(2)HTML 文件和用JavaScript 編寫的WebGL 代碼文件的連接;(3) 簡單的WebGL 繪圖函數(shù);(4) 著色器程序在WebGL 中的地位。
第3 章——繪制和變換三角形
這一章在之前的基礎上,探索了如何繪制較為復雜的圖形,如何操作三維空間中的這些圖形。這一章主要包括:(1) 三角形的關鍵作用,以及WebGL 對繪制三角形的支持;(2)使用多個三角形繪制出其他圖形;(3) 使用方程對三角形進行基本的變換,如平移、旋轉和縮放等;(4) 矩陣可以簡化變換的運算。
第4 章——高級變換和動畫基礎
這一章將更加深入地探索變換的原理,并開始將變換用于動畫中。你將:(1) 了解一個矩陣變換庫,該庫將矩陣變換的數(shù)學運算細節(jié)隱藏了起來;(2) 使用矩陣庫將多次變換組合起來;(3) 在矩陣庫的幫助下,探索如何實現(xiàn)簡單的動畫。這些技術是構建復雜WebGL 程序的基石,在后面幾章的示例程序中都會用到。
第5 章——顏色和紋理
這一章在之前幾章的基礎上,進一步深入研究了以下三個問題:(1) 除了頂點坐標數(shù)據(jù),我們還可以將顏色信息等其他數(shù)據(jù)傳入頂點著色器;(2) 頂點著色器和片元著色器之間的光柵化過程,將圖形轉化為了片元;(3) 如何將圖像(或紋理)貼到圖形或模型的表面。這一章是有關WebGL 核心功能的最后一章。
第6 章——OpenGL ES 著色器語言(GLSL ES)
這一章不涉及WebGL 示例程序,而是詳細介紹了OpenGL ES 著色器語言(GLSL ES)的核心特性,包括:(1) 數(shù)據(jù)、變量、變量類型;(2) 矢量、矩陣、結構體、數(shù)組和取樣器;(3) 運算符、流程控制和函數(shù);(4)attribute 變量、uniform 變量和varying 變量;(5)精度限定字;(6) 預處理過程和編程準則。在這一章的最后,你將對GLSL ES 有很好的理解,并學會使用該語言來編寫各種著色器。
第7 章——進入三維世界
這一章將帶領讀者首次進入三維世界,探索如何將以前學到的一切從二維空間搬到三維空間中。具體地,你將探索:(1) 如何在三維空間中表示觀察者;(2) 如何控制可視的三維空間體積;(3) 裁剪;(4) 物體的前后關系;(5) 繪制一個三維物體——立方體。所有這些問題都會對三維場景的渲染和最終呈現(xiàn)給用戶的樣子產(chǎn)生重大的影響。為了構建三維場景,深入理解并掌握它們是必須的。
第8 章——光照
這一章主要研究如何實現(xiàn)光照,研究了不同類型的光源及其對三維場景產(chǎn)生的效果。如果想要使三維場景逼真,光照是必需的,因為光照會增強場景的深度感。
本章討論了以下幾個關鍵點:(1) 著色、陰影和不同類型的光源產(chǎn)生的光,包括點光源光、平行光和環(huán)境光;(2) 三維場景中兩種主要的反射光類型:漫反射和環(huán)境反射;(3)著色的細節(jié),以及如何實現(xiàn)光照效果時場景更像是三維的。
第9 章——層次模型
這一章是關于如何使用WebGL 的核心特性的最后一章。在這一章結束時,你將掌握WebGL 的所有基礎知識,并完全能夠創(chuàng)建逼真和可交互的三維場景了。這一章的重點是層次模型。層次模型能夠使復雜模型,如游戲角色、機器人,甚至是真人模型產(chǎn)生動作,而不僅僅是生硬的立方體。
第10 章——高級技術
這一章在整本書的基礎上,介紹了若干有用的高級技術,提供了一些關鍵的工具,幫助你構建出可交互的、令人驚嘆的三維圖形。每一項技術都通過一個完整的示例來展示,你可以在自己的WebGL 程序中重用其中的代碼。
附錄A——WebGL 無須交換緩沖區(qū)
這篇附錄解釋了為什么WebGL 無須像OpenGL 那樣交換緩沖區(qū)。
附錄B——GLSL ES 1.0 內(nèi)置函數(shù)
這篇附錄提供了一份包含所有OpenGL ES 著色器語言內(nèi)置函數(shù)的參考列表。
附錄C——投影矩陣
這篇附錄提供了Matrix4.setOrtho() 函數(shù)和Matrix4.setPerspective() 函數(shù)生成的投影矩陣。
附錄D——WebGL/OpenGL :左手還是右手坐標系?
這篇附錄介紹了WebGL 和OpenGL 的內(nèi)在坐標系統(tǒng),并從技術上解釋了為什么我們說WebGL 和OpenGL 對采取左手坐標系或右手坐標系是中立的。
附錄E——逆轉值矩陣
這篇附錄解釋了模型矩陣的逆轉值矩陣為什么可以用來變換法向量。
附錄F——從文件中加載著色器
這篇附錄解釋了如何從文件中加載著色器程序。
附錄G——世界坐標系和本地坐標系
這篇附錄介紹了兩種不同的坐標系統(tǒng),以及如何在三維圖形中使用它們。
附錄H——關于WebGL 的瀏覽器設置
這篇附錄介紹了瀏覽器的高級設置方法,以確保WebGL 程序能夠正確運行,以及程序不能正確運行時的應對方法。
支持WebGL 的瀏覽器
在撰寫本書之時,WebGL 被Chrome、Firefox、Safari、Opera 瀏覽器支持。遺憾的是,有一些瀏覽器如IE9(Microsoft Internet Explorer)并不支持WebGL。在本書中,我們使用Google 發(fā)布的Chrome 瀏覽器。Chrome 不僅支持WebGL,還支持一些有用的特性,如調試WebGL 的控制臺函數(shù)。我們已經(jīng)在以下環(huán)境中檢查過本書的所有示例程序,都能夠正確運行。在任何支持WebGL 的瀏覽器中,這些程序也應當能夠正確運行。
表P.1 PC 環(huán)境
瀏覽器 Chrome(25.0.1364.152 m)
操作系統(tǒng) Windows7 & 8
顯卡 NVIDIA Quadro FX 380,NVDIA GT X 580,NVDIA GeForce GTS 450,Mobile Intel
4 Series Express Chipset Family,AMD Radeon HD 6970
參考這個頁面:www.khronos.org/webgl/wiki/BlacklistsAndWhitelists,以獲取最新的、關于可能導致問題的硬件列表。
為了不受阻礙地開始學習本書,你應該去下載Chrome(或者你中意的其他瀏覽器),然后進入本書的幫助網(wǎng)站https://sites.google.com/site/webglbook/。
在第3 章,點擊示例程序文件HelloTriangle.html,如果你看到如圖P.1 所示的紅色三角形,就說明WebGL 正常工作了。
圖P.1 加載HelloTriangle 顯示紅色三角形
如果你沒有看到紅色三角形,那么請參考附錄H,改變你的瀏覽器設置以加載WebGL 程序。
示例程序和相關鏈接
本書所有的示例程序都可以在幫助站點上找到。出版社的官方站點位于www.informit.com/title/9780321902924, 而作者的站點則位于https://sites.google.com/site/webglbook。
后一個站點包含了本書所有示例程序的鏈接,你可以點擊鏈接并直接運行每個程序。
如果你想修改示例程序,可以從上述任意一個站點下載包含所有本書所有示例程序的壓縮文件到你自己的磁盤上。你會發(fā)現(xiàn)每個程序都包含一個HTML 文件和一個相應的JavaScript 文件,二者在同一個文件夾下。比如,示例程序HelloTriangle,就包含HelloTriangle.html 和HelloTriangle.js。雙擊HelloTriangle.html 就可以運行該程序。
排版約定
本書遵循以下排版約定:
y 粗體Bold——術語或重要詞匯首次出現(xiàn)。
y 斜體Italic——函數(shù)參數(shù)名、或引用名、程序名或文件名。
y Monospace 字體——示例代碼、方法、函數(shù)、變量、命令行選項、JavaScript 對象名稱、HTML 標簽名稱。
致謝
在撰寫本書(包括最初的日文版和后來的英文版)的過程中,我們有幸接受了很多才華橫溢的同仁的幫助。
Takafumi Kanda 為本書提供了大量的代碼示例和程序,如果沒有他,這本書不可能完成。Yasuko Kikuchi、Chie Onuma 和Yuichi Nishizawa 為本書的早期版本提供了很多有價值的反饋,尤其是Kikuchi 女士的一條極富遠見建議,使我們完全重寫了好幾節(jié)內(nèi)容,大大充實了本書。Hiroyuki Tanaka 和Kazsuhira Oonishi(iLinx) 為示例程序提供了幫助,Teruhisa Kamachi 和Tetsuo Yoshitani 為本書關于HTML5 和JavaScript 的章節(jié)提供了幫助。WebGL 工作小組,尤其是Ken Russell(Google),Chris Marin(Apple) 和Dan Ginsburg(AMD) 回答了很多技術問題。我們的工作也有幸受到Khronos 小組的主席Neil Trevett 的認可,同時也感謝幫助我們聯(lián)系上Trevett 先生和WebGL 工作小組的Hitoshi Kasai(MIACIS 的社長)。此外,還需要感謝Xavier Michel 和Makoto Sato( 上智大學),他們?yōu)楸緯鴱娜照Z翻譯為英語提供了巨大的幫助。而Jeff Gilbert、Rick Rafey 和Daniel Haehn 則仔細地審閱了本書的英文版,并給出了極好的建議和反饋。最后,我們還從個人角度感謝Laura Lewin 和Olivia Basegio( 培生) 為順利出版本書所作的組織工作。
我們對培生集團出版的“紅寶書”(OpenGL Programming Guide) 和“金寶書”(OpenGL ES 2.0 Programming Guide) 的所有作者致敬,如果沒有那兩本書,這本書也無從談起。
我們希望這本書的出版,如果可能的話,能夠略表寸心。
關于作者
Kouichi Matsuda 博士是多媒體產(chǎn)品用戶界面和用戶體驗設計方面的專家。他先后供職于日本電氣(NEC)、索尼(Sony) 研發(fā)中心、索尼(Sony) 計算機科學實驗室,曾經(jīng)做過產(chǎn)品研發(fā),也做過科學研究,最終回到產(chǎn)品研發(fā)的崗位。目前,他是用戶體驗和人機交互領域的首席研究員,負責多款消費類電子產(chǎn)品的設計。他曾經(jīng)設計了社交三維虛擬世界“PAW”,也曾經(jīng)參與過VRML97(ISO/IEC 14772-1:1997) 標準的開發(fā)工作,在VRML和X3D(WebGL 的前身) 社區(qū)中仍然非;钴S。他撰寫過15 本計算機技術的書籍,并翻譯過25 本相關書籍。他專長于用戶體驗、用戶界面、人機交互、自然語言處理和面向娛樂的網(wǎng)絡設備,以及接口代理系統(tǒng)等領域。他不僅對技術領域的新鮮事物充滿熱情,還熱衷于溫泉、夏季的海灘、紅酒和漫畫(為此他已經(jīng)沉迷于繪制插畫一段時間了)。他在東京大學工程系獲得了博士學位,你可以通過WebGL.prog.guide@gmail.com 聯(lián)系他。
Rodger Lea 博士是卑詩大學媒體與圖像跨學科中心的兼職教授,對多媒體和分布式計算等領域很感興趣。他和他帶領的研究小組在學術和工業(yè)領域耕耘超過20 年,參與制定了VRML97 標準,開發(fā)了多媒體操作系統(tǒng)、可交互數(shù)字電視原型,并領導了家用多媒體網(wǎng)絡標準的制定工作。他發(fā)表了60 多篇學術論文,著有3 本技術書籍,并擁有12 項專利。目前,他的研究集中在探索發(fā)展中的互聯(lián)網(wǎng),但他仍然對有關多媒體和圖形學的一切抱有熱情。
關于譯者
謝光磊,畢業(yè)于南京大學,目前為中科院在讀碩士,即將成為淘寶UED 的一名前端工程師。因一次偶然機會接觸WebGL 而對其萌生興趣,并愿意持久深入地研究這項技術。
個人站點為www.xieguanglei.com。
……