余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

three.js 简介

xiyangw 2022-11-26 15:44 14 浏览 0 评论

threejs的学习

  1. 创建一个基本的场景渲染器:

  2. function init(){

    1. //设置一个场景 var scene = new THREE.Scene();

      //设置相机:

      //横纵比例设置

      var win_w = window.innerWidth;

      var win_h = window.innerHeight;

      var fx = win_w/win_h;

      var camera = new THREE.PerspectiveCamera(70,fx,0.1,1000);

      camera.position.x = -30;

      camera.position.y = 20;

      camera.position.z = 20;

      camera.lookat(scene.position);

      /* 这里你可以添加其他的任何three.js相关物体

      demo eg: /创建一个球体/

      var sphereG = new THREE.SphereGeometry(4,10,10);

      var sphereM =new THREE.MeshBasicMaterial({color:0x7777ff,wireframe:true}); var o_sphere = new THREE.Mesh(sphereG,sphereM);

      scene.add(o_sphere);

      o_sphere.position.x = 20;

      o_sphere.position.y = 4;

      o_sphere.position.z = 2; */

//设置渲染器:

var renderer = new THREE.WebGLRenderer();

renderer.setClearColor(new THREE.Color(0xeeeeee));

renderer.setSize(win_w,win_h);

////把渲染器加入指定DOM中

document.getElementById('output').appendChild(renderer,domElement);

renderer.render(scene,camera);

}

window.onload = init;

解: new THREE.Scene()==>设置一个场景

new THREE.PerspectiveCamera(70,fx,0.1,1000)==>设置一个远景透视相机

PerspectiveCamera( fov, aspect, near, far )

fov — 相机视锥体垂直视角

aspect — 相机视锥体宽高比

near — 相机视锥体近裁剪面

far — 相机视锥体远裁剪面

new THREE.WebGLRenderer()==>设置渲染器为WebGL的渲染器 .

setClearColor(new THREE.Color(0xeeeeee))==>设置渲染器的渲染时的背景色 .

setSize(win_w,win_h)==>设置渲染器的大小

document.getElementById('output').appendChild(renderer,domElement);==>挂载到dom元素上 renderer.render(scene,camera)==render方法开始执行渲染开始带页面

new THREE.MeshBasicMaterial({color:0xff0000,wireframe:false})==>材质的设置 .

color==材质颜色的设置

.wireframe:true/false==>物体材质表现true为实物全显,false为以线的描述显示; new THREE.Mesh(gemotry,material)==>创建一个网格物体 .

position.x==设置物体的x位置 .

position.y==设置物体的y位置 .

position.z==设置物体的z位置

scene.add(obj)==>把创建的物体加入场景中

2.阴影的设置

renderer.shadowMapEnabled = true/false===>渲染器开启阴影设置

mesh.castShadow=true/false==>mesh产生阴影

mesh.receiveShadow=true/false ==mesh接受阴影

3.动画的实现:

实例 requestAnimationFrame(renderScene);

函数的使用; //设置变化的参数

var step = 0; renderScene();

function renderScene(){

// rotate the cube around its axes

cube.rotation.x += 0.02;

cube.rotation.y += 0.02;

cube.rotation.z += 0.02;

 // bounce the sphere up and down
 step += 0.01;
 sphere.position.x = 20 + ( 10 * (Math.cos(step)));
 sphere.position.y = 2 + ( 10 * Math.abs(Math.sin(step)));
 // render using requestAnimationFrame
 requestAnimationFrame(renderScene);
 renderer.render(scene, camera);

}

4.窗口改变时对渲染器的实时设置

// listen to the resize events

window.addEventListener('resize', onResize, false);

function onResize() {

camera.aspect = window.innerWidth / window.innerHeight;

camera.updateProjectionMatrix();

renderer.setSize(window.innerWidth, window.innerHeight);

}

相关推荐

spring利用spring.handlers解析自定义配置(spring validation 自定义)

一、问题我们在spring的xml配置文件里经常定义各种各样的配置(tx、bean、mvc、bean等等)。以及集成第三方框架时,也会看到一些spring之外的配置,例如dubbo的配置、securi...

「Spring源码分析」AOP源码解析(上篇)(spring源码深度解析(第2版))

