《H5和WebGL 3D开发实战详解》PDF下载

  • 购买积分:13 如何计算积分?
  • 作  者:吴亚峰,于复兴,索依娜编著
  • 出 版 社:北京:人民邮电出版社
  • 出版年份:2017
  • ISBN:9787115441010
  • 页数:367 页
图书介绍:本书系统介绍HTML5的基本情况和新特性、介绍WebGL的基本情况,并引导读者完成了WebGL的基础案例。 对用于实现WebGL中可编程渲染管线着色器的着色语言进行了系统介绍,为着色器的高级开发打下坚实的基础。介绍了3D开发的多种投影、变换的原理及实现,同时还详细介绍了点、线段、三角形三大类绘制方式。

第1章 HTML 5开发基础——进入WebGL世界的第一道坎 1

1.1 HTML的发展简史 1

1.1.1 HTML的由来 1

1.1.2 HTML的历史 1

1.2 HTML5概述 2

1.2.1 HTML5的新标准 2

1.2.2 HTML5引入的新特性 2

1.2.3 HTML5现状 3

1.3 初识HTML5 4

1.3.1 HTML5标签简介 4

1.3.2 基础标签 4

1.3.3 格式标签 5

1.3.4 表单标签 10

1.3.5 图像、链接、列表标签 17

1.3.6 表格、元信息等标签 20

1.3.7 HTML5中的全局属性 26

1.3.8 HTML5中的事件 29

1.4 初识CSS 31

1.4.1 CSS简介 31

1.4.2 CSS基础语法 32

1.4.3 如何插入样式表 33

1.4.4 使用CSS样式 33

1.5 初识JavaScript 40

1.5.1 JavaScript的名字和版本 41

1.5.2 准备使用JavaScript 41

1.5.3 使用语句 41

1.5.4 使用变量和类型 42

1.5.5 JavaScript运算符 43

1.5.6 使用数组 44

1.5.7 创建自己的JavaScript对象 45

1.5.8 常用的JavaScript工具 47

1.6 HTML5 Canvas概述 47

1.6.1 文档对象模型(DOM)和Canvas 48

1.6.2 JavaScript与Canvas 48

1.6.3 HTML5 Canvas版“HelloWorld” 48

1.6.4 Canvas上的基础图形 50

1.7 本章小结 51

1.8 习题 52

第2章 初识WebGL 53

2.1 WebGL概述 53

2.1.1 WebGL简介 53

2.1.2 WebGL效果展示 54

2.2 初识WebGL应用 54

2.2.1 WebGL应用案例部署运行步骤简介 55

2.2.2 初识WebGL应用程序 56

2.3 着色器与渲染管线 61

2.3.1 WebGL的渲染管线 61

2.3.2 WebGL中立体物体的构建 66

2.4 本章小结 68

2.5 习题 68

第3章 着色语言 69

3.1 着色语言概述 69

3.2 着色语言基础 70

3.2.1 数据类型简介 70

3.2.2 数据类型的基本使用 73

3.2.3 运算符 74

3.2.4 类型转换 76

3.2.5 限定符 77

3.2.6 流程控制 79

3.2.7 函数的声明与使用 81

3.2.8 片元着色器中浮点变量精度的指定 82

3.2.9 程序的基本结构 82

3.3 特殊的内建变量 83

3.3.1 顶点着色器中的内建变量 83

3.3.2 片元着色器中的内建变量 83

3.4 着色语言的内置函数 84

3.4.1 角度转换与三角函数 85

3.4.2 指数函数 86

3.4.3 常见函数 86

3.4.4 纹理采样函数 88

3.5 本章小结 89

3.6 习题 89

第4章 必知必会的3D开发知识——投影及各种变换 91

4.1 矩阵数学计算工具脚本Matrix 91

4.2 摄像机的设置 92

4.3 两种投影方式 93

4.3.1 正交投影 93

4.3.2 透视投影 97

4.4 各种变换 100

4.4.1 基本变换的相关数学知识 100

4.4.2 平移变换 100

4.4.3 旋转变换 102

4.4.4 缩放变换 103

4.4.5 基本变换的实质 105

4.5 所有变换的完整流程 106

4.6 绘制方式 109

4.6.1 各种绘制方式概览 109

4.6.2 点与线段绘制方式 110

4.6.3 三角形条带与扇面绘制方式 112

4.7 设置合理的视角 116

4.8 卷绕和背面剪裁 120

4.8.1 基本知识 121

4.8.2 一个简单的案例 121

4.9 本章小结 123

4.10 习题 123

第5章 光照效果 125

5.1 曲面物体的构建 125

