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次浏览 引子 今天是九一八事变八十三周年,大家勿忘国耻!加油学习!经济和技术等 ...
随机推荐
- 调用系统的loading界面
//在状态栏显示一个圈圈转动 代表正在请求 [UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
- python学习列表(Lists).基础二
列表(Lists) 序列是Python中最基本的数据结构,序列中的每个元素都分配一个数字,它的第一个索引是0第二个索引是1,依次类推. 列表是最常用的Python数据类型,它可以作为一个方括号内的逗号 ...
- 关于beforeRouteEnter中的next()
beforeRouteEnter(to,from, next){ console.log(this) //undefined next(vm => { console.log(vm)}) } ...
- (转)协议森林08 不放弃 (TCP协议与流通信)
协议森林08 不放弃 (TCP协议与流通信) 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! TCP(Transportation ...
- 等价类计数:Burnside引理 & Polya定理
提示: 本文并非严谨的数学分析,有很多地方是自己瞎口胡的,仅供参考.有错误请不吝指出 :p 1. 群 1.1 群的概念 群 \((S,\circ)\) 是一个元素集合 \(S\) 和一种二元运算 $ ...
- strongsan基本用法
0x01 安装 ====> CentOS RPM安装 下载:https://pkgs.org/download/strongswanwget http://download-ib01.fedor ...
- SQL的分类使用(增删改查)
1.SQL的分类使用(*代表重点的程度) DDL ** (Data Definition Language)数据库定义语言 用来定义数据库对象: 库 表 列 等 DCL (D ...
- vunlhub-DC-1-LinuxSuid提权
将靶场搭建起来 桥接看不到IP 于是用masscan 进行C段扫描 试试80 8080 访问之后发现是个drupal 掏出msf搜索一波 使用最近年限的exp尝试 exploit/unix/webap ...
- zabbix笔记_002
监控登录用户 监控图形配置 创建图形: 配置完成后查看图形: 创建触发器配置 创建完成后可以查看 监控磁盘IO I/O查看工具: istat 安装[需要epel源]: yum install -y s ...
- 趣学Spring:一文搞懂Aware、异步编程、计划任务
你好呀,我是沉默王二,一个和黄家驹一样身高,刘德华一样颜值的程序员(不信围观朋友圈呗).从 2 位偶像的年纪上,你就可以断定我的码龄至少在 10 年以上,但实话实说,我一直坚信自己只有 18 岁,因为 ...