@hology/core 0.0.72 → 0.0.73

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,4 @@
1
- import{__decorate as e,__metadata as t}from"tslib";import{Ball as n,Capsule as o,Cone as s,ConvexPolyhedron as r,Cuboid as i,Cylinder as a,Heightfield as c,ShapeType as l,TriMesh as p}from"@dimforge/rapier3d-compat";import{init as h}from"@recast-navigation/core";import{DebugDrawer as d,getPositionsAndIndices as u}from"@recast-navigation/three";import{BehaviorSubject as f,debounceTime as m,filter as g,firstValueFrom as w,takeUntil as b}from"rxjs";import*as y from"three";import{BufferGeometryUtils as x,ConvexHull as v}from"three/examples/jsm/Addons.js";import{Actor as B,BaseActor as M,Parameter as S,PhysicsSystem as A,ViewController as C,World as k,inject as z}from"../../";import{DynamicTiledNavMesh as F}from"../../ai/dynamic-tiled-navmesh";var G;!function(e){e[e.none=0]="none",e[e.starting=1]="starting",e[e.started=2]="started"}(G||(G={}));let I=G.none,P=new f(!1);export async function safeRecastInit(){return I===G.none?(I=G.starting,h().then((()=>{P.next(!0),I=G.started}))):w(P.pipe(g((e=>e))))}const j=new y.Box3(new y.Vector3(-2e3,-200,-2e3),new y.Vector3(2e3,200,2e3)),V=navigator.hardwareConcurrency??1;let N=!1,E=class extends M{constructor(){super(...arguments),this.physics=z(A),this.view=z(C),this.world=z(k),this.debug=!0,this.refreshMs=2e3,this.tileSize=400,this.walkableClimb=5,this.walkableSlopeAngle=45}async onInit(){N||(await safeRecastInit(),N=!0),this.init()}init(){const e={tileSize:400,walkableClimb:.2*this.walkableClimb,walkableSlopeAngle:this.walkableSlopeAngle,walkableRadius:2,walkableHeight:5,detailSampleDist:1,minRegionArea:6,mergeRegionArea:400,cs:.2,ch:.2,maxSimplificationError:1.3,maxEdgeLen:200},t=(new y.Box3,new F({navMeshBounds:j,recastConfig:e,maxTiles:16384,workers:V,cacheId:"nav"+this.object.userData?.src?.id}));this.navMesh=t.navMesh,this.object.position.set(0,0,0);const n=this.tileSize*e.cs*2,o=performance.now(),s=new Map,r=new d;t.navMesh;const i=()=>{const e=this.view.getCamera().getWorldPosition(new y.Vector3),t=new y.Box3((new y.Vector3).copy(e).subScalar(n),(new y.Vector3).copy(e).addScalar(n)),o=[],r=this.physics.world.bodies,i=new y.Box3;for(const e of r.getAll())for(let n=0,r=e.numColliders();n<r;n++){const r=e.collider(n);if(r.isSensor()||null!=r.parent().userData&&!0===r.parent().userData.ignoreForNavMesh)continue;const a=e.handle+","+n,c=s.get(a)?.mesh,l=c??R(r);if(D(r,l),null!=l){i.copy(l.geometry.boundingBox),i.min.add(l.position),i.max.add(l.position);const e=i.intersectsBox(t)||!0;s.set(a,{pos:r.translation(),mesh:l}),e&&o.push(l)}}return o},a=new y.Box3,c=new Map,l=new Map;let p=!0,h=performance.now();const f=setInterval((()=>{const e=new y.Box3,n=i();for(const t of n){const n=c.get(t);!0!==n?.equals(t.position)&&(null!=n&&e.expandByPoint(n),e.expandByObject(t),c.set(t,t.position.clone()))}e.min.subScalar(50),e.max.addScalar(50);const o=t.getTilesForBounds(e);if(0!=o.length){const s=[];for(const t of n)a.setFromObject(t),a.intersectsBox(e)&&s.push(t);console.log("tiles to update ",o),console.log("intersecting meshes",s.length),console.log(n),console.time("get positions");const[r,i]=u(s);console.timeEnd("get positions");const c=p;p=!1,Promise.all(o.map((e=>(h=performance.now(),t.buildTile(r,i,e,c).then((()=>{const t=e[0]+","+e[1];l.set(t,(l.get(t)??0)+1),this.debug})))))).then((()=>{this.debug}))}}),this.refreshMs??1e4);this.disposed.subscribe((()=>clearInterval(f))),t.onNavMeshUpdate.pipe(b(this.disposed),m(200)).subscribe((()=>{console.log("duration ",(performance.now()-h)/1e3),r.clear(),r.drawNavMesh(t.navMesh)})),console.log("Create navmesh with debug",this.debug),this.debug&&this.object.parent.add(r),this.disposed.subscribe((()=>{t?.destroy(),r.removeFromParent(),r.dispose()}));const g=performance.now()-o;g>1e3&&console.warn(`NavMesh update took ${g} ms. Consider changing tileSize or other parameter that may affect performance`)}};e([S(),t("design:type",Boolean)],E.prototype,"debug",void 0),e([S(),t("design:type",Number)],E.prototype,"walkableClimb",void 0),e([S({range:[0,89]}),t("design:type",Number)],E.prototype,"walkableSlopeAngle",void 0),E=e([B()],E);export default E;function H(e){if(e.shape instanceof c)return function(e){const t=e.shape;if(t.type!==l.HeightField)throw new Error("The provided collider is not a height field.");let n=!1;const o=t,s=o.heights,r=o.nrows,i=o.ncols,a=o.scale.x,c=o.scale.z,p=o.scale.y,h=r+1,d=new y.PlaneGeometry(c,a,i,r);d.rotateX(-Math.PI/2);const u=d.attributes.position.array;let f=0;for(let e=0;e<h;e++)for(let t=0;t<h;t++)u[f+1]=s[t*h+e]*p,f+=3,0!=u[f+1]&&(n=!0);if(!n){const e=new y.PlaneGeometry(a,c,2,2);return e.rotateX(-Math.PI/2),e}return d}(e);if(e.shape instanceof n)return new y.SphereGeometry(e.shape.radius);if(e.shape instanceof i){const t=e.shape.halfExtents;return new y.BoxGeometry(2*t.x,2*t.y,2*t.z)}if(e.shape instanceof r)return function(e){const t=[];for(let n=0;n<e.length;n+=3)t.push(new y.Vector3(e[n],e[n+1],e[n+2]));const n=(new v).setFromPoints(t),o=[];n.faces.forEach((e=>{const t=e.edge.head().point,n=e.edge.next.head().point,s=e.edge.next.next.head().point;o.push(t.x,t.y,t.z),o.push(n.x,n.y,n.z),o.push(s.x,s.y,s.z)}));const s=new y.BufferGeometry;return s.setAttribute("position",new y.Float32BufferAttribute(o,3)),s}(e.shape.vertices);if(e.shape instanceof p){const t=e.shape.vertices,n=e.shape.indices;let o=new y.BufferGeometry;return o.setAttribute("position",new y.Float32BufferAttribute(t,3)),null!=n?o.setIndex(new y.Uint16BufferAttribute(n,1)):o=x.mergeVertices(o),o.computeVertexNormals(),o}if(e.shape instanceof a){const t=e.shape.halfHeight,n=e.shape.radius;return new y.CylinderGeometry(n,n,2*t)}if(e.shape instanceof s){const t=e.shape.halfHeight,n=e.shape.radius;return new y.ConeGeometry(n,2*t)}if(e.shape instanceof o){const t=e.shape.halfHeight,n=e.shape.radius;return new y.CapsuleGeometry(n,2*t)}return console.warn("Unsupported shape",e.shape.type,e),null}function R(e){const t=H(e);if(null==t)return null;const n=new y.MeshBasicMaterial({wireframe:!1,color:16711680,side:y.FrontSide}),o=new y.Mesh(t,n);return o.geometry.computeBoundingBox(),o.geometry.scale(1.01,1.01,1.01),o}function D(e,t){const n=e.translation(),o=e.rotation();t.position.set(n.x,n.y,n.z),t.quaternion.set(o.x,o.y,o.z,o.w)}
1
+ import{__decorate as e,__metadata as t}from"tslib";import{Ball as n,Capsule as o,Cone as s,ConvexPolyhedron as r,Cuboid as i,Cylinder as a,Heightfield as c,ShapeType as l,TriMesh as p}from"@dimforge/rapier3d-compat";import{init as h}from"@recast-navigation/core";import{DebugDrawer as u,getPositionsAndIndices as d}from"@recast-navigation/three";import{BehaviorSubject as f,debounceTime as m,filter as g,firstValueFrom as w,takeUntil as b}from"rxjs";import*as y from"three";import{BufferGeometryUtils as x,ConvexHull as v}from"three/examples/jsm/Addons.js";import{Actor as B,BaseActor as M,Parameter as S,PhysicsSystem as A,ViewController as C,World as k,inject as z}from"../../";import{DynamicTiledNavMesh as F}from"../../ai/dynamic-tiled-navmesh";var G;!function(e){e[e.none=0]="none",e[e.starting=1]="starting",e[e.started=2]="started"}(G||(G={}));let I=G.none,P=new f(!1);export async function safeRecastInit(){return I===G.none?(I=G.starting,h().then((()=>{P.next(!0),I=G.started}))):w(P.pipe(g((e=>e))))}const j=new y.Box3(new y.Vector3(-2e3,-200,-2e3),new y.Vector3(2e3,200,2e3)),V=navigator.hardwareConcurrency??1;let D=!1,N=class extends M{constructor(){super(...arguments),this.physics=z(A),this.view=z(C),this.world=z(k),this.debug=!0,this.refreshMs=2e3,this.tileSize=400,this.walkableClimb=5,this.walkableSlopeAngle=45}async onInit(){D||(await safeRecastInit(),D=!0),this.init()}init(){const e={tileSize:400,walkableClimb:.2*this.walkableClimb,walkableSlopeAngle:this.walkableSlopeAngle,walkableRadius:2,walkableHeight:5,detailSampleDist:1,minRegionArea:6,mergeRegionArea:400,cs:.2,ch:.2,maxSimplificationError:1.3,maxEdgeLen:200},t=(new y.Box3,new F({navMeshBounds:j,recastConfig:e,maxTiles:16384,workers:V,cacheId:"nav"+this.object.userData?.src?.id}));this.navMesh=t.navMesh,this.object.position.set(0,0,0);const n=this.tileSize*e.cs*2,o=performance.now(),s=new Map,r=new u;r.userData.isDebugDrawer=!0;t.navMesh;const i=()=>{const e=this.view.getCamera().getWorldPosition(new y.Vector3),t=new y.Box3((new y.Vector3).copy(e).subScalar(n),(new y.Vector3).copy(e).addScalar(n)),o=[],r=this.physics.world.bodies,i=new y.Box3;for(const e of r.getAll())for(let n=0,r=e.numColliders();n<r;n++){const r=e.collider(n);if(r.isSensor()||null!=r.parent().userData&&!0===r.parent().userData.ignoreForNavMesh)continue;const a=e.handle+","+n,c=s.get(a)?.mesh,l=c??H(r);if(R(r,l),null!=l){i.copy(l.geometry.boundingBox),i.min.add(l.position),i.max.add(l.position);const e=i.intersectsBox(t)||!0;s.set(a,{pos:r.translation(),mesh:l}),e&&o.push(l)}}return o},a=new y.Box3,c=new Map,l=new Map;let p=!0,h=performance.now();const f=setInterval((()=>{const e=new y.Box3,n=i();for(const t of n){const n=c.get(t);!0!==n?.equals(t.position)&&(null!=n&&e.expandByPoint(n),e.expandByObject(t),c.set(t,t.position.clone()))}e.min.subScalar(50),e.max.addScalar(50);const o=t.getTilesForBounds(e);if(0!=o.length){const s=[];for(const t of n)a.setFromObject(t),a.intersectsBox(e)&&s.push(t);console.log("tiles to update ",o),console.log("intersecting meshes",s.length),console.log(n),console.time("get positions");const[r,i]=d(s);console.timeEnd("get positions");const c=p;p=!1,Promise.all(o.map((e=>(h=performance.now(),t.buildTile(r,i,e,c).then((()=>{const t=e[0]+","+e[1];l.set(t,(l.get(t)??0)+1),this.debug})))))).then((()=>{this.debug}))}}),this.refreshMs??1e4);this.disposed.subscribe((()=>clearInterval(f))),t.onNavMeshUpdate.pipe(b(this.disposed),m(200)).subscribe((()=>{console.log("duration ",(performance.now()-h)/1e3),r.clear(),r.drawNavMesh(t.navMesh)})),console.log("Create navmesh with debug",this.debug),this.debug&&this.object.parent.add(r),this.disposed.subscribe((()=>{t?.destroy(),r.removeFromParent(),r.dispose()}));const g=performance.now()-o;g>1e3&&console.warn(`NavMesh update took ${g} ms. Consider changing tileSize or other parameter that may affect performance`)}};e([S(),t("design:type",Boolean)],N.prototype,"debug",void 0),e([S(),t("design:type",Number)],N.prototype,"walkableClimb",void 0),e([S({range:[0,89]}),t("design:type",Number)],N.prototype,"walkableSlopeAngle",void 0),N=e([B()],N);export default N;function E(e){if(e.shape instanceof c)return function(e){const t=e.shape;if(t.type!==l.HeightField)throw new Error("The provided collider is not a height field.");let n=!1;const o=t,s=o.heights,r=o.nrows,i=o.ncols,a=o.scale.x,c=o.scale.z,p=o.scale.y,h=r+1,u=new y.PlaneGeometry(c,a,i,r);u.rotateX(-Math.PI/2);const d=u.attributes.position.array;let f=0;for(let e=0;e<h;e++)for(let t=0;t<h;t++)d[f+1]=s[t*h+e]*p,f+=3,0!=d[f+1]&&(n=!0);if(!n){const e=new y.PlaneGeometry(a,c,2,2);return e.rotateX(-Math.PI/2),e}return u}(e);if(e.shape instanceof n)return new y.SphereGeometry(e.shape.radius);if(e.shape instanceof i){const t=e.shape.halfExtents;return new y.BoxGeometry(2*t.x,2*t.y,2*t.z)}if(e.shape instanceof r)return function(e){const t=[];for(let n=0;n<e.length;n+=3)t.push(new y.Vector3(e[n],e[n+1],e[n+2]));const n=(new v).setFromPoints(t),o=[];n.faces.forEach((e=>{const t=e.edge.head().point,n=e.edge.next.head().point,s=e.edge.next.next.head().point;o.push(t.x,t.y,t.z),o.push(n.x,n.y,n.z),o.push(s.x,s.y,s.z)}));const s=new y.BufferGeometry;return s.setAttribute("position",new y.Float32BufferAttribute(o,3)),s}(e.shape.vertices);if(e.shape instanceof p){const t=e.shape.vertices,n=e.shape.indices;let o=new y.BufferGeometry;return o.setAttribute("position",new y.Float32BufferAttribute(t,3)),null!=n?o.setIndex(new y.Uint16BufferAttribute(n,1)):o=x.mergeVertices(o),o.computeVertexNormals(),o}if(e.shape instanceof a){const t=e.shape.halfHeight,n=e.shape.radius;return new y.CylinderGeometry(n,n,2*t)}if(e.shape instanceof s){const t=e.shape.halfHeight,n=e.shape.radius;return new y.ConeGeometry(n,2*t)}if(e.shape instanceof o){const t=e.shape.halfHeight,n=e.shape.radius;return new y.CapsuleGeometry(n,2*t)}return console.warn("Unsupported shape",e.shape.type,e),null}function H(e){const t=E(e);if(null==t)return null;const n=new y.MeshBasicMaterial({wireframe:!1,color:16711680,side:y.FrontSide}),o=new y.Mesh(t,n);return o.geometry.computeBoundingBox(),o.geometry.scale(1.01,1.01,1.01),o}function R(e,t){const n=e.translation(),o=e.rotation();t.position.set(n.x,n.y,n.z),t.quaternion.set(o.x,o.y,o.z,o.w)}
2
2
  /*
3
3
  * Copyright (©) 2023. All rights reserved.
4
4
  * See the LICENSE.md file for details.
@@ -7,7 +7,7 @@ import { PhysicsSystem } from '../../services/physics/physics-system.js';
7
7
  * A camera that is behind the actor.
8
8
  * It can also spring back and forward to avoid clipping into other elements
9
9
  */