5.1.1 球体的构建原理 125

5.1.2 案例效果概览 126

5.1.3 具体开发步骤 126

5.2 基本光照效果 129

5.2.1 构建球体的原理 129

5.2.2 环境光 129

5.2.3 散射光 131

5.2.4 镜面光 135

5.2.5 三种光照通道的合成 138

5.3 定位光与定向光 140

5.4 点法向量和面法向量 142

5.5 光照的每顶点计算与每片元计算 144

5.6 本章小结 146

5.7 习题 146

第6章 纹理映射 147

6.1 初识纹理映射 147

6.1.1 基本原理 147

6.1.2 一个简单的案例 148

6.2 纹理拉伸 153

6.2.1 两种拉伸方式概览 153

6.2.2 不同拉伸方式的案例 154

6.3 纹理采样 156

6.3.1 纹理采样简介 157

6.3.2 最近点采样 157

6.3.3 线性纹理采样 158

6.3.4 MIN与MAG采样 159

6.3.5 不同纹理采样方式的案例 159

6.4 mipmap纹理技术 161

6.5 多重纹理与过程纹理 162

6.5.1 案例概览 162

6.5.2 将2D纹理映射到球面上的策略 163

6.5.3 案例的场景结构 164

6.5.4 开发过程 165

6.6 压缩纹理的使用 167

6.6.1 ETC压缩纹理 167

6.6.2 DXT5 169

6.6.3 PVRTC 171

6.7 本章小结 172

6.8 习题 172

第7章 3D模型加载 173

7.1 obj模型文件概述 173

7.1.1 obj文件的格式 173

7.1.2 用3ds Max设计3D模型 174

7.2 加载obj文件 175

7.2.1 加载仅有顶点坐标与面数据的obj文件 175

7.2.2 加载后自动计算面法向量 178

7.2.3 加载后自动计算平均法向量 180

7.2.4 加载纹理坐标 182

7.2.5 加载顶点法向量 184

7.3 本章小结 185

7.4 习题 185

第8章 混合与雾 187

8.1 混合技术 187

8.1.1 混合的基本知识 187

8.1.2 源因子和目标因子 188

8.1.3 简单混合效果案例 189

8.2 地月系云层效果的实现 191

8.3 雾 193

8.3.1 雾的原理与优势 193

8.3.2 雾的简单实现 194

8.4 本章小结 196

8.5 习题 196

第9章 常用3D开发技巧 197

9.1 标志板 197

9.1.1 案例效果与基本原理 197

9.1.2 开发步骤 198

9.2 灰度图地形 201

9.2.1 基本原理 201

9.2.2 普通灰度图地形 202

9.2.3 过程纹理地形 205

9.2.4 mipmap地形 206

9.3 天空盒与天空穹 207

9.3.1 天空盒 207

9.3.2 天空穹 209

9.3.3 天空盒与天空穹的使用技巧 210

9.4 本章小结 211

9.5 习题 211

第10章 渲染出更加酷炫的3D场景——几种剪裁与测试 213

10.1 剪裁测试 213

10.1.1 基本原理与核心代码 213

10.1.2 一个主次视角的简单案例 213

10.2 模板测试 215

10.2.1 基本原理 215

10.2.2 一个简单的案例 217

10.3 任意剪裁平面 218

10.3.1 基本原理 218

10.3.2 茶壶被任意平面剪裁的案例 218

10.4 本章小结 220

10.5 习题 220

第11章 Three.js引擎 221

11.1 Three.js概述 221

11.1.1 Three.js简介 221

11.1.2 Three.js效果展示 222

11.2 初识Three.js应用 222

11.3 Three.js基本组件 224

11.3.1 场景 224

11.3.2 几何对象 226

11.3.3 摄像机 228

11.3.4 光源 232

11.3.5 材质 239

11.4 模型加载 245

11.4.1 Three.js中支持的模型文件格式 246

11.4.2 导入三维格式文件 251

11.4.3 骨骼动画的加载 254

11.5 贴图的使用 258

11.5.1 使用纹理贴图 259

11.5.2 使用法向贴图 260

11.5.3 使用凹凸贴图 261

11.5.4 使用光照贴图制作静态阴影 262

11.5.5 使用高光贴图 264

11.6 粒子系统 265

11.7 二次绘制 269

11.7.1 认识效果组合器 269

11.7.2 FilmPass通道 270

11.7.3 BloomPass通道 271

11.7.4 DotScreenPass通道 272

11.7.5 ShaderPass通道 273

11.8 本章小结 276

11.9 习题 276

第12章 Egret 3D游戏引擎应用开发 277

12.1 Egret入门 277

