上一面讲述了向场景中添加物体对象。这一篇准备把每个功能点细细的讲述一遍,一方面是为了加深自己的理解。另一方面希望能够

帮助到有需要的人。

一、在学习WEBGL的时候,你应该先了解要创建一个WebGL程序需要哪些步骤。就跟弄梅菜扣肉一样,需要哪些步骤。

  • 初始化WebGL绘图上下文
  • 初始化着色器程序
  • 建立模型和数据缓存
  • 完成绘制和动画

这是一个面向过程编程。然而three.js不一样,是一个面向对象编程。主要构建三个对象 scene(场景) camera(相机) renderer(渲染器).。

这三个东西是什么意思呢?听起来完全不懂是啥。举个小列子:就拿电影来说。场景(scene)就好比整个布局空间,相机(camera)相当于

拍摄期。而渲染器相当于(renderer)把拍摄的电影转换成胶卷也就是电脑的屏幕。

场景和空间包含了3D和数据模型,而renderer包含了着色器和WebGL绘图上下文。

二、THREE.JS创建场景,相机,渲染器

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Demo1(three入门第一篇)</title>
</head>
<body> </body>
<script type="text/javascript" src="js/three.js"></script>
<script type="text/javascript">
var width = window.innerWidth, height = window.innerHeight;
var scene = new THREE.Scene(); //创建一个场景
var camera = new THREE.PerspectiveCamera(75,width/height,1,5000); //创建相机
/*
three.js创建相机的方式有很多种,其中最长用的是PerspectiveCamera();
远景相机,相当于人眼观察模式
肯定有人会有疑问,这几个参数是什么意思呢?
第一个 75 是 视角
width / height 相机拍摄面的长宽比,别问为什么这么写,我也没搞清楚。反正设置为窗口
的width/height图形就不会被压变形。
下面两个是近裁剪面。和远裁剪面。
*/
var renderer = new THREE.WebGLRenderer(); //s上一篇用的是CSS3DRenderer
//WebGLrenderer其实是用CANVAS渲染。
renderer.setSize(width,height);
document.getElementsByTagName('body')[0].appendChild(renderer.domElement);
</script>
</html>

电影,场景,胶卷都准备好了,那如何才能展示演员呢?也就是上面一篇说 的如何向场景中添加物体对象呢?

三、添加演员(3D立方体)。

 //演员进场
var geometry = new THREE.BoxGeometry(1,1,1);
//BoxGeometry(); 3D盒子模型。包含了立方体所有顶点和填充面的对象。
var material = new THREE.MeshBasicMaterial({color:'red'});
//有个几何模型,我们需要材料为其上色。我们采用的时候 网孔基础材料MeshBasicMaterial();
var mesh = new THREE.Mesh(geometry,material);
//需要一个网孔,来承载几何模型和材料
scene.add(mesh); //把这个网孔放置到场景中去。 camera.position.z = 5; //调节相机的位置。 renderer.render(scene,camera); //把画面转换成相机,并播放

这样这个演员就入镜了。

四、如何让这个演员动起来呢?

    //懂动起来。
function loop(){
requestAnimationFrame(loop);
mesh.rotation.x += 0.1; //X选择
mesh.rotation.y += 0.1; //Y旋转
renderer.render(scene,camera); //把画面转换成相机,并播放
}
loop();
//解释下requestAnimationFrame这个api
/*
requestAnimationFrame这个函数,它用来替代 setInterval, 这个新接口具备多个优点,
比如浏览器Tab切换后停止渲染以节约资源、
和屏幕刷新同步避免无效刷新、在不支持该接口的浏览器中能安全回退为setInterval。
简直就是动画神奇
*/

演员入镜,并有了,打动效果。第一个小短篇算完成了吧。

五、整个代码(本来想托管到githup上)。发现太慢了。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Demo1(three入门第一篇)</title>
</head>
<body> </body>
<script type="text/javascript" src="js/three.js"></script>
<script type="text/javascript">
var width = window.innerWidth, height = window.innerHeight;
var scene = new THREE.Scene(); //创建一个场景
var camera = new THREE.PerspectiveCamera(75,width/height,1,5000); //创建相机
/*
three.js创建相机的方式有很多种,其中最长用的是PerspectiveCamera();
远景相机,相当于人眼观察模式
肯定有人会有疑问,这几个参数是什么意思呢?
第一个 75 是 视角
width / height 相机拍摄面的长宽比,别问为什么这么写,我也没搞清楚。反正设置为窗口
的width/height图形就不会被压缩。
下面两个是近裁剪面。和远裁剪面。
*/
var renderer = new THREE.WebGLRenderer(); //s上一篇用的是CSS3DRenderer
//WebGLrenderer其实是用CANVAS渲染。
renderer.setSize(width,height);
document.getElementsByTagName('body')[0].appendChild(renderer.domElement); //演员进场
var geometry = new THREE.BoxGeometry(1,1,1);
//BoxGeometry(); 3D盒子模型。包含了立方体所有顶点和填充面的对象。
var material = new THREE.MeshBasicMaterial({color:'red'});
//有个几何模型,我们需要材料为其上色。我们采用的时候 网孔基础材料MeshBasicMaterial();
var mesh = new THREE.Mesh(geometry,material);
//需要一个网孔,来承载几何模型和材料
scene.add(mesh); //把这个网孔放置到场景中去。 camera.position.z = 5; //调节相机的位置。 //懂动起来。
function loop(){
requestAnimationFrame(loop);
mesh.rotation.x += 0.1; //X选择
mesh.rotation.y += 0.1; //Y旋转
renderer.render(scene,camera); //把画面转换成相机,并播放
}
loop();
//解释下requestAnimationFrame这个api
/*
requestAnimationFrame这个函数,它用来替代 setInterval, 这个新接口具备多个优点,
比如浏览器Tab切换后停止渲染以节约资源、
和屏幕刷新同步避免无效刷新、在不支持该接口的浏览器中能安全回退为setInterval。
简直就是动画神奇
*/ </script>
</html>

