forked from fernandojsg/aframe-teleport-controls
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaframe-teleport-component.min.js
1 lines (1 loc) · 10.7 KB
/
aframe-teleport-component.min.js
1
!function(t){function e(r){if(i[r])return i[r].exports;var n=i[r]={exports:{},id:r,loaded:!1};return t[r].call(n.exports,n,n.exports,e),n.loaded=!0,n.exports}var i={};return e.m=t,e.c=i,e.p="",e(0)}([function(t,e,i){var r=i(1),n=i(2);if("undefined"==typeof AFRAME)throw new Error("Component attempted to register before AFRAME was available.");AFRAME.registerComponent("teleport",{schema:{type:{default:"parabolic",oneOf:["parabolic","line"]},button:{default:"trackpad",oneOf:["trackpad","trigger","grip","menu"]},collisionEntity:{type:"selector"},hitEntity:{type:"selector"},hitCylinderColor:{type:"color",default:"#99ff99"},hitCylinderRadius:{default:.25},hitCylinderHeight:{default:.3},maxLength:{default:10,if:{type:["line"]}},curveNumberPoints:{default:30,if:{type:["parabolic"]}},curveLineWidth:{default:.025},curveHitColor:{type:"color",default:"#99ff99"},curveMissColor:{type:"color",default:"#ff0000"},curveShootingSpeed:{default:5,if:{type:["parabolic"]}},landingNormal:{type:"vec3",default:"0 1 0"},landingMaxAngle:{default:"45"}},init:function(){this.active=!1,this.obj=this.el.object3D,this.hitPoint=new THREE.Vector3,this.hit=!1,this.prevHeightDiff=0,this.referenceNormal=new THREE.Vector3,this.curveMissColor=new THREE.Color,this.curveHitColor=new THREE.Color,this.raycaster=new THREE.Raycaster,this.defaultPlane=this.createDefaultPlane(),this.teleportEntity=document.createElement("a-entity"),this.teleportEntity.className="teleport-ray",this.teleportEntity.setAttribute("visible",!1),this.el.sceneEl.appendChild(this.teleportEntity),this.el.addEventListener(this.data.button+"down",this.onButtonDown.bind(this)),this.el.addEventListener(this.data.button+"up",this.onButtonUp.bind(this))},onButtonDown:function(t){this.active=!0},onButtonUp:function(t){if(this.active&&(this.active=!1,this.hitEntity.setAttribute("visible",!1),this.teleportEntity.setAttribute("visible",!1),this.hit)){var e=this.el.sceneEl.camera.el,i=(new THREE.Vector3).copy(e.getAttribute("position")),r=i.y+this.hitPoint.y-this.prevHeightDiff,n=new THREE.Vector3(this.hitPoint.x,r,this.hitPoint.z);this.prevHeightDiff=this.hitPoint.y,e.setAttribute("position",n);for(var s=document.querySelectorAll("a-entity[tracked-controls]"),o=0;o<s.length;o++){var a=s[o].getAttribute("position"),h=(new THREE.Vector3).copy(a),l=i.clone().sub(h),c=n.clone().sub(l);s[o].setAttribute("position",c)}this.el.emit("teleported",{oldCamPosition:i,newCamPosition:n,hitPoint:this.hitPoint})}},update:function(t){this.referenceNormal.copy(this.data.landingNormal),this.curveMissColor.set(this.data.curveMissColor),this.curveHitColor.set(this.data.curveHitColor),t.curveNumberPoints!==this.data.curveNumberPoints&&this.createLine(),this.data.hitEntity?this.hitEntity=this.data.hitEntity:this.hitEntity=this.createHitEntity(),this.hitEntity.setAttribute("visible",!1)},remove:function(){},tick:function(){var t=new THREE.Vector3,e=new THREE.Quaternion,i=new THREE.Vector3,n=new THREE.Vector3,s=new THREE.Vector3,o=new THREE.Vector3;return function(a,h){if(this.active){var l=this.obj.matrixWorld;l.decompose(i,e,n);var c=s.set(0,0,-1).applyQuaternion(e).normalize();this.line.setDirection(c.clone()),t.copy(this.obj.position);var u,A=t.clone();if(this.teleportEntity.setAttribute("visible",!0),this.line.material.color.set(this.curveMissColor),this.hitEntity.setAttribute("visible",!1),this.hit=!1,"parabolic"===this.data.type)for(var d=c.clone().multiplyScalar(this.data.curveShootingSpeed),p=-9.8,E=new THREE.Vector3(0,p,0),y=0;y<this.line.numPoints;y++){var f=y/(this.line.numPoints-1);u=r(t,d,E,f);var v=o.copy(u).sub(A).normalize();if(this.raycaster.far=v.length(),this.raycaster.set(A,v),this.checkMeshCollision(y,u))break;A.copy(u)}else"line"===this.data.type&&(u=A.add(c.clone().multiplyScalar(this.data.maxLength)),this.raycaster.far=this.data.maxLength,this.raycaster.set(t,c),this.line.setPoint(0,t),this.checkMeshCollision(1,u))}}}(),checkMeshCollision:function(t,e){var i=this.data.collisionEntity&&this.data.collisionEntity.getObject3D("mesh");i||(i=this.defaultPlane);var r=this.raycaster.intersectObject(i,!0);if(r.length>0&&!this.hit&&this.isValidNormalsAngle(r[0].face.normal)){var n=r[0].point;this.line.material.color.set(this.curveHitColor),this.hitEntity.setAttribute("position",n),this.hitEntity.setAttribute("visible",!0),this.hit=!0,this.hitPoint.copy(r[0].point);for(var s=t;s<this.line.numPoints;s++)this.line.setPoint(s,this.hitPoint);return!0}return this.line.setPoint(t,e),!1},isValidNormalsAngle:function(t){var e=this.referenceNormal.angleTo(t);return THREE.Math.RAD2DEG*e<=this.data.landingMaxAngle},createLine:function(){var t="line"===this.data.type?2:this.data.curveNumberPoints;this.line=new n(t,this.data.curveLineWidth),this.teleportEntity.setObject3D("mesh",this.line.mesh)},createHitEntity:function(){var t=document.createElement("a-entity");t.className="hintEntity";var e=document.createElement("a-entity");e.setAttribute("geometry",{primitive:"torus",radius:this.data.hitCylinderRadius,radiusTubular:.01}),e.setAttribute("rotation",{x:90,y:0,z:0}),e.setAttribute("material",{shader:"flat",color:this.data.hitCylinderColor,side:"double",depthTest:!1}),t.appendChild(e);var i=document.createElement("a-entity");return i.setAttribute("geometry",{primitive:"cylinder",segmentsHeight:1,radius:this.data.hitCylinderRadius,height:this.data.hitCylinderHeight,openEnded:!0}),i.setAttribute("position",{x:0,y:this.data.hitCylinderHeight/2,z:0}),i.setAttribute("material",{shader:"flat",color:this.data.hitCylinderColor,side:"double",src:"url()",transparent:!0,depthTest:!1}),t.appendChild(i),document.querySelector("a-scene").appendChild(t),t},createDefaultPlane:function(){var t=new THREE.BoxBufferGeometry(100,.5,100);t.applyMatrix((new THREE.Matrix4).makeTranslation(0,-.25,0));var e=new THREE.MeshBasicMaterial({color:16776960}),i=new THREE.Mesh(t,e);return i}})},function(t,e){function i(t,e,i,r){return t+e*r+.5*i*r*r}function r(t,e,r,n){var s=new THREE.Vector3;return s.x=i(t.x,e.x,r.x,n),s.y=i(t.y,e.y,r.y,n),s.z=i(t.z,e.z,r.z,n),s}t.exports=r},function(t,e){var i=function(t,e){this.geometry=new THREE.BufferGeometry,this.vertices=new Float32Array(3*t*2),this.uvs=new Float32Array(2*t*2),this.width=e,this.geometry.addAttribute("position",new THREE.BufferAttribute(this.vertices,3).setDynamic(!0)),this.material=new THREE.MeshBasicMaterial({side:THREE.DoubleSide,color:16711680}),this.mesh=new THREE.Mesh(this.geometry,this.material),this.mesh.drawMode=THREE.TriangleStripDrawMode,this.mesh.frustumCulled=!1,this.mesh.vertices=this.vertices,this.direction=new THREE.Vector3,this.numPoints=t};i.prototype={setDirection:function(t){var e=new THREE.Vector3(0,1,0);this.direction.copy(t).cross(e).normalize().multiplyScalar(this.width/2)},setWidth:function(t){this.width=t},setPoint:function(){var t=new THREE.Vector3,e=new THREE.Vector3;return function(i,r){t.copy(r).add(this.direction),e.copy(r).sub(this.direction);var n=6*i;this.vertices[n++]=t.x,this.vertices[n++]=t.y,this.vertices[n++]=t.z,this.vertices[n++]=e.x,this.vertices[n++]=e.y,this.vertices[n++]=e.z,this.geometry.attributes.position.needsUpdate=!0}}()},t.exports=i}]);