12.1.1 Egret简介 277

12.1.2 Egret Engine的安装、部署与使用插件 278

12.1.3 使用EgretWing插件调试与开发程序 279

12.1.4 Egret Engine 3D简介 281

12.2 Egret 3D入门 282

12.2.1 创建3D场景 282

12.2.2 使用鼠标事件 285

12.3 天空盒与模型加载 287

12.3.1 Egret 3D中添加天空盒 287

12.3.2 Egret 3D中加载模型 288

12.4 Egret 3D中的纹理与灯光 291

12.4.1 Egret 3D中的纹理应用 291

12.4.2 Egret 3D中的灯光应用 292

12.5 Egret 3D中的骨骼动画 294

12.5.1 导出Egret引擎的骨骼动画 294

12.5.2 使用Egret引擎加载骨骼动画 294

12.6 本章小结 296

12.7 习题 296

第13章 Ammo物理引擎 297

13.1 Ammo物理引擎概述 297

13.2 Ammo中常用类概述 297

13.2.1 btVector3类——三维向量类 298

13.2.2 btTransform类——变换类 298

13.2.3 btRigidBody类——刚体类 299

13.2.4 btDynamicsWorld类——物理世界类 299

13.2.5 btDiscreteDynamicsWorld类——离散物理世界类 300

13.2.6 btSoftRigidDynamicsWorld类——支持模拟软体的物理世界类 300

13.2.7 btCollisionShape类——碰撞形状类 301

13.2.8 btStaticPlaneShape类——静态平面形状 301

13.2.9 btSphereShape类——球体形状类 301

13.2.10 btBoxShape类——长方体盒碰撞形状类 301

13.2.11 btCylinderShape类——圆柱形状类 302

13.2.12 btCapsuleShape类——胶囊形状类 302

13.2.13 btConeShape类——圆锥形状类 302

13.2.14 btCompoundShape类——复合碰撞形状类 302

13.3 简单的物理场景 303

13.3.1 案例运行效果 303

13.3.2 案例的基本结构 303

13.3.3 主要方法的介绍 304

13.4 多种形状刚体的碰撞 306

13.4.1 案例运行效果 306

13.4.2 案例开发过程 307

13.5 旋转的陀螺 308

13.5.1 案例运行效果 308

13.5.2 案例开发过程 308

13.6 触发器——消失的箱子 309

13.6.1 案例运行效果 310

13.6.2 案例开发过程 310

13.7 碰撞过滤——物体碰撞下落 311

13.7.1 案例运行效果 311

13.7.2 案例开发过程 312

13.8 关节的介绍 313

13.8.1 关节的父类——btTypedConstraint类 313

13.8.2 铰链关节——btHingeConstraint类 313

13.8.3 铰链关节的案例——球落门开 314

13.8.4 齿轮关节——btGearConstraint类 316

13.8.5 齿轮关节的案例——转动的齿轮 316

13.8.6 点对点关节——btPoint2PointConstraint类 318

13.8.7 点对点关节的案例——悬挂的物体 318

13.8.8 滑动关节——btSliderConstraint类 320

13.8.9 滑动关节的案例——6个方向的物体滑动 321

13.8.10 六自由度关节——btGeneric6DofConstraint类 323

13.8.11 六自由度关节的案例——掉落的蜘蛛 323

13.9 交通工具类的介绍 326

13.9.1 交通工具类——btRaycastVehicle类 326

13.9.2 交通工具的案例——移动的小车 327

13.10 软体 331

13.10.1 软体帮助类——btSoftBodyHelps类 331

13.10.2 软布案例 332

13.10.3 三角形网格软体案例 334

13.10.4 绳索软体案例 337

13.11 本章小结 339

13.12 习题 339

第14章 休闲类游戏——极地大作战 341

14.1 背景以及功能概述 341

14.1.1 游戏背景概述 341

14.1.2 游戏功能简介 342

14.2 游戏的策划及准备工作 343

14.2.1 游戏的策划 343

14.2.2 游戏的准备工作 343

14.3 游戏的架构 344

14.3.1 各个脚本简介 344

14.3.2 游戏架构简介 345

14.4 网页文件example.html 346

14.5 游戏相关脚本 350

14.5.1 初始化资源脚本 350

14.5.2 键盘事件监听脚本 354

14.5.3 添加模型脚本 356

14.5.4 碰撞检测脚本 360

14.6 游戏中相关工具类脚本概述 363

14.7 游戏中着色器的开发 363

14.7.1 带有光照的着色器 363

14.7.2 不带有光照的简单着色器 365

14.8 游戏的优化与改进 365

参考文献 367