六、在WebGL中three.js扮演了重要的角色,然而中文api真的少。只有一个一个的慢慢累积。

Three.js入门篇(一)创建一个场景的更多相关文章

  1. 1. web前端开发分享-css,js入门篇

    关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人与人的教育背景与成长环境心理活动都有差别,但就别人的心得再结合自己的特点,然后探索适合自己的学 ...

  2. web前端开发分享-css,js入门篇(转)

    转自:http://www.cnblogs.com/jikey/p/3600308.html 关注前端这么多年,没有大的成就,就入门期间积累了不少技巧与心得,跟大家分享一下,不一定都适合每个人,毕竟人 ...

  3. web前端开发分享-css,js入门篇

    学习没有捷径,但学习是有技巧与方法.   一,css入门篇:   推荐书籍:css哪些事儿,精通css. 理由:css那些事儿,他是一本介绍css基础类的书,是入门的经典读物. 系统的介绍了css的选 ...

  4. Vue.js 入门:从零开始做一个极简 To-Do 应用

    Vue.js 入门:从零开始做一个极简 To-Do 应用 写作时间:2019-12-10版本信息:Vue.js 2.6.10官网文档:https://cn.vuejs.org/ 前言  学习 Vue ...

  5. cocos3.2中如何创建一个场景

    1.可以将一些比较通用的东西放到Common.h中,这是一个.h文件,必须手动添加,且保证在classes目录里 #ifndef __COMMON_H__ #define __COMMON_H__ # ...

  6. 【SSRS】入门篇(一) -- 创建SSRS项目

    原文:[SSRS]入门篇(一) -- 创建SSRS项目 在本篇中,您将学习如何在 SQL Server Data Tools (SSDT) 中创建报表服务器项目. 报表服务器项目用于创建在报表服务器中 ...

  7. Three.js 第一篇:绘制一个静态的3D球体

    第一篇就画一个球体吧 首先我们知道Three.js其实是一个3D的JS引擎,其中的强大之处就在于这个JS框架并不是依托于JQUERY来写的.那么,我们在写这一篇绘制3D球体的文章的时候,应该注意哪些地 ...

  8. Node.js 入门篇

    Node.js 使用C++开发的. Node.js是一个事件驱动服务端JavaScript环境,只要能够安装相应的模块包,就可以开发出需要的服务端程序,如HTTP服务端程序.Socket程序等. No ...

  9. Node.js实战1:创建一个新的Node项目。

    你也许在猜专业的Node开发如何创建一个新项目. 有Npm在 ,这会非常简单. 虽然你可以创建一个JS文件,并执行:node file.js,但我建议你使用npm init来先创建一个node项目,这 ...

随机推荐

  1. 基于bootstrap的文本编辑器组件:Summernote

    Summernote官网地址 :https://summernote.org/ 这是官网的一个例子: <!DOCTYPE html> <html lang="en" ...

  2. dpkg使用记录

    dpkg -l 查看所有已安装的包 grep即可过滤想要的内容 dpkg -r 包名   // 卸载包    -P  完全卸载 可能会有配置文件不能删除  不能删除的重启再卸载即可 dpkg -i 包 ...

  3. css绘制常见的几何图形

    前言:终于我的大一生活结束了,迎来了愉快的暑假,大家都开始了各自的忙碌.一直忙着一些项目的事情,终于决定今天要更新一篇博客了,对上一阶段的学习做简单的总结. 这次我主要总结一下用Css绘制各种形状的技 ...

  4. CSS过渡动画之transition

    O(∩_∩)O~ 这两天在看看CSS的相关内容,关于transition动画感觉很有意思,分享一下. CSS负责给html加效果,自然少不了各种动画,今天介绍一下transition. 概述 看一段比 ...

  5. yum 执行不了, 解决方法

    在执行yum命令时忽然发现出现以下报错: 1 2 3 4 5 # yum list File "/usr/bin/yum", line 30 except KeyboardInte ...

  6. 关于Unity中OnGUI()的简单使用

    有时候想要输出一些数据到屏幕上方便查看,新建一个UI对象又挺麻烦,用OnGUI()在屏幕上直接绘制UI比较方便. GUI.Label(, , , ), “aaa", style); 这条语句 ...

  7. ThreadPoolExecutor 使用说明

    它是一个ExecutorService,使用线程池中的线程执行提交的任务.通常我们使用Executors框架,定义使用. 线程池主要用来解决两类问题:通过缓存一定数量的可用线程,避免频繁的线程创建,销 ...

  8. [C++]值传递和引用传递

    概念 在定义函数时函数括号中的变量名成为形式参数,简称形参或虚拟参数: 在主调函数中调用一个函数时,该函数括号中的参数名称为实际参数,简称实参,实参可以是常量.变量或表达式. 注意: C语言中实参和形 ...

  9. python基础学习笔记(一)

    最好有点c++基础来看,,每天都更新一篇吧 这一篇是一些基础东西 1.运算符2.变量3.基本输入输出4.字符串5.列表6.元组7.字典8.集合9.简单的说下循环啥的 1.运算符 特别的 a / b:为 ...

  10. Nginx笔记(一):安装

    Nginx在安装前需要先安装其所依赖的类库,所以需先行安装好之后再进行Nginx安装. Nginx依赖以下模块: l  gzip模块需要 zlib 库 l  rewrite模块需要 pcre 库 l  ...