《WebGL入门指南》——第2章,第2.3节一个简单的Three.js网页

简介:

本节书摘来自异步社区《WebGL入门指南》一书中的第2章,第2.3节一个简单的Three.js网页,作者 【美】Tony Parisi,更多章节内容可以访问云栖社区“异步社区”公众号查看

2.3 一个简单的Three.js网页
WebGL入门指南
好了,我想现在是时候来编写你的第一个 WebGL 程序了。在这一节中,你会看到上手Three.js是一件相当简单的事情。示例2-1实际上是第1章中的那个绘制正方形示例的翻版,但是将代码从150行精简到30行。由此可见,在使用Three.js之后对代码的压缩量之大。

示例2-1 一个简单的Three.js网页

<!DOCTYPE html>
<html>
<head>
<title>A Simple Three.js Page</title>
     <script src="../libs/Three.js"></script>
     <script>
     function onLoad()
     {
          // 抓取作为Canvas容器的<div>标签
        var container = document.getElementById("container");
        // 创建Three.js渲染器,并添加到<div>标签中
         var renderer = new THREE.WebGLRenderer();
         renderer.setSize(container.offsetWidth, container.offsetHeight);
         container.appendChild( renderer.domElement );
         // 创建Three.js场景
         var scene = new THREE.Scene();
         // 创建相机,并添加到场景中
        var camera = new THREE.PerspectiveCamera( 45, 
             container.offsetWidth / container.offsetHeight, 1, 4000 );
        camera.position.set( 0, 0, 3.3333 );
        scene.add( camera );
        // 创建一个矩形几何体,并添加到场景中
        var geometry = new THREE.PlaneGeometry(1, 1);               
        var mesh = new THREE.Mesh( geometry, 
             new THREE.MeshBasicMaterial( ) );
        scene.add( mesh );
        // 渲染绘制
         renderer.render( scene, camera );
     }
     </script>
</head>
<body onLoad="onLoad();">
    <div id="container" 
       style="width:500px; height:500px; background-color:#000000">
    </div>
</body>
</html>

让我们来遍历一下代码,看看它是如何工作的。

首先,我们使用了

然后我们添加了绘制正方形的代码。整个程序都放在了一个onLoad()函数中,并响应页面的onLoad事件。

在函数体中,我们首先找到页面中用于WebGL渲染的元素,并存储在container变量中。然后,我们初始化了Three.js的渲染器对象renderer。渲染器负责所有的Three.js的绘制工作(当然,是通过WebGL上下文来进行的)。我们构建了渲染器对象,并把它设置成和Canvas容器相同的尺寸,然后作为一个DOM子元素添加到容器中。

然后,我们建立了一个场景(scene)。在Three.js中,场景是最高级的对象,用于容纳所有的其他图形对象(Three.js中的对象都是作为父子层级存在的,我们在稍后的章节中会进行讲解)。当有了场景之后,我们就可以往里面添加其他的对象:一个相机和一个网格。相机定义了我们从哪里观察场景,在这个示例中,我们通过变换相机的位置属性,把它调整到距离原点3.3333个单位的位置(稍微往后一些)。之后,我们又通过Three.js中内置的 PlaneGeometry对象添加了一个1x1大小的矩形。然后通过配置材质来告诉Three.js如何对其进行着色。在这个示例中,我们使用的材质类型是MeshBasicMaterial(使用单一颜色,比如纯白色)。在Three.js中,物体的默认位置都是0,0,0,所以我们的白色矩形将会出现在原点位置。

最后,我们需要渲染整个场景。我们通过调用渲染器的render()方法,来处理场景和相机。

最终的运行结果如图2-1所示。是不是很熟悉呢?


53027a48dd46836b651bd1b1ee552aeab0d3fd62

图2-1 使用Three.js重新编写的绘制正方形的示例

需要注意的是,Three.js紧密的符合了我们在第1章中介绍的图形学的概念:我们处理的是对象(而不是处理那些充满了各种数字的顶点数组),我们通过相机观察场景和物体,使用变换来移动它们,使用材质来定义它们的外观。我们仅仅使用了短短的30行代码,就生成了之前使用原生WebGL编写150行代码才生成的图形。

很多老道的Web开发者也许已经发现了很多令人不快的地方。首先是对于onLoad事件的使用;在后面的章节中,我们将不再使用这种方法来检测页面加载,而是启用jQuery中的强大的ready()方法。其次,整个程序都放在了一个函数中;显然在编写更复杂的应用时我们无法再这么做。在之后的章节中,我会介绍一个非常简单的框架,以便使用Three.js来编写多模块应用。那我为什么还要如此而为呢?这是因为我想要尝试保证尽可能少的改动代码块,使得示例尽量清晰简单。所以,各位资深开发者们,请再忍耐一个章节,结构化的代码稍后奉上。

相关文章
|
1月前
|
数据采集 Web App开发 JavaScript
JavaScript爬虫进阶攻略:从网页采集到数据可视化
JavaScript爬虫进阶攻略:从网页采集到数据可视化
|
1月前
|
移动开发 前端开发 JavaScript
编程笔记 html5&css&js 005 网页上都有哪内容、形式和操作
编程笔记 html5&css&js 005 网页上都有哪内容、形式和操作
|
3月前
|
前端开发 JavaScript
百度搜索:蓝易云【用JavaScript和HTML实现一个精美的计算器网页】
该计算器网页使用HTML定义了页面结构,CSS样式使其具有精美的外观,而JavaScript脚本实现了计算器的逻辑。用户可以通过按钮输入数字和操作符,并通过“=”按钮来进行计算,计算结果会显示在文本框中。
40 6
|
3月前
|
JavaScript 前端开发 算法
JavaScript实现网页关灯效果
JavaScript实现网页关灯效果
25 0
|
4月前
|
前端开发 JavaScript
前端js代码一句话模拟Ctrl+A全选网页内容效果document.execCommand(‘selectAll‘);
前端js代码一句话模拟Ctrl+A全选网页内容效果document.execCommand(‘selectAll‘);
|
1月前
|
数据采集 JSON JavaScript
如何处理动态网页(例如使用 JavaScript 生成的内容)?
如何处理动态网页(例如使用 JavaScript 生成的内容)?
15 0
|
1月前
|
JavaScript 前端开发 UED
JS自动跳转手机移动网页
JS自动跳转手机移动网页
454 0
|
1月前
|
前端开发 JavaScript 开发者
编程笔记 html5&css&js 014 网页布局框架
编程笔记 html5&css&js 014 网页布局框架
|
1月前
|
前端开发 搜索推荐 JavaScript
编程笔记 html5&css&js 001 学习编程从网页开始
编程笔记 html5&css&js 001 学习编程从网页开始
|
2月前
|
前端开发 JavaScript API
网页开发者必看!5种JS跳转页面技巧,提升用户交互体验
欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚开始学习前端的读者们打造的。无论你是初学者还是有一些基础的开发者,我们都会在这里为你提供一个系统而又亲切的学习平台。我们以问答形式更新,为大家呈现精选的前端知识点和最佳实践。通过深入浅出的解释概念,并提供实际案例和练习,让你逐步建立起一个扎实的基础。无论是HTML、CSS、JavaScript还是最新的前端框架和工具,我们都将为你提供丰富的内容和实用技巧,帮助你更好地理解并运用前端开发中的各种技术。