threejs球体旋转与场景旋转_three.js实现围绕某物体旋转
话不多说,请看代码:
可以拖动右上角观察变化
Document
// 1.设置three.js渲染器
var renderer;
function initThree(){
width = document.getElementById("box").clientWidth;
height = document.getElementById("box").clientHeight;
renderer = new THREE.WebGLRenderer({
antialias:true
});/*生成渲染器对象(属性:抗锯齿效果为设置有效)*/
renderer.setSize(width,height);
document.getElementById("box").appendChild(renderer.domElement);
/*设置canvas背景色(clearColor)和背景色透明度(clearAlpha) */
renderer.setClearColor(0xFFFF00,1.0);
}
// 2.设置摄像机camera
var camera;
function initCamera(){
camera = new THREE.PerspectiveCamera(45,width/height,1,10000);
camera.position.x = 1000;
camera.position.y = 1000;
camera.position.z = 1000;
camera.up.x = 0;
camera.up.y = 0;
camera.up.z = 100;
camera.lookAt({x:0,y:0,z:0}); //设置视野的中心坐标
}
// 3.设置场景
var scene;
function initScene(){
scene = new THREE.Scene();
}
// 4.设置光源light
var light;
function initLight(){
light = new THREE.DirectionalLight(0xFF00FF, 1.0, 0); //平行光
light.position.set(100,100, 200); //设置光源位置
scene.add(light); //将官员添加到场景
}
//5.设置物体
var sphereMesh;
var cubeMesh;
var cubeMesh2;
var cubeMesh3;
var cubeMesh4;
var cubeMesh5;
var cubeMesh6;
function initObject(){
cubeMesh = new THREE.Mesh(new THREE.BoxGeometry(80,80,80),new THREE.MeshLambertMaterial({color:0xff0000})/*
设置球体的材质*/);
cubeMesh2 = new THREE.Mesh(new THREE.BoxGeometry(80,80,80),new THREE.MeshLambertMaterial({color:0xff0000})/*
设置球体的材质*/);
cubeMesh3 = new THREE.Mesh(new THREE.BoxGeometry(80,80,80),new THREE.MeshLambertMaterial({color:0xff0000})/*
设置球体的材质*/);
sphereMesh = new THREE.Mesh(new THREE.SphereGeometry(200,200,200),new THREE.MeshLambertMaterial({color:0xff00FF})/*设置球体的材质*/); //材质设定
sphereMesh.position.set(0,0,0); /*设置物体位置*/
cubeMesh2.position.set(400,0,0);
cubeMesh.position.set(390,150,0);
cubeMesh3.position.set(380,100,0);
/*
* 旋转要点。。。
*/
var pivotPoint = new THREE.Object3D();
pivotPoint.add(cubeMesh);
pivotPoint.add(cubeMesh2);
pivotPoint.add(cubeMesh3);
sphereMesh.add(pivotPoint);
scene.add(sphereMesh);
sphereMesh.name = 'cube'
}
control = new function () {
this.rotationSpeedX = 0.001;
this.rotationSpeedY = 0.001;
this.rotationSpeedZ = 0.001;
};
function addController(){
var gui = new dat.GUI();
gui.add(control, 'rotationSpeedX', -0.2, 0.2);
gui.add(control, 'rotationSpeedY', -0.2, 0.2);
gui.add(control, 'rotationSpeedZ', -0.2, 0.2);
}
function render(){
renderer.render(scene, camera);
scene.getObjectByName('cube').rotation.x += control.rotationSpeedX;
scene.getObjectByName('cube').rotation.y += control.rotationSpeedY;
scene.getObjectByName('cube').rotation.z += control.rotationSpeedZ;
requestAnimationFrame(render);
}
function threeExcute(){
initThree();
initCamera();
initScene();
initLight();
initObject();
renderer.clear();
addController();
render();
}
div#box{
border: none;
cursor: move;
width: 100%;
height: 100%;
background-color: #EEEEEE;
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!
threejs球体旋转与场景旋转_three.js实现围绕某物体旋转相关推荐
- 相机围绕目标物体旋转观察
效果如下,白色方块为观察的目标物体. 将下列脚本挂载到相机上即可,其他参数可自行调整. 脚本实现如下: using UnityEngine; using System.Collections;/// ...
- Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(二)
Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(二) 本篇目录: 五.实例中所使用的代码语法详细解释 (1).构建一个三维空间场景 (2).选择一个透视投影相机作为观察点 (a).创 ...
- UE4蓝图基础——蓝图实现物体移动和物体旋转
UE4蓝图基础--蓝图实现物体移动和物体旋转 物体旋转组件 物体旋转蓝图实现 物体移动蓝图实现 actor物体移动或者旋转在游戏或者应用最常用的基本操作方式,在UE4中基础蓝图部分就来学习分享一下具体 ...
- threejs 绘制球体_Three.js 第一篇:绘制一个静态的3D球体
第一篇就画一个球体吧 首先我们知道Three.js其实是一个3D的JS引擎,其中的强大之处就在于这个JS框架并不是依托于JQUERY来写的.那么,我们在写这一篇绘制3D球体的文章的时候,应该注意哪些地 ...
- Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(一)
Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(一) 本文目录: 一.[旋转的精灵女孩]案例运行效果 二.Three.js简介 三.Three.js代码正常运行显示条件 (1)不载入 ...
- three.js 带更新文字的旋转地球
2019独角兽企业重金招聘Python工程师标准>>> 查看旋转地球效果 主要用到几个知识点 (1)显示文字是使用了three.js 的精灵(Sprite),精灵的文字方向始终面向相 ...
- Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(三)
Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(三) 本篇目录: 六.完整构建整个[旋转的精灵女孩]实例 (1).新建.启动webGL工程空间 (2).构建项目的目录层次结构 (2. ...
- js室内地图开发_three.js搭建室内场景教程
公司做商城.消防.用电等项目,需要实现楼层和设备的可视化,以前都是使用其他建模工具创建的整体模型,再使用three.js的加载器加载到场景中,但是这样的加载存在缺陷,比如不能给模型的元素赋属性.不能单 ...
- 【Android】11.3 屏幕旋转和场景变换过程中GridView的呈现
分类:C#.Android.VS2015: 创建日期:2016-02-21 一.简介 实际上,对于布局文件中的View来说,大多数情况下,Android都会自动保存这些状态,并不需要我们都去处理它.这 ...
最新文章
- P4064 [JXOI2017]加法
- python-朴素贝叶斯分类器
- font-family常见中文字体对应的英文名称
- ISO文件编辑工具-UltraISO软碟通提供下载
- 区块链开发主流编程语言居然是Go语言
- strlen函数php中文,strlen函数介绍与使用方法详解
- DDD的模式与实践案例
- 【每日一短语】首席芭蕾舞演员
- latexkatex@常用符号@符号手写识别
- java里break的使用方法_java中break,continue,return使用方法
- JavaScript 什么是函数式编程
- 反病毒利器Autoruns和ProcessExplorer, SREng - 本人推荐使用的查毒杀毒辅助工具
- 纯C语言INI文件解析
- 【机器学习】使用Python实现k-means算法,并根据红酒的13个特征对红酒数据进行聚类。
- loadrunner入门教程(31) --Analysis
- 20220316_Scanner、匿名对象、Random、ArrayList
- JAVA 建造者模式
- matlab求解二维矩阵并画图,Matlab教程2_ 绘图 _ 二维(2)
- keepalived工作原理和配置说明
- Win10右键管理打不开时,显示explorer.exe:Windows无法访问指定设备,路径或文件。你可能没有合适的权利访问这个项目
热门文章
- 年终庆典高端海报设计PSD分层模板
- UI设计学习软件下载的好去处
- 2020年的海报设计,掌握7种风格,稳了
- 【网页素材】数据图表界面设计UI设计PSD模板
- php字符串转二进制数组中,如何将php字符串转成二进制
- oracle full table scan,ORACLE优化之执行规划(1) - TABLE FULL SCAN/INDEX FULL SCAN
- Linux内核跟踪eBPF:bpftrace 参考指南
- OpenCV学习笔记:绘图指令(矩形、圆、线、文本标注)
- xp计算机用户密码设置,XP怎么设置开机密码_XP系统设置开机密码教程-192路由网...
- Django模板层:内置模板标签if,for in(forloop.counter)with,url,spaceless,autoescape,verbatim,firstof,block,cycle