前言前面写了六篇文章详细地分析了SpringBean加载流程,这部分完了之后就要进入一个比较困难的部分了,就是AOP的实现原理分析。为了探究AOP实现原理,首先定义几个类,一个Dao接口:1&nbs...

Spring 解析注册BeanDefinition这一篇就Over
Spring 解析注册BeanDefinition这一篇就Over

一、简介:学习过Spring框架的人一定都会听过Spring的IoC(控制反转)、DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC、...

2023-03-20 14:53 xiyangw

域、模块、空间、闭包,你真的懂了吗?(模块控制域与作用域的关系)

Javascript有一个特性叫做域。尽管对于初学者来说理解域是有难度的,但我会尽力用最简单的方式让你理解域。理解域能让你的代码更优秀,减少错误,及有助于你做出更强大的模式设计。什么是域域是在运行时,...

这一次搞懂Spring自定义标签以及注解解析原理
这一次搞懂Spring自定义标签以及注解解析原理

前言在上一篇文章中分析了Spring是如何解析默认标签的,并封装为BeanDefinition注册到缓存中,这一篇就来看看对于像context这种自定义标签是如...

2023-03-20 14:53 xiyangw

前端基础进阶(七)-前端工程师最容易出错的问题-this关键字
前端基础进阶(七)-前端工程师最容易出错的问题-this关键字

我们在学习JavaScript的时候,因为对一些概念不是很清楚,但是又会通过一些简洁的方式把它给记下来,那么这样自己记下来的概念和真正的概念产生了很强的偏差.当...

2023-03-20 14:52 xiyangw

深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)
深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)

建议学习:膜拜!阿里内部都在强推的K8S(kubernetes)学习指南,不能再详细了最近也一直在加班,处理项目中的事情,发现问题越多越是感觉自己的能力不足,...

2023-03-20 14:52 xiyangw

Spring 是如何解析 bean 标签的?(spring beans标签)
Spring 是如何解析 bean 标签的?(spring beans标签)

前情回顾上回「SpringIoC容器初始化(2)」说到了Spring如何解析我们定义的<bean>标签,代码跟进了一层又一层,跋山涉水,...

2023-03-20 14:52 xiyangw

快速了解JavaScript文本框操作(javascript文本框代码)
快速了解JavaScript文本框操作(javascript文本框代码)

HTML中使用<input>元素表示单行输入框和<textarea>元素表示多行文本框。HTML中使用的<input&...

2023-03-20 14:51 xiyangw

荐读|30道JavaOOP面试题,可以和面试官扯皮了
荐读|30道JavaOOP面试题,可以和面试官扯皮了

面试是我们每个人都要经历的事情,大部分人且不止一次,今天给大家准备了30道JavaOOP面试题,希望能够帮助到对Java感兴趣的同学,让大家在找工作的时候能够...

2023-03-20 14:51 xiyangw

源码系列——mybatis源码刨析总结,下(mybatis源码分析)
源码系列——mybatis源码刨析总结,下(mybatis源码分析)

接上文简答题一.1.Mybatis动态sql是做什么的?1.动态sql就是根据条件标签动态的拼接sql,包括判空,循环,拼接等2.哪些动态sql?动态sql大...

2023-03-20 14:50 xiyangw

Java面试题(第二弹)(java面试题及答案整理)
Java面试题(第二弹)(java面试题及答案整理)

1.抽象类和接口的区别?接口可以被多重implements,抽象类只能被单一extends接口只有定义,抽象类可以有定义和实现接口的字段定义默认为:public...

2023-03-20 14:50 xiyangw

mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)
mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)

大纲动态sql使用示例SqlSource和BoundSql以及实现类LanguageDriver以及实现类SqlNode以及实现类动态sql解...

2023-03-20 14:50 xiyangw

第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)
第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)

本内容是《Web前端开发之Javascript视频》的课件,请配合大师哥《Javascript》视频课程学习。文本节点用Text类型表示,包含的是可以按字面解释...

2023-03-20 14:49 xiyangw

Qt读写三种文件(qt读取文件数据并赋值给变量)

第一种INI配置文件.ini文件是InitializationFile的缩写,即初始化文件。除了windows现在很多其他操作系统下面的应用软件也有.ini文件,用来配置应用软件以实现不同用户的要...

取消回复欢迎 发表评论: