javascript 3d网页 示例 ( three.js 初探 七)
1 完整代码下载
https://pan.baidu.com/s/1JJyVcP2KqXsd5G6eaYpgHQ
提取码 3fzt (压缩包名: 2020-4-5-demo.zip)
2 图片展示

3 主要代码
"use strict"
class InitControl{
constructor(View, Three){
this.view = View;
this.three = Three;
this.target = {object: null, isDown: false, isMove: false};
this.dragTarget = {};
this.group = this.add(new THREE.Group(), null, true);
this.setDrag(Three.scene, Three.camera, Three.renderer, this.group.children);
this.setOrbit(Three.scene, Three.camera, Three.renderer);
this.setTransform(Three.scene, Three.camera, Three.renderer);
this.setEvents(View, Three);
this.view.updateLanguage(this.group, "ch");//更改为中文字体
}
add (a, b, c){ // a 添加至-> b, c 如果没有定义,新添加的对象将自动获得焦点
a = this.three.add(a, b);
this.view.addList(a, b);
if(c === undefined) this.setTarget(a, {focusList: true});
return a;
}
remove (a){
this.removeTarget(a);
this.view.removeList(a);
this.three.remove(a);
this.three.update();
}
setDrag(scene, camera, renderer, children){
let drag = new THREE.DragControls(children, camera, renderer.domElement);
drag.addEventListener('hoveron', (e)=>{
this.dragTarget.old = null;
this.dragTarget.now = e.object;
});
drag.addEventListener('hoveroff', (e)=>{
this.dragTarget.now = null;
this.dragTarget.old = e.object;
});
drag.enabled = false;
this.drag = drag;
}
setOrbit(scene, camera, renderer){
let orbit = new THREE.OrbitControls(camera, renderer.domElement);
orbit.target = new THREE.Vector3(0, 0, 0);//控件焦点
//orbit.minPolarAngle = Math.PI * 0.3;//向上最大角度
//orbit.maxPolarAngle = Math.PI * 0.4;//向下最大角度
orbit.minDistance = camera.near;//最小距离
orbit.maxDistance = camera.far;//最大距离
orbit.autoRotateSpeed = 10;//自动旋转速度
//orbit.panSpeed = 100;//鼠标旋转速度
orbit.enableZoom = true;//是否启用缩放
orbit.enableKeys = true;//是否启用键盘
orbit.panSpeed = 1;//鼠标平移速度
orbit.keyPanSpeed = 100;//按键平移的速度
orbit.keys.LEFT = 65;//key a左
orbit.keys.UP = 87;//key w前
orbit.keys.RIGHT = 68;//key d右
orbit.keys.BOTTOM = 83;//key s后
orbit.addEventListener("change", ()=>{renderer.render(scene, camera);});
this.orbit = orbit;
}
setTransform(scene, camera, renderer){
var transform = new THREE.TransformControls(camera, renderer.domElement);
transform.size = 1;
scene.add(transform);
this.transform = transform;
transform.addEventListener( 'dragging-changed', (e)=>{this.orbit.enabled = !e.value;});
transform.addEventListener('change', (e)=>{
let type = transform.getMode(), mesh = this.target.object || e.target.object;
let hc = mesh.WHX.elem.listContent.mesh.object;
switch(type){
case "translate":
hc.position.x = mesh.position.x;
hc.position.y = mesh.position.y;
hc.position.z = mesh.position.z;
break;
case "rotate":
hc.rotation.x = mesh.rotation.x;
hc.rotation.y = mesh.rotation.y;
hc.rotation.z = mesh.rotation.z;
break;
case "scale":
hc.scale.x = mesh.scale.x;
hc.scale.y = mesh.scale.y;
hc.scale.z = mesh.scale.z;
break;
default: break;
}
this.three.boxHelper.update();
renderer.render(scene, camera);
});
}
setTarget(object, param){
this.removeTarget(this.target.object);
if(!object || !object.WHX) return;
param = param || {};
this.three.boxHelper.setFromObject(object);
this.three.boxHelper.visible = true;
this.transform.attach(object);
if(param.focusListStyle === undefined) this.view.focusListStyle(object.WHX.elem.son);
if(param.focusList === true) this.view.focusList(object);
object.WHX.elem.listContent.mesh.father.style.display = "block";//if(param.listContent === undefined) this.view.objectContents(object);
this.target.object = object;
this.three.update();
}
removeTarget(object){
if(!object || !object.WHX) return;
this.three.boxHelper.visible = false;
this.transform.detach(object);
this.view.focusListStyle(object.WHX.elem.son, "remove");
object.WHX.elem.listContent.mesh.father.style.display = "none"; //this.view.objectContents();
this.target.object = null;
this.three.update();
}
setEvents(View, Three){
let _holdGroup = null, getObject = (a)=>{
if(a.WHX_ID === undefined){return;}
let o = Three.scene.getObjectById(a.WHX_ID);
if(o === undefined){console.log("获取对象失败"); return;}
//let object = a.tagName === "SUMMARY" ? o.WHX.backGroup : o;
return o;
}
//scene -> list
let down = ()=>{this.target.isDown = true;}
let move = ()=>{if(this.target.isDown === true && this.target.isMove === false) this.target.isMove = true;}
let up = ()=>{
if(this.target.isMove === false) this.setTarget(this.dragTarget.now, {focusList:true});
this.target.isMove = false;
this.target.isDown = false;
Three.renderer.domElement.removeEventListener("mousedown", down);
Three.renderer.domElement.removeEventListener("mousemove", move);
Three.renderer.domElement.removeEventListener("mouseup", up);
}
View.addEvent(Three.renderer.domElement, "mousedown", down);
View.addEvent(Three.renderer.domElement, "mousemove", move);
View.addEvent(Three.renderer.domElement, "mouseup", up);
//list -> scene
View.targetCallback = (a)=>{
if(a.WHX_control_ID !== undefined){ //WHX_control_ID = 0 删除 1 复制 2 子级
if(_holdGroup !== null) _holdGroup = null;
if(a.WHX_control_ID === 2) a.style.background = "rgba(0, 0, 200, 0.5)";
let o = this.target.object;
switch(a.WHX_control_ID){
case 0: this.remove(o); break;
case 1: this.setTarget(this.add(o.clone(true), o)); break;
case 2: _holdGroup = o; this.setTarget(o); break;
default: break;
}
return;
}
if(_holdGroup !== null){//分组操作
let o = getObject(a);
if(o){
this.remove(o);
this.add(o, _holdGroup);
}
_holdGroup = null;
View.right.t_control[3].style.background = "";
this.setTarget(o); return;
}
this.setTarget(getObject(a));
}
}
}
javascript 3d网页 示例 ( three.js 初探 七)的更多相关文章
- 网页3D效果库Three.js初窥
网页3D效果库Three.js初窥 背景 一直想研究下web页面的3D效果,最后选择了一个比较的成熟的框架Three.js下手 ThreeJs官网 ThreeJs-github; 接下来我会陆续翻译 ...
- [JS]jQuery,javascript获得网页的高度和宽度
[JS]jQuery,javascript获得网页的高度和宽度网页可见区域宽: document.body.clientWidth 网页可见区域高: document.body.clientHeigh ...
- Javascript模块化编程:require.js的用法
摘自:http://blog.jobbole.com/30046/ 这个系列的第一部分和第二部分,介绍了Javascript模块原型和理论概念,今天介绍如何将它们用于实战. 我采用的是一个非常流行的库 ...
- Three.js学习笔记 – “我和小伙伴都惊呆了”的特效和Three.js初探
什么是Three.js three.js是JavaScript编写的WebGL第三方库.提供了非常多的3D显示功能.Three.js 是一款运行在浏览器中的 3D 引擎,你可以用它创建各种三维场景,包 ...
- JavaScript交互式网页设计 • 【第1章 JavaScript 基本语法】
全部章节 >>>> 本章目录 1.1 JavaScript 概述 1.1.1 JavaScript 简介 1.1.2 JavaScript 的概念和执行原理 1.1.3 J ...
- 将JavaScript 插入网页的方法
将JavaScript 插入网页的方法 使用Javascript代码. 插入JavaScript 与在网页中插入CSS的方式相似.使用下面的代码可以在网页中插入JavaScript: ... 其中的. ...
- [转]backbone.js 初探
本文转自:http://weakfi.iteye.com/blog/1391990 什么是backbone backbone不是脊椎骨,而是帮助开发重量级的javascript应用的框架. 主要提供了 ...
- Javascript调用ActiveX示例
Javascript调用ActiveX示例 写一个ActiveX控件比如叫做MyNameSpace.SecreteInfo,安装在客户机器上,这样可以通过c++获取到机器的几乎任何信息. 在网 ...
- jquery的height()和javascript的height总结,js获取屏幕高度
jquery的height()和javascript的height总结,js获取屏幕高度 2014年9月18日 15048次浏览 引子 今天是九一八事变八十三周年,大家勿忘国耻!加油学习!经济和技术等 ...
随机推荐
- Matplotlib数据可视化(6):饼图与箱线图
In [1]: from matplotlib import pyplot as plt import numpy as np import matplotlib as mpl mpl.rcParam ...
- 计算机网络原理实验_使用网络协议分析仪Wireshark
一.实验名称 使用网络协议分析仪Wireshark 二.实验目的: 1. 掌握安装和配置网络协议分析仪Wireshark的方法: 2. 熟悉使用Wireshark工具分析网络协议的基本方法,加深对协 ...
- MyISAM 和 InnoDB
1.MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持已经外部键等高级 ...
- 学妹问的Spring Bean常用配置,我用最通俗易懂的讲解让她学会了
你好呀,我是沉默王二,一枚有趣的程序员,写的文章一直充满灵气,力求清新脱俗.昨天跑去王府井的小米店订购了一台小米 10,说是一周之内能到货,但我还是忍不住今天就想见到她.见我茶不思饭不想的,老婆就劝我 ...
- 计算属性(computed)+侦听器(watch)+ 方法(methods)
计算属性 computed 当数据改变时,方法的结果也会发生改变.如果多处地方调用计算属性里面的同一个方法时,该方法只会执行一次.如图,在控制台改变data里面的num值时,虽然在多处使用comput ...
- @on-row-click="$emit('on-row-click', arguments[0], arguments[1])" 行内返回事件的一种写法
@on-row-click="$emit('on-row-click', arguments[0], arguments[1])"
- Redis(十二):redis请求转发的实现
请求转发一般的原因为: 1. 该请求自身无法处理,需要转发给对应的服务器处理: 2. 为实现负载均衡,使用路由服务,选择目标实例进行转发: 在集群模式下,请求可以打到任何一台redis服务器上.然而并 ...
- 聊聊OkHttp实现WebSocket细节,包括鉴权和长连接保活及其原理!
一.序 OkHttp 应该算是 Android 中使用最广泛的网络库了,我们通常会利用它来实现 HTTP 请求,但是实际上它还可以支持 WebSocket,并且使用起来还非常的便捷. 那本文就来聊聊, ...
- SpringBoot的启动流程是怎样的?SpringBoot源码(七)
注:该源码分析对应SpringBoot版本为2.1.0.RELEASE 1 温故而知新 本篇接 SpringBoot内置的各种Starter是怎样构建的? SpringBoot源码(六) 温故而知新, ...
- angular 项目中遇到rxjs error TS1005:';'
因为rxjs的版本问题,只需要在package.json 中将依赖的 rxjs:'^6.00' 改为 rxjs'6.00', 然后执行 npm update 更新下rxjs的依赖版本即可解决