10
- export declare class ThirdPartyCameraComponent extends ActorComponent {
10
+ export declare class ThirdPersonCameraComponent extends ActorComponent {
11
11
  private viewController;
12
12
  private physicsSystem;
13
13
  camera: CameraComponent;
@@ -43,3 +43,6 @@ export declare class ThirdPartyCameraComponent extends ActorComponent {
43
43
  private getLookAtPosition;
44
44
  private updateCameraPosition;
45
45
  }
46
+ /** @deprecated Use ThirdPersonCameraComponent. No difference just renamed */
47
+ export declare class ThirdPartyCameraComponent extends ThirdPersonCameraComponent {
48
+ }
@@ -1,4 +1,4 @@
1
- import{__decorate as t,__metadata as s}from"tslib";import{ActorComponent as e,Component as i,attach as o}from"../component.js";import{CameraComponent as n}from"./camera-component.js";import{Vector3 as a,MathUtils as h}from"three";import{ViewController as c}from"../../services/render.js";import{DecimalInput as r,RestrictedRotationInput as m}from"../../input/index.js";import{PhysicsSystem as d,RayTestResult as l}from"../../services/physics/physics-system.js";let u=class extends e{constructor(t,s){super(),this.viewController=t,this.physicsSystem=s,this.camera=o(n),this.distance=9,this.minDistance=1.5,this.maxDistance=this.distance,this.height=3,this.offsetX=-1,this.offsetZ=1.5,this.autoActivate=!0,this.bounceBackSpeed=5,this.collisionCheckRadius=.5,this.restrictedDistance=Math.max(this.distance,this.maxDistance),this.rotationInput=new m(-Math.PI/4,Math.PI/2-.7),this.zoomInput=new r(1,0,1),this.offset=new a,this.lookAtOffset=new a(this.offsetX,0,this.offsetZ),this.isMouseLocked=!1,this.canvas=null,this.pointerLockInactivatedAt=null,this.onMouseDown=t=>{this.isMouseLocked||this.hideCursor()},this.onKeyDown=t=>{"Escape"===t.key&&this.showCursor()},this.onPointerLockChange=()=>{null!=document.pointerLockElement||null!=document.mozPointerLockElement||this.showCursor()}}async onInit(){this.restrictedDistance=Math.max(this.distance,this.maxDistance),this.lookAtOffset.set(this.offsetX,0,this.offsetZ),this.autoActivate&&this.activate()}activate(){this.viewController.setCamera(this.camera.instance);const t=this.element;null!=document.body.requestPointerLock&&(t.addEventListener("mousedown",this.onMouseDown),t.addEventListener("keydown",this.onKeyDown),document.addEventListener("pointerlockchange",this.onPointerLockChange,!1),this.disposed.subscribe((()=>{t.removeEventListener("mousedown",this.onMouseDown),t.removeEventListener("keydown",this.onKeyDown),document.removeEventListener("pointerlockchange",this.onPointerLockChange,!1)})))}onLateUpdate(t){this.setFromRotation(t)}get element(){return this.viewController.htmlElement}hideCursor(){"ontouchstart"in window||navigator.maxTouchPoints>0||navigator.msMaxTouchPoints>0||null!=this.pointerLockInactivatedAt&&performance.now()-this.pointerLockInactivatedAt<1600||(this.element.style.cursor="none",null==this.canvas&&(this.canvas=this.element.getElementsByTagName("canvas")[0]),this.canvas&&(this.canvas.requestPointerLock(),this.isMouseLocked=!0))}showCursor(){this.pointerLockInactivatedAt=performance.now(),this.element.style.cursor="default",window.document.exitPointerLock(),this.isMouseLocked=!1}setFromRotation(t){this.checkForCollision(t);const s=h.clamp(Math.min(this.restrictedDistance,this.distance),Math.min(this.minDistance,this.restrictedDistance),Math.max(this.distance*this.zoomInput.value,this.minDistance)),e=Math.cos(this.rotationInput.rotation.x)*s;this.offset.x=Math.sin(this.rotationInput.rotation.y)*e,this.offset.y=Math.sin(this.rotationInput.rotation.x)*s+2,this.offset.z=Math.cos(this.rotationInput.rotation.y)*-e,this.offset.add(this.lookAtOffset),this.updateCameraPosition()}checkForCollision(t){const s=this.getLookAtPosition(),e=f;let i=!1,o=this.distance;const n=new l,a=this.camera.instance.getWorldPosition(w);for(let t=-1;t<=1;t++){const h=k.subVectors(a,s);e.copy(a).add(h.multiplyScalar(1.2)),e.x+=t*this.collisionCheckRadius,this.physicsSystem.rayTest(s,e,n,{debugLifetime:0,excludeActor:this.actor,excludeTriggers:!0}),n.hasHit&&n.distance<this.distance&&(o=Math.min(n.distance,o),i||=n.hasHit)}i||(this.restrictedDistance=h.lerp(this.restrictedDistance,this.distance,h.clamp(this.bounceBackSpeed*t,0,1)))}getLookAtPosition(){const t=p;return t.set(0,0,0),t.y=this.height,t.add(this.lookAtOffset),t.applyMatrix4(this.actor.object.matrixWorld),t}updateCameraPosition(){this.camera.instance.position.copy(this.offset);const t=this.getLookAtPosition();this.camera.instance.lookAt(t)}};u=t([i(),s("design:paramtypes",[c,d])],u);export{u as ThirdPartyCameraComponent};const p=new a,f=new a,k=(new a,new a),w=new a;
1
+ import{__decorate as t,__metadata as e}from"tslib";import{ActorComponent as s,Component as i,attach as o}from"../component.js";import{CameraComponent as n}from"./camera-component.js";import{Vector3 as a,MathUtils as h}from"three";import{ViewController as c}from"../../services/render.js";import{DecimalInput as r,RestrictedRotationInput as m}from"../../input/index.js";import{PhysicsSystem as d,RayTestResult as l}from"../../services/physics/physics-system.js";let u=class extends s{constructor(t,e){super(),this.viewController=t,this.physicsSystem=e,this.camera=o(n),this.distance=9,this.minDistance=1.5,this.maxDistance=this.distance,this.height=3,this.offsetX=-1,this.offsetZ=1.5,this.autoActivate=!0,this.bounceBackSpeed=5,this.collisionCheckRadius=.5,this.restrictedDistance=Math.max(this.distance,this.maxDistance),this.rotationInput=new m(-Math.PI/4,Math.PI/2-.7),this.zoomInput=new r(1,0,1),this.offset=new a,this.lookAtOffset=new a(this.offsetX,0,this.offsetZ),this.isMouseLocked=!1,this.canvas=null,this.pointerLockInactivatedAt=null,this.onMouseDown=t=>{this.isMouseLocked||this.hideCursor()},this.onKeyDown=t=>{"Escape"===t.key&&this.showCursor()},this.onPointerLockChange=()=>{null!=document.pointerLockElement||null!=document.mozPointerLockElement||this.showCursor()}}async onInit(){this.restrictedDistance=Math.max(this.distance,this.maxDistance),this.lookAtOffset.set(this.offsetX,0,this.offsetZ),this.autoActivate&&this.activate()}activate(){this.viewController.setCamera(this.camera.instance);const t=this.element;null!=document.body.requestPointerLock&&(t.addEventListener("mousedown",this.onMouseDown),t.addEventListener("keydown",this.onKeyDown),document.addEventListener("pointerlockchange",this.onPointerLockChange,!1),this.disposed.subscribe((()=>{t.removeEventListener("mousedown",this.onMouseDown),t.removeEventListener("keydown",this.onKeyDown),document.removeEventListener("pointerlockchange",this.onPointerLockChange,!1)})))}onLateUpdate(t){this.setFromRotation(t)}get element(){return this.viewController.htmlElement}hideCursor(){"ontouchstart"in window||navigator.maxTouchPoints>0||navigator.msMaxTouchPoints>0||null!=this.pointerLockInactivatedAt&&performance.now()-this.pointerLockInactivatedAt<1600||(this.element.style.cursor="none",null==this.canvas&&(this.canvas=this.element.getElementsByTagName("canvas")[0]),this.canvas&&(this.canvas.requestPointerLock(),this.isMouseLocked=!0))}showCursor(){this.pointerLockInactivatedAt=performance.now(),this.element.style.cursor="default",window.document.exitPointerLock(),this.isMouseLocked=!1}setFromRotation(t){this.checkForCollision(t);const e=h.clamp(Math.min(this.restrictedDistance,this.distance),Math.min(this.minDistance,this.restrictedDistance),Math.max(this.distance*this.zoomInput.value,this.minDistance)),s=Math.cos(this.rotationInput.rotation.x)*e;this.offset.x=Math.sin(this.rotationInput.rotation.y)*s,this.offset.y=Math.sin(this.rotationInput.rotation.x)*e+2,this.offset.z=Math.cos(this.rotationInput.rotation.y)*-s,this.offset.add(this.lookAtOffset),this.updateCameraPosition()}checkForCollision(t){const e=this.getLookAtPosition(),s=f;let i=!1,o=this.distance;const n=new l,a=this.camera.instance.getWorldPosition(w);for(let t=-1;t<=1;t++){const h=k.subVectors(a,e);s.copy(a).add(h.multiplyScalar(1.2)),s.x+=t*this.collisionCheckRadius,this.physicsSystem.rayTest(e,s,n,{debugLifetime:0,excludeActor:this.actor,excludeTriggers:!0}),n.hasHit&&n.distance<this.distance&&(o=Math.min(n.distance,o),i||=n.hasHit)}i||(this.restrictedDistance=h.lerp(this.restrictedDistance,this.distance,h.clamp(this.bounceBackSpeed*t,0,1)))}getLookAtPosition(){const t=p;return t.set(0,0,0),t.y=this.height,t.add(this.lookAtOffset),t.applyMatrix4(this.actor.object.matrixWorld),t}updateCameraPosition(){this.camera.instance.position.copy(this.offset);const t=this.getLookAtPosition();this.camera.instance.lookAt(t)}};u=t([i(),e("design:paramtypes",[c,d])],u);export{u as ThirdPersonCameraComponent};const p=new a,f=new a,k=(new a,new a),w=new a;export class ThirdPartyCameraComponent extends u{}
2
2
  /*
3
3
  * Copyright (©) 2023. All rights reserved.
4
4
  * See the LICENSE.md file for details.
@@ -1,6 +1,6 @@
1
1
  export { CameraActor } from './builtin/camera-actor.js';
2
2
  export { CameraComponent } from './camera/camera-component.js';
3
- export { ThirdPartyCameraComponent } from './camera/third-party-camera-component.js';
3
+ export { ThirdPersonCameraComponent, ThirdPartyCameraComponent } from './camera/third-party-camera-component.js';
4
4
  export { SpawnPoint } from './builtin/spawn-point.js';
5
5
  export { TriggerVolume, TriggerVolumeComponent } from './builtin/trigger-volume.js';
6
6
  export { PositionalAudioActor, PositionalAudioComponent } from './builtin/positional-audio-actor.js';
@@ -1,4 +1,4 @@
1
- export{CameraActor}from"./builtin/camera-actor.js";export{CameraComponent}from"./camera/camera-component.js";export{ThirdPartyCameraComponent}from"./camera/third-party-camera-component.js";export{SpawnPoint}from"./builtin/spawn-point.js";export{TriggerVolume,TriggerVolumeComponent}from"./builtin/trigger-volume.js";export{PositionalAudioActor,PositionalAudioComponent}from"./builtin/positional-audio-actor.js";export*from"./builtin/components/mesh-component.js";export*from"./builtin/components/character/character-movement.js";export*from"./builtin/components/character/modes.js";export*from"./builtin/components/character/character-animation.js";
1
+ export{CameraActor}from"./builtin/camera-actor.js";export{CameraComponent}from"./camera/camera-component.js";export{ThirdPersonCameraComponent,ThirdPartyCameraComponent}from"./camera/third-party-camera-component.js";export{SpawnPoint}from"./builtin/spawn-point.js";export{TriggerVolume,TriggerVolumeComponent}from"./builtin/trigger-volume.js";export{PositionalAudioActor,PositionalAudioComponent}from"./builtin/positional-audio-actor.js";export*from"./builtin/components/mesh-component.js";export*from"./builtin/components/character/character-movement.js";export*from"./builtin/components/character/modes.js";export*from"./builtin/components/character/character-animation.js";
2
2
  /*
3
3
  * Copyright (©) 2023. All rights reserved.
4
4
  * See the LICENSE.md file for details.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hology/core",
3
- "version": "0.0.72",
3
+ "version": "0.0.73",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "type": "module",