@realsee/dnalogel 3.69.6-alpha.4 → 3.69.7-alpha.1
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.
- package/CHANGELOG.md +5 -1
- package/dist/index.cjs.js +33 -33
- package/dist/index.js +1711 -1683
- package/dist/index.umd.js +37 -37
- package/docs/classes/AreaMakerPluginType.AreaMakerController.html +2 -2
- package/docs/classes/AreaMakerPluginType.AreaMakerItem.html +2 -2
- package/docs/classes/CSS3DRender.html +2 -2
- package/docs/classes/GuideLineItem.GuideLineItem.html +2 -2
- package/docs/classes/GuideLineModeItem.GuideLineModeItem.html +2 -2
- package/docs/classes/ModelMakerPluginInstance.html +2 -2
- package/docs/classes/ModelMakerPluginType.ModelMakerBoxItem.html +2 -2
- package/docs/classes/ModelMakerPluginType.ModelMakerPolygonItem.html +2 -2
- package/docs/classes/ModelMakerPluginType.ModelMakerPrismItem.html +2 -2
- package/docs/classes/ModelRoomLabelController.html +2 -2
- package/docs/classes/MoveController.html +2 -2
- package/docs/classes/Object3DHelperController.html +2 -2
- package/docs/classes/PaintBrush.html +2 -2
- package/docs/classes/PanoMeasurePluginLine.html +2 -2
- package/docs/classes/PanoMeasurePluginModel.html +2 -2
- package/docs/classes/PanoMeasurePluginPoint.html +2 -2
- package/docs/classes/PanoMeasurePluginPolyline.html +2 -2
- package/docs/classes/PanoTagPluginController.html +2 -2
- package/docs/classes/Sculpt.html +2 -2
- package/docs/classes/Util.BetterTween.html +2 -2
- package/docs/classes/Util.FiveDomEvents.html +2 -2
- package/docs/classes/Util.FivePuppet.html +2 -2
- package/docs/classes/Util.Interval.html +2 -2
- package/docs/classes/Util.LegacyPointHelper.html +2 -2
- package/docs/classes/Util.LightTag.html +2 -2
- package/docs/classes/Util.LineSegments.html +2 -2
- package/docs/classes/Util.Magnifier.html +2 -2
- package/docs/classes/Util.Object3D.html +2 -2
- package/docs/classes/Util.PointDomHelper.html +2 -2
- package/docs/classes/Util.PointHelper.html +2 -2
- package/docs/classes/Util.PointSelector.html +2 -2
- package/docs/classes/Util.PointSelectorHelper.html +2 -2
- package/docs/classes/Util.Rectangle.html +2 -2
- package/docs/classes/Util.sculpt.BaseEditor.html +2 -2
- package/docs/classes/Util.sculpt.BoxMesh.html +2 -2
- package/docs/classes/Util.sculpt.BoxMeshEditor.html +2 -2
- package/docs/classes/Util.sculpt.CircleMesh.html +2 -2
- package/docs/classes/Util.sculpt.CircleMeshEditor.html +2 -2
- package/docs/classes/Util.sculpt.CircleWithEdgeMesh.html +2 -2
- package/docs/classes/Util.sculpt.CylinderMesh.html +2 -2
- package/docs/classes/Util.sculpt.CylinderMeshEditor.html +2 -2
- package/docs/classes/Util.sculpt.LineMesh.html +2 -2
- package/docs/classes/Util.sculpt.PointMesh.html +2 -2
- package/docs/classes/Util.sculpt.PolygonMesh.html +2 -2
- package/docs/classes/Util.sculpt.PrismMesh.html +2 -2
- package/docs/classes/Util.sculpt.PrismMeshEditor.html +2 -2
- package/docs/classes/Util.sculpt.RectangleMesh.html +2 -2
- package/docs/classes/Util.sculpt.RectangleMeshEditor.html +2 -2
- package/docs/classes/Util.sculpt.RectangleWithEdgeMesh.html +2 -2
- package/docs/classes/WalkController.html +2 -2
- package/docs/enums/CameraMovementEffect.html +2 -2
- package/docs/enums/ContentType.html +2 -2
- package/docs/enums/DIRECTION.html +2 -2
- package/docs/enums/DISPLAY_STRATEGY_TYPE.html +2 -2
- package/docs/enums/DimensionType.html +2 -2
- package/docs/enums/FLOOR_PLAN_ATTACHED_TO.html +2 -2
- package/docs/enums/ITEM_LABEL_PLUGIN_DISPLAY_STRATEGY_TYPE.html +2 -2
- package/docs/enums/PaintBrushTypeEnum.html +2 -2
- package/docs/enums/PointType.html +2 -2
- package/docs/enums/Rotation.html +2 -2
- package/docs/functions/AreaMakerPlugin.html +1 -1
- package/docs/functions/CSS3DRenderPlugin.html +1 -1
- package/docs/functions/CameraMovementPlugin.html +2 -2
- package/docs/functions/CruisePlugin.html +1 -1
- package/docs/functions/CurrentPanoImagePlugin.html +1 -1
- package/docs/functions/GuideLinePlugin.html +1 -1
- package/docs/functions/ItemLabelPlugin.html +1 -1
- package/docs/functions/MapviewFloorplanPlugin.html +1 -1
- package/docs/functions/MeasurePlugin.html +1 -1
- package/docs/functions/ModelChassisCompassPlugin.html +2 -2
- package/docs/functions/ModelEntryDoorGuidePlugin.html +2 -2
- package/docs/functions/ModelFloorplanPlugin.html +1 -1
- package/docs/functions/ModelItemLabelPlugin.html +1 -1
- package/docs/functions/ModelMakerPlugin.html +1 -1
- package/docs/functions/ModelRoomLabelPlugin.html +1 -1
- package/docs/functions/ModelTVVideoPlugin.html +1 -1
- package/docs/functions/ModelViewPlugin.html +2 -2
- package/docs/functions/MovePlugin.html +1 -1
- package/docs/functions/Object3DHelperPlugin.html +1 -1
- package/docs/functions/PanoCompassPlugin.html +1 -1
- package/docs/functions/PanoCursorRaycasterPlugin.html +2 -2
- package/docs/functions/PanoDoorLabelPlugin.html +1 -1
- package/docs/functions/PanoFloorplanRadarPlugin.html +1 -1
- package/docs/functions/PanoMeasurePlugin.html +1 -1
- package/docs/functions/PanoRulerPlugin.html +2 -2
- package/docs/functions/PanoRulerProPlugin.html +2 -2
- package/docs/functions/PanoSpatialTagPlugin.html +2 -2
- package/docs/functions/PanoTagPlugin.html +1 -1
- package/docs/functions/PanoVideoPlugin.html +2 -2
- package/docs/functions/PipelinePlugin.html +1 -1
- package/docs/functions/SculptPlugin.html +2 -2
- package/docs/functions/SculptPluginForFive.html +2 -2
- package/docs/functions/TopviewFloorplanPlugin.html +1 -1
- package/docs/functions/Util.awaitNextFrame.html +1 -1
- package/docs/functions/Util.blink.html +2 -2
- package/docs/functions/Util.bounding.html +1 -1
- package/docs/functions/Util.boundingBox.html +1 -1
- package/docs/functions/Util.boundingSphere.html +1 -1
- package/docs/functions/Util.boxVertex.html +2 -2
- package/docs/functions/Util.boxVertexes.html +1 -1
- package/docs/functions/Util.checkFiveModelLoaded.html +2 -2
- package/docs/functions/Util.convexHull.html +2 -2
- package/docs/functions/Util.equal.html +2 -2
- package/docs/functions/Util.fiveModelIsLoaded.html +2 -2
- package/docs/functions/Util.getCoordsFromClient.html +1 -1
- package/docs/functions/Util.getCoordsFromElement.html +1 -1
- package/docs/functions/Util.getFrameTime.html +2 -2
- package/docs/functions/Util.getIntersectFromRelativePosition.html +1 -1
- package/docs/functions/Util.getRaycasterFromFivePointer.html +1 -1
- package/docs/functions/Util.initialCSS3DRender.html +1 -1
- package/docs/functions/Util.inside.html +1 -1
- package/docs/functions/Util.isModelLike.html +1 -1
- package/docs/functions/Util.isNil.html +2 -2
- package/docs/functions/Util.isPanoramaLike.html +1 -1
- package/docs/functions/Util.lookObject.html +2 -2
- package/docs/functions/Util.lookPoint.html +2 -2
- package/docs/functions/Util.nextFrame.html +1 -1
- package/docs/functions/Util.notNil.html +2 -2
- package/docs/functions/Util.reblink.html +2 -2
- package/docs/functions/Util.replaceStaticPrefix.html +2 -2
- package/docs/functions/Util.requestAnimationFrameInterval.html +2 -2
- package/docs/functions/Util.sculpt.createBox.html +1 -1
- package/docs/functions/Util.sculpt.createCircle.html +1 -1
- package/docs/functions/Util.sculpt.createCylinder.html +1 -1
- package/docs/functions/Util.sculpt.createLine.html +2 -2
- package/docs/functions/Util.sculpt.createPoint.html +1 -1
- package/docs/functions/Util.sculpt.createPolygon.html +1 -1
- package/docs/functions/Util.sculpt.createPrism.html +1 -1
- package/docs/functions/Util.sculpt.createRectangle.html +2 -2
- package/docs/functions/Util.tag.html +1 -1
- package/docs/functions/Util.tweenProgress.html +1 -1
- package/docs/functions/Util.uuid.html +2 -2
- package/docs/functions/Util.waitFiveModelLoaded.html +2 -2
- package/docs/functions/Util.worldBounding.html +1 -1
- package/docs/functions/Util.worldBoundingBox.html +1 -1
- package/docs/functions/Util.worldBoundingSphere.html +1 -1
- package/docs/functions/createPolyline.html +2 -2
- package/docs/functions/pluginFlag.html +1 -1
- package/docs/hierarchy.html +1 -1
- package/docs/index.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.AnimeOptions.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.Config.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.EventMap.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.Params.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.ServerAreaMakerItem.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.ServerAreaMakerItemV1.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.ServerDataV1.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.ServerDataV2.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.ShowHideOptions.html +2 -2
- package/docs/interfaces/AreaMakerPluginType.State.html +2 -2
- package/docs/interfaces/CSS3DRenderPluginEventMap.html +2 -2
- package/docs/interfaces/CSS3DRenderPluginState.html +2 -2
- package/docs/interfaces/CameraMovementPluginExportType.html +2 -2
- package/docs/interfaces/ContentTypeMapInterface.html +2 -2
- package/docs/interfaces/CruisePluginTypes.Config.html +2 -2
- package/docs/interfaces/CruisePluginTypes.CruiseKeyframe.html +2 -2
- package/docs/interfaces/CruisePluginTypes.EventMap.html +2 -2
- package/docs/interfaces/CruisePluginTypes.GuildLineConfig.html +2 -2
- package/docs/interfaces/CruisePluginTypes.MoveAction.html +2 -2
- package/docs/interfaces/CruisePluginTypes.MoveWithKeyframesAction.html +2 -2
- package/docs/interfaces/CruisePluginTypes.MoveWithPanoIndexAction.html +2 -2
- package/docs/interfaces/CruisePluginTypes.PluginData.html +2 -2
- package/docs/interfaces/CruisePluginTypes.PluginServerData.html +2 -2
- package/docs/interfaces/CruisePluginTypes.PluginState.html +2 -2
- package/docs/interfaces/CurrentPanoImagePluginType.Config.html +2 -2
- package/docs/interfaces/CurrentPanoImagePluginType.EventMap.html +2 -2
- package/docs/interfaces/CurrentPanoImagePluginType.Params.html +2 -2
- package/docs/interfaces/CurrentPanoImagePluginType.ShowHideOptions.html +2 -2
- package/docs/interfaces/CurrentPanoImagePluginType.State.html +2 -2
- package/docs/interfaces/FloorplanBounding.html +2 -2
- package/docs/interfaces/FloorplanData.html +2 -2
- package/docs/interfaces/FloorplanEntrance.html +2 -2
- package/docs/interfaces/FloorplanExtraObject.html +2 -2
- package/docs/interfaces/FloorplanExtraObject3D.html +2 -2
- package/docs/interfaces/FloorplanFloorData.html +2 -2
- package/docs/interfaces/FloorplanImagePosition.html +2 -2
- package/docs/interfaces/FloorplanObserver.html +2 -2
- package/docs/interfaces/FloorplanOutlineItem.html +2 -2
- package/docs/interfaces/FloorplanPosition.html +2 -2
- package/docs/interfaces/FloorplanRoomItem.html +2 -2
- package/docs/interfaces/FloorplanRoomLabelItem.html +2 -2
- package/docs/interfaces/FloorplanServerBounding.html +2 -2
- package/docs/interfaces/FloorplanServerComputedData.html +2 -2
- package/docs/interfaces/FloorplanServerData.html +2 -2
- package/docs/interfaces/FloorplanServerDoorItem.html +2 -2
- package/docs/interfaces/FloorplanServerDoorPosition.html +2 -2
- package/docs/interfaces/FloorplanServerEntrance.html +2 -2
- package/docs/interfaces/FloorplanServerFloorData.html +2 -2
- package/docs/interfaces/FloorplanServerImagePosition.html +2 -2
- package/docs/interfaces/FloorplanServerObserver.html +2 -2
- package/docs/interfaces/FloorplanServerOutlineItem.html +2 -2
- package/docs/interfaces/FloorplanServerPosition.html +2 -2
- package/docs/interfaces/FloorplanServerRoomItem.html +2 -2
- package/docs/interfaces/FloorplanServerRoomLabelItem.html +2 -2
- package/docs/interfaces/GuideLineModeItem.GuideLineTagContainer.html +2 -2
- package/docs/interfaces/GuideLinePluginType.CatmullRomCurve3.html +2 -2
- package/docs/interfaces/GuideLinePluginType.EventMap.html +2 -2
- package/docs/interfaces/GuideLinePluginType.ExtraRouteData.html +2 -2
- package/docs/interfaces/GuideLinePluginType.GuideLineGeometryStyle.html +2 -2
- package/docs/interfaces/GuideLinePluginType.GuideLineItemContainer.html +2 -2
- package/docs/interfaces/GuideLinePluginType.GuideLineMaterialStyle.html +2 -2
- package/docs/interfaces/GuideLinePluginType.GuideLineMeshStyle.html +2 -2
- package/docs/interfaces/GuideLinePluginType.LineGeometriesConfig.html +2 -2
- package/docs/interfaces/GuideLinePluginType.ModelGuideLineStyle.html +2 -2
- package/docs/interfaces/GuideLinePluginType.ModelGuideLineTagData.html +2 -2
- package/docs/interfaces/GuideLinePluginType.PanoramaGuideLineStyle.html +2 -2
- package/docs/interfaces/GuideLinePluginType.PluginDataV2.html +1 -1
- package/docs/interfaces/GuideLinePluginType.PluginServerData.html +2 -2
- package/docs/interfaces/GuideLinePluginType.PluginState.html +2 -2
- package/docs/interfaces/GuideLinePluginType.Route.html +2 -2
- package/docs/interfaces/HelperOffset.html +2 -2
- package/docs/interfaces/ImagePlaneGroup.html +2 -2
- package/docs/interfaces/ItemLabelPluginData.html +2 -2
- package/docs/interfaces/ItemLabelPluginExportReturnsType.html +2 -2
- package/docs/interfaces/ItemLabelPluginParametersType.html +2 -2
- package/docs/interfaces/MinMax.html +2 -2
- package/docs/interfaces/ModelChassisCompassPluginData.html +2 -2
- package/docs/interfaces/ModelChassisCompassPluginExportType.html +2 -2
- package/docs/interfaces/ModelChassisCompassPluginParameterType.html +2 -2
- package/docs/interfaces/ModelEntryDoorGuidePluginData.html +2 -2
- package/docs/interfaces/ModelEntryDoorGuidePluginExportType.html +2 -2
- package/docs/interfaces/ModelItemLabelPluginData.html +2 -2
- package/docs/interfaces/ModelItemLabelPluginExportReturnsType.html +2 -2
- package/docs/interfaces/ModelItemLabelPluginParametersType.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.BoxItemObjectData.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.EventMap.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.PrismItemObjectData.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.ServerBaseItem.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.ServerBoxItem.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.ServerData.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.ServerPrismItem.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.ServerTrianglesItem.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.State.html +2 -2
- package/docs/interfaces/ModelMakerPluginType.TrianglesItemObjectData.html +2 -2
- package/docs/interfaces/ModelRoomLabelPluginData.html +2 -2
- package/docs/interfaces/ModelTVVideoPluginData.html +2 -2
- package/docs/interfaces/ModelTVVideoPluginExportType.html +2 -2
- package/docs/interfaces/ModelTVVideoPluginParameterType.html +2 -2
- package/docs/interfaces/ModelViewPluginExportType.html +2 -2
- package/docs/interfaces/Object3DHelperState.html +2 -2
- package/docs/interfaces/ObjectHelperControllers.html +2 -2
- package/docs/interfaces/PaintBrushAction.html +2 -2
- package/docs/interfaces/PaintBrushConfigs.html +2 -2
- package/docs/interfaces/PaintBrushState.html +2 -2
- package/docs/interfaces/PanoCursorRaycasterPluginExportType.html +2 -2
- package/docs/interfaces/PanoCursorRaycasterPluginParameterType.html +1 -1
- package/docs/interfaces/PanoMeasureParameterType.html +2 -2
- package/docs/interfaces/PanoMeasurePluginLineJson.html +2 -2
- package/docs/interfaces/PanoMeasurePluginOpenParameter.html +2 -2
- package/docs/interfaces/PanoMeasurePluginPointJson.html +2 -2
- package/docs/interfaces/PanoMeasurePluginPolylineJson.html +2 -2
- package/docs/interfaces/PanoRulerPluginExportType.html +2 -2
- package/docs/interfaces/PanoRulerPluginOptions.html +2 -2
- package/docs/interfaces/PanoRulerPluginParameterType.html +2 -2
- package/docs/interfaces/PanoRulerProPluginExportType.html +2 -2
- package/docs/interfaces/PanoRulerProPluginOptions.html +2 -2
- package/docs/interfaces/PanoRulerProPluginParameterType.html +2 -2
- package/docs/interfaces/PanoRulerProPluginState.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginContentEvent.html +1 -1
- package/docs/interfaces/PanoSpatialTagPluginContentReplacement.html +1 -1
- package/docs/interfaces/PanoSpatialTagPluginData.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginDataElement.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginExportType.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginOriginElement.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginParameterType.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginPointElement.html +2 -2
- package/docs/interfaces/PanoSpatialTagPluginTagElement.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.LoadParams.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.PanoVideoItem.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.PluginData.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.PluginEventMap.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.PluginState.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.VideoItem.html +2 -2
- package/docs/interfaces/PanoVideoPluginType.VideoMeshParams.html +2 -2
- package/docs/interfaces/PluginEventMap.html +2 -2
- package/docs/interfaces/Point.html +2 -2
- package/docs/interfaces/Room.html +2 -2
- package/docs/interfaces/RoomInfo.html +2 -2
- package/docs/interfaces/RoomLabel.html +2 -2
- package/docs/interfaces/RoomRules.html +1 -1
- package/docs/interfaces/Rooms.html +1 -1
- package/docs/interfaces/Scissor.html +2 -2
- package/docs/interfaces/SculptConfig.html +2 -2
- package/docs/interfaces/State.html +2 -2
- package/docs/interfaces/TagCacheInterface.html +2 -2
- package/docs/interfaces/TagConfig.html +2 -2
- package/docs/interfaces/TagGLTFObjectGroup.html +2 -2
- package/docs/interfaces/TagIconUrl.html +2 -2
- package/docs/interfaces/TagObjectGroup.html +2 -2
- package/docs/interfaces/TagState.html +2 -2
- package/docs/interfaces/TagStyle.html +2 -2
- package/docs/interfaces/Tags.html +2 -2
- package/docs/interfaces/TemporaryState.html +2 -2
- package/docs/interfaces/Util.AnimeInstance.html +2 -2
- package/docs/interfaces/Util.BlinkAnimeOptions.html +2 -2
- package/docs/interfaces/Util.EventHandlerConfig.html +2 -2
- package/docs/interfaces/Util.FiveDomEvent.html +2 -2
- package/docs/interfaces/Util.FiveDomEventMap.html +2 -2
- package/docs/interfaces/Util.LegacyMouseGroupParameter.html +2 -2
- package/docs/interfaces/Util.MagnifierParameter.html +2 -2
- package/docs/interfaces/Util.MouseGroupParameter.html +2 -2
- package/docs/interfaces/Util.PointIntersection.html +2 -2
- package/docs/interfaces/Util.PointSelectorHelperConfig.html +2 -2
- package/docs/interfaces/Util.ReBlinkAnimeOptions.html +2 -2
- package/docs/modules/AreaMakerPluginType.html +2 -2
- package/docs/modules/CruisePluginTypes.html +2 -2
- package/docs/modules/CurrentPanoImagePluginType.html +2 -2
- package/docs/modules/GuideLineItem.html +2 -2
- package/docs/modules/GuideLineModeItem.html +2 -2
- package/docs/modules/GuideLinePluginType.html +2 -2
- package/docs/modules/ModelMakerPluginType.html +2 -2
- package/docs/modules/PanoVideoPluginType.html +2 -2
- package/docs/modules/SculptData.html +2 -2
- package/docs/modules/SculptType.html +2 -2
- package/docs/modules/Util.html +2 -2
- package/docs/modules/Util.sculpt.html +2 -2
- package/docs/modules.html +2 -2
- package/docs/types/AddObject3DHelperConfig.html +2 -2
- package/docs/types/AreaMakerPluginType.AreaMakerItemEventMap.html +2 -2
- package/docs/types/AreaMakerPluginType.ItemRenderer.html +1 -1
- package/docs/types/AreaMakerPluginType.PluginData.html +2 -2
- package/docs/types/AreaMakerPluginType.ServerData.html +2 -2
- package/docs/types/ArrayPosition.html +1 -1
- package/docs/types/AudioAppearance.html +1 -1
- package/docs/types/CSS3DRenderExportType.html +1 -1
- package/docs/types/CSS3DRenderPluginExportType.html +1 -1
- package/docs/types/CSS3DRenderPluginParameterType.html +1 -1
- package/docs/types/ClassFunctionParameters.html +1 -1
- package/docs/types/Color.html +1 -1
- package/docs/types/ContentTypeConfigKey.html +1 -1
- package/docs/types/ContentTypeConfigKeySplit.html +1 -1
- package/docs/types/ContentTypeMap.html +1 -1
- package/docs/types/Create3DDomContainerReturnType.html +1 -1
- package/docs/types/Create3DElementReturnType.html +1 -1
- package/docs/types/CruisePluginExportType.html +1 -1
- package/docs/types/CruisePluginTypes.CruiseData.html +2 -2
- package/docs/types/CruisePluginTypes.MoveEffect.html +1 -1
- package/docs/types/CurrentPanoImagePluginExportType.html +1 -1
- package/docs/types/DeprecatedMediaPlaneProperty.html +2 -2
- package/docs/types/DeprecatedTagProperty.html +2 -2
- package/docs/types/Direction-1.html +1 -1
- package/docs/types/Direction4.html +1 -1
- package/docs/types/ElementRenderer.html +2 -2
- package/docs/types/FloorplanRuleLabels.html +2 -2
- package/docs/types/FloorplanServerRuleLabels.html +1 -1
- package/docs/types/GuideLinePluginExportType.html +1 -1
- package/docs/types/GuideLinePluginType.GuideLineItem.html +2 -2
- package/docs/types/GuideLinePluginType.GuideLineItemEventMap.html +1 -1
- package/docs/types/GuideLinePluginType.GuideLineModeItemMode.html +1 -1
- package/docs/types/GuideLinePluginType.GuideLineStyle.html +2 -2
- package/docs/types/GuideLinePluginType.ModelGuideLineTag.html +2 -2
- package/docs/types/GuideLinePluginType.PathItem.html +2 -2
- package/docs/types/GuideLinePluginType.PluginData.html +2 -2
- package/docs/types/GuideLinePluginType.RouteConfig.html +2 -2
- package/docs/types/HelperEventMap.html +1 -1
- package/docs/types/InternalHelperEventMap.html +1 -1
- package/docs/types/MapviewFloorplanPluginParameterType.html +1 -1
- package/docs/types/MapviewFloorplanPluginReturnType.html +1 -1
- package/docs/types/MeasureEndReason.html +1 -1
- package/docs/types/MeasurePluginConfig.html +2 -2
- package/docs/types/MediaData.html +2 -2
- package/docs/types/MediaStore.html +1 -1
- package/docs/types/ModelEntryDoorGuidePluginParameterType.html +1 -1
- package/docs/types/ModelFloorplanPluginParameterType.html +1 -1
- package/docs/types/ModelFloorplanPluginReturnType.html +1 -1
- package/docs/types/ModelId.html +1 -1
- package/docs/types/ModelMakerPluginType.ElementRenderer.html +1 -1
- package/docs/types/ModelMakerPluginType.ItemType.html +2 -2
- package/docs/types/ModelMakerPluginType.MarkerItem.html +1 -1
- package/docs/types/ModelMakerPluginType.ServerItem.html +2 -2
- package/docs/types/ModelRoomLabelPluginParameters.html +1 -1
- package/docs/types/ModelRoomLabelPluginReturnType.html +1 -1
- package/docs/types/MoveArgs.html +2 -2
- package/docs/types/MoveOpts.html +2 -2
- package/docs/types/Object3DHelperEventMap.html +1 -1
- package/docs/types/ObjectFit.html +1 -1
- package/docs/types/PaintBrushEventMap.html +1 -1
- package/docs/types/PanoCompassPluginData.html +1 -1
- package/docs/types/PanoCompassPluginExportType.html +1 -1
- package/docs/types/PanoCompassPluginParameterType.html +1 -1
- package/docs/types/PanoFloorplanRadarPluginParameterType.html +1 -1
- package/docs/types/PanoFloorplanRadarPluginReturnType.html +1 -1
- package/docs/types/PanoIndex.html +1 -1
- package/docs/types/PanoMeasurePluginEvent.html +1 -1
- package/docs/types/PanoMeasureReturnType.html +1 -1
- package/docs/types/PanoSpatialTagPluginId.html +1 -1
- package/docs/types/PanoTagPluginExportInterface.html +1 -1
- package/docs/types/PanoTagPluginParamsInterface.html +1 -1
- package/docs/types/PanoVideoPluginParameterType.html +1 -1
- package/docs/types/PanoVideoPluginReturnType.html +1 -1
- package/docs/types/PickTagContentTypeInContentTypeConfigKey.html +2 -2
- package/docs/types/PipelinePluginParameterType.html +1 -1
- package/docs/types/PipelinePluginReturnType.html +1 -1
- package/docs/types/PlaneTag.html +2 -2
- package/docs/types/Point2DTag.html +2 -2
- package/docs/types/Point3DTag.html +2 -2
- package/docs/types/PointTagInstance.html +1 -1
- package/docs/types/Position.html +1 -1
- package/docs/types/PositionFrom.html +1 -1
- package/docs/types/RotateArgs.html +2 -2
- package/docs/types/RotateOpts.html +2 -2
- package/docs/types/RuleLabelsKey.html +1 -1
- package/docs/types/RuleLabelsValue.html +1 -1
- package/docs/types/ScaleCallback.html +1 -1
- package/docs/types/ScalePosition.html +2 -2
- package/docs/types/SculptData.BoxData.html +1 -1
- package/docs/types/SculptData.CircleData.html +1 -1
- package/docs/types/SculptData.CylinderData.html +1 -1
- package/docs/types/SculptData.PointData.html +1 -1
- package/docs/types/SculptData.PolygonData.html +1 -1
- package/docs/types/SculptData.PolylineData.html +1 -1
- package/docs/types/SculptData.PrismData.html +1 -1
- package/docs/types/SculptData.RectangleData.html +1 -1
- package/docs/types/SculptType.Theme.html +2 -2
- package/docs/types/StickType.html +1 -1
- package/docs/types/Tag.html +2 -2
- package/docs/types/Tag2D.html +2 -2
- package/docs/types/Tag3D.html +2 -2
- package/docs/types/TagClickParams.html +1 -1
- package/docs/types/TagConfigByKey.html +1 -1
- package/docs/types/TagContentType.html +1 -1
- package/docs/types/TagContentTypeMapping.html +1 -1
- package/docs/types/TagDimensionType.html +1 -1
- package/docs/types/TagElement.html +2 -2
- package/docs/types/TagEvents.html +1 -1
- package/docs/types/TagGLTFObject.html +1 -1
- package/docs/types/TagHooks.html +1 -1
- package/docs/types/TagId.html +1 -1
- package/docs/types/TagInstance.html +1 -1
- package/docs/types/TagPlacement.html +2 -2
- package/docs/types/TagPointType.html +2 -2
- package/docs/types/TagRendererMap.html +1 -1
- package/docs/types/TopviewFloorplanPluginParameterType.html +1 -1
- package/docs/types/TopviewFloorplanPluginReturnType.html +1 -1
- package/docs/types/Util.ActionIfNoIntersection.html +1 -1
- package/docs/types/Util.AdherePoint.html +2 -2
- package/docs/types/Util.PointSelectorConfig.html +1 -1
- package/docs/types/WorkCode.html +1 -1
- package/docs/variables/FLOOR_TYPE_MAP.html +2 -2
- package/docs/variables/PLUGIN.html +1 -1
- package/docs/variables/ROOM_FETILE_TYPE_MAP.html +2 -2
- package/docs/variables/ROOM_TYPE_MAP.html +2 -2
- package/docs/variables/Util.CURRENT_PANO_IMAGE_DEFAULT_IMAGE.html +2 -2
- package/docs/variables/Util.DEFAULT_STATIC_PREFIX.html +2 -2
- package/docs/variables/Util.DNALOGEL_DEFAULT_ASSETS.html +2 -2
- package/docs/variables/Util.ENTRY_DOOR_DEFAULT_IMAGE.html +2 -2
- package/docs/variables/Util.FLOORPLAN_DEFAULT_IMAGE.html +2 -2
- package/docs/variables/Util.GUIDELINE_DEFAULT_ARROW_TEXTURE.html +2 -2
- package/docs/variables/Util.GUIDELINE_WHITE_ARROW_TEXTURE.html +2 -2
- package/docs/variables/Util.MODEL_CHASSIS_COMPASS_DEFAULT_MODEL.html +2 -2
- package/docs/variables/Util.MODEL_ENTRY_DOOR_GUIDE_PLUGIN_DEFAULT_MODEL.html +2 -2
- package/docs/variables/Util.PANO_COMPASS_DEFAULT_IMAGE.html +2 -2
- package/docs/variables/Util.PANO_SPATIAL_TAG_BLUR_IMAGE.html +2 -2
- package/docs/variables/Util.PANO_TAG_DEFAULT_LINK_ICON.html +2 -2
- package/docs/variables/Util.animeMap.html +1 -1
- package/docs/variables/defaultGlobalConfig.html +1 -1
- package/docs/variables/itemLabelPluginServerParams.html +1 -1
- package/docs/variables/modelItemLabelPluginServerParams.html +1 -1
- package/docs/variables/modelRoomLabelPluginServerParams.html +1 -1
- package/libs/DigitalPerformancePlugin/controller/index.d.ts +224 -0
- package/libs/DigitalPerformancePlugin/controller/index.js +865 -0
- package/libs/DigitalPerformancePlugin/core/DigitalHuman.d.ts +41 -0
- package/libs/DigitalPerformancePlugin/core/DigitalHuman.js +174 -0
- package/libs/DigitalPerformancePlugin/core/DigitalPlayground.d.ts +33 -0
- package/libs/DigitalPerformancePlugin/core/DigitalPlayground.js +155 -0
- package/libs/DigitalPerformancePlugin/core/DigitalStateMachine.d.ts +143 -0
- package/libs/DigitalPerformancePlugin/core/DigitalStateMachine.js +153 -0
- package/libs/DigitalPerformancePlugin/core/Trace.d.ts +9 -0
- package/libs/DigitalPerformancePlugin/core/Trace.js +23 -0
- package/libs/DigitalPerformancePlugin/index.d.ts +11 -0
- package/libs/DigitalPerformancePlugin/index.js +17 -0
- package/libs/DigitalPerformancePlugin/mock.d.ts +70 -0
- package/libs/DigitalPerformancePlugin/mock.js +371 -0
- package/libs/DigitalPerformancePlugin/typings/index.d.ts +79 -0
- package/libs/DigitalPerformancePlugin/typings/index.js +1 -0
- package/libs/base/BasePlugin.js +1 -1
- package/libs/components/AreaLabel/LabelItem.js +164 -136
- package/libs/shared-utils/logger.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import type { GLTFObject } from '@realsee/five/gltf-loader';
|
|
3
|
+
import { DigitalStateMachine } from './DigitalStateMachine';
|
|
4
|
+
import type { DigitalModelKeyframe, DigitalModelPlayerItem, DigitalModelPlayerEffect } from './DigitalStateMachine';
|
|
5
|
+
export declare class DigitalHuman {
|
|
6
|
+
model: GLTFObject;
|
|
7
|
+
keyframesManager: DigitalStateMachine;
|
|
8
|
+
keyframes: DigitalModelKeyframe[];
|
|
9
|
+
items: DigitalModelPlayerItem[];
|
|
10
|
+
effects: DigitalModelPlayerEffect[];
|
|
11
|
+
digitalPlayground: any;
|
|
12
|
+
private mixer;
|
|
13
|
+
private action;
|
|
14
|
+
state: {
|
|
15
|
+
currentTime: number;
|
|
16
|
+
currentAnimation: THREE.AnimationClip | null;
|
|
17
|
+
playing: boolean;
|
|
18
|
+
};
|
|
19
|
+
animationFrameId: number | null;
|
|
20
|
+
private itemMatrixMap;
|
|
21
|
+
private trace;
|
|
22
|
+
curveLine: THREE.Line;
|
|
23
|
+
effectsGroup: THREE.Group;
|
|
24
|
+
effectObjects: Map<string, THREE.Mesh>;
|
|
25
|
+
container: THREE.Group;
|
|
26
|
+
constructor(model: GLTFObject, digitalPlayground: any);
|
|
27
|
+
playAnimation(animation: THREE.AnimationClip, repeat: boolean, switchDuration: number): void;
|
|
28
|
+
pauseAnimation(): void;
|
|
29
|
+
stopAnimation(): void;
|
|
30
|
+
continueAnimation(): void;
|
|
31
|
+
attachItem(): void;
|
|
32
|
+
init(): void;
|
|
33
|
+
reset(): void;
|
|
34
|
+
play(option?: {
|
|
35
|
+
keyframes: DigitalModelKeyframe[];
|
|
36
|
+
items: DigitalModelPlayerItem[];
|
|
37
|
+
effects: DigitalModelPlayerEffect[];
|
|
38
|
+
}): Promise<boolean>;
|
|
39
|
+
traceUpDate(): void;
|
|
40
|
+
clearTrace(): void;
|
|
41
|
+
}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
var P = Object.defineProperty;
|
|
2
|
+
var L = (u, e, s) => e in u ? P(u, e, { enumerable: !0, configurable: !0, writable: !0, value: s }) : u[e] = s;
|
|
3
|
+
var n = (u, e, s) => (L(u, typeof e != "symbol" ? e + "" : e, s), s);
|
|
4
|
+
var I = (u, e, s) => new Promise((y, c) => {
|
|
5
|
+
var r = (h) => {
|
|
6
|
+
try {
|
|
7
|
+
p(s.next(h));
|
|
8
|
+
} catch (w) {
|
|
9
|
+
c(w);
|
|
10
|
+
}
|
|
11
|
+
}, M = (h) => {
|
|
12
|
+
try {
|
|
13
|
+
p(s.throw(h));
|
|
14
|
+
} catch (w) {
|
|
15
|
+
c(w);
|
|
16
|
+
}
|
|
17
|
+
}, p = (h) => h.done ? y(h.value) : Promise.resolve(h.value).then(r, M);
|
|
18
|
+
p((s = s.apply(u, e)).next());
|
|
19
|
+
});
|
|
20
|
+
import * as t from "three";
|
|
21
|
+
import { DigitalStateMachine as S } from "./DigitalStateMachine.js";
|
|
22
|
+
import { Trace as B } from "./Trace.js";
|
|
23
|
+
const q = 300;
|
|
24
|
+
class D {
|
|
25
|
+
constructor(e, s) {
|
|
26
|
+
n(this, "model");
|
|
27
|
+
n(this, "keyframesManager");
|
|
28
|
+
n(this, "keyframes");
|
|
29
|
+
n(this, "items");
|
|
30
|
+
n(this, "effects");
|
|
31
|
+
n(this, "digitalPlayground");
|
|
32
|
+
n(this, "mixer");
|
|
33
|
+
n(this, "action");
|
|
34
|
+
n(this, "state");
|
|
35
|
+
n(this, "animationFrameId");
|
|
36
|
+
n(this, "itemMatrixMap");
|
|
37
|
+
n(this, "trace");
|
|
38
|
+
n(this, "curveLine");
|
|
39
|
+
n(this, "effectsGroup");
|
|
40
|
+
n(this, "effectObjects");
|
|
41
|
+
n(this, "container");
|
|
42
|
+
this.model = e, this.model.visible = !1, this.model.mixer = null, this.mixer = new t.AnimationMixer(this.model), this.action = null, this.keyframesManager = new S(), this.keyframes = [], this.items = [], this.effects = [], this.digitalPlayground = s, this.state = {
|
|
43
|
+
currentTime: 0,
|
|
44
|
+
currentAnimation: null,
|
|
45
|
+
playing: !1
|
|
46
|
+
}, this.animationFrameId = null, this.itemMatrixMap = /* @__PURE__ */ new Map(), this.trace = new B(), this.curveLine = new t.Line(), this.curveLine.material = new t.LineBasicMaterial({ color: 14467195, linewidth: 5 }), this.effectsGroup = new t.Group(), this.effectObjects = /* @__PURE__ */ new Map(), this.container = new t.Group(), this.container.add(this.model), this.container.add(this.curveLine), this.container.add(this.effectsGroup);
|
|
47
|
+
}
|
|
48
|
+
playAnimation(e, s, y) {
|
|
49
|
+
const c = this.action, r = this.mixer.clipAction(e);
|
|
50
|
+
r.reset(), s || (r.setLoop(t.LoopOnce, 1), r.clampWhenFinished = !0), c && (r.enabled = !0, r.setEffectiveTimeScale(1), r.crossFadeFrom(c, y / 1e3, !0)), r.play(), c && c !== r && setTimeout(() => {
|
|
51
|
+
c.stop();
|
|
52
|
+
}, y), this.action = r;
|
|
53
|
+
}
|
|
54
|
+
pauseAnimation() {
|
|
55
|
+
this.action && (this.action.paused = !0), this.animationFrameId && (cancelAnimationFrame(this.animationFrameId), this.animationFrameId = null), this.state.playing = !1;
|
|
56
|
+
}
|
|
57
|
+
stopAnimation() {
|
|
58
|
+
this.state.currentAnimation = null, this.mixer.stopAllAction(), this.state.playing = !1;
|
|
59
|
+
}
|
|
60
|
+
continueAnimation() {
|
|
61
|
+
this.action && (this.action.paused = !1), this.animationFrameId && (cancelAnimationFrame(this.animationFrameId), this.animationFrameId = null), this.keyframes.length > 0 && this.play(), this.state.playing = !0;
|
|
62
|
+
}
|
|
63
|
+
attachItem() {
|
|
64
|
+
}
|
|
65
|
+
init() {
|
|
66
|
+
this.state.currentTime = 0, this.model.position.copy(new t.Vector3().fromArray(this.keyframes[0].position)), this.model.quaternion.copy(new t.Quaternion().fromArray(this.keyframes[0].quaternion)), this.model.visible = this.keyframes[0].visible;
|
|
67
|
+
}
|
|
68
|
+
reset() {
|
|
69
|
+
this.state.currentTime = 0, this.keyframes && this.keyframes.length > 0 && (this.model.position.copy(new t.Vector3().fromArray(this.keyframes[0].position)), this.model.quaternion.copy(new t.Quaternion().fromArray(this.keyframes[0].quaternion))), this.model.visible = !1, this.container.visible = !1, this.animationFrameId && cancelAnimationFrame(this.animationFrameId), this.stopAnimation(), this.clearTrace(), this.state.playing = !1;
|
|
70
|
+
}
|
|
71
|
+
play(e) {
|
|
72
|
+
return I(this, null, function* () {
|
|
73
|
+
const { keyframes: s, items: y, effects: c } = e || {};
|
|
74
|
+
return this.keyframes = s || this.keyframes, this.items = y || this.items, this.effects = c || this.effects, this.state.currentAnimation = null, this.state.playing = !0, new Promise((r, M) => {
|
|
75
|
+
this.state.currentTime || this.init();
|
|
76
|
+
let p = null;
|
|
77
|
+
for (let o = 0; o < this.items.length; o++) {
|
|
78
|
+
const m = this.digitalPlayground.getDigitalItem(this.items[o].model);
|
|
79
|
+
if (m) {
|
|
80
|
+
let i = null;
|
|
81
|
+
const d = this.model.children[0].children.find((f) => f instanceof t.Bone), g = this.model.children[0].children.find((f) => f instanceof t.SkinnedMesh);
|
|
82
|
+
if (!d || !g)
|
|
83
|
+
throw new Error("模型骨骼缺失");
|
|
84
|
+
if (this.model.children[0].children[2].traverse((f) => {
|
|
85
|
+
f instanceof t.Bone && f.name === "RightHand" && (i = f);
|
|
86
|
+
}), !i)
|
|
87
|
+
throw new Error("没有找到绑定的骨骼");
|
|
88
|
+
i.add(m);
|
|
89
|
+
const a = new t.Vector3(), l = new t.Quaternion(), A = new t.Vector3();
|
|
90
|
+
new t.Matrix4().fromArray(this.items[o].initialMatrix).decompose(a, l, A), m.position.copy(a), m.quaternion.copy(l), m.scale.copy(A), m.updateMatrixWorld(!0);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
const h = /* @__PURE__ */ new Map(), w = new t.TextureLoader();
|
|
94
|
+
for (let o = 0; o < this.effects.length; o++) {
|
|
95
|
+
const m = this.effects[o];
|
|
96
|
+
if (m.type === "frameSequence") {
|
|
97
|
+
const i = m.keyframes;
|
|
98
|
+
for (let d = 0; d < i.length; d++)
|
|
99
|
+
w.load(i[d].image, (g) => {
|
|
100
|
+
g.name = i[d].image, h.set(i[d].image, g);
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
const v = (o) => {
|
|
105
|
+
var g;
|
|
106
|
+
p === null && (p = o);
|
|
107
|
+
const m = o - p;
|
|
108
|
+
p = o, this.state.currentTime += m;
|
|
109
|
+
const i = this.keyframesManager.getStateByTime(this.state.currentTime, this.keyframes, "model");
|
|
110
|
+
this.trace.addPoint(i.translation);
|
|
111
|
+
const d = new t.BufferGeometry().setFromPoints(this.trace.tracePoints);
|
|
112
|
+
if (this.curveLine.geometry = d, this.model.position.copy(i.translation), this.model.quaternion.copy(i.quaternion), this.model.scale.copy(i.scale), this.model.visible = i.visible, i.isFinal) {
|
|
113
|
+
this.model.visible = !1, this.container.visible = !1, this.stopAnimation(), this.model.needsRender = !0, r(!0), this.animationFrameId !== null && (cancelAnimationFrame(this.animationFrameId), this.animationFrameId = null);
|
|
114
|
+
return;
|
|
115
|
+
} else if (i.animation) {
|
|
116
|
+
const a = this.digitalPlayground.getAnimation(i.animation.url);
|
|
117
|
+
a !== this.state.currentAnimation && (this.state.currentAnimation = a, this.playAnimation(
|
|
118
|
+
a,
|
|
119
|
+
i.animation.repeat,
|
|
120
|
+
(g = i.animation.switchDuration) != null ? g : q
|
|
121
|
+
)), this.mixer.update(m / 1e3), i.animation.isOver === !0 && (this.action.paused = !0, this.action.time = this.state.currentAnimation.duration, this.mixer.update(0));
|
|
122
|
+
}
|
|
123
|
+
for (let a = 0; a < this.items.length; a++) {
|
|
124
|
+
const l = this.digitalPlayground.getDigitalItem(this.items[a].model);
|
|
125
|
+
l && (this.keyframesManager.getStateByTime(
|
|
126
|
+
this.state.currentTime,
|
|
127
|
+
this.items[a].keyframes,
|
|
128
|
+
"item"
|
|
129
|
+
).visible === !0 ? l.visible = !0 : l.visible = !1);
|
|
130
|
+
}
|
|
131
|
+
for (let a = 0; a < this.effects.length; a++) {
|
|
132
|
+
const l = this.effects[a];
|
|
133
|
+
if (l.type === "frameSequence") {
|
|
134
|
+
const A = l.type + a;
|
|
135
|
+
if (!this.effectObjects.has(A)) {
|
|
136
|
+
const b = new t.PlaneGeometry(1, 1), x = new t.MeshBasicMaterial({
|
|
137
|
+
transparent: !0
|
|
138
|
+
}), F = new t.Mesh(b, x);
|
|
139
|
+
F.rotateX(-Math.PI / 2), F.position.copy(new t.Vector3().fromArray(l.position)), this.effectObjects.set(A, F), this.effectsGroup.add(F);
|
|
140
|
+
}
|
|
141
|
+
const k = this.effectObjects.get(A), f = this.keyframesManager.getStateByTime(
|
|
142
|
+
this.state.currentTime,
|
|
143
|
+
this.effects[a].keyframes,
|
|
144
|
+
"effect"
|
|
145
|
+
), T = h.get(f.image);
|
|
146
|
+
k.material.map = T, k.visible = f.visible;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
this.model.needsRender = !0, this.animationFrameId = requestAnimationFrame(v);
|
|
150
|
+
};
|
|
151
|
+
this.animationFrameId && (cancelAnimationFrame(this.animationFrameId), this.animationFrameId = null), this.animationFrameId = requestAnimationFrame(v);
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
// 用于分段时 更新轨迹
|
|
156
|
+
traceUpDate() {
|
|
157
|
+
this.trace.clear();
|
|
158
|
+
for (let e = 0; e <= this.state.currentTime; e += 100) {
|
|
159
|
+
const s = this.keyframesManager.getStateByTime(e, this.keyframes, "model");
|
|
160
|
+
this.trace.addPoint(s.translation);
|
|
161
|
+
const y = new t.BufferGeometry().setFromPoints(this.trace.tracePoints);
|
|
162
|
+
this.curveLine.geometry = y;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
// 清楚轨迹
|
|
166
|
+
clearTrace() {
|
|
167
|
+
this.trace.clear();
|
|
168
|
+
const e = new t.BufferGeometry().setFromPoints(this.trace.tracePoints);
|
|
169
|
+
this.curveLine.geometry = e;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
export {
|
|
173
|
+
D as DigitalHuman
|
|
174
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
import { GLTFLoader } from '@realsee/five/gltf-loader';
|
|
3
|
+
import { DigitalHuman } from './DigitalHuman';
|
|
4
|
+
import type { DigitalScript, DigitalChapter } from './DigitalStateMachine';
|
|
5
|
+
export declare class DigitalPlayground {
|
|
6
|
+
gltfLoader: GLTFLoader;
|
|
7
|
+
private digitalHumanMap;
|
|
8
|
+
private digitalItemMap;
|
|
9
|
+
private skeletalAnimationMap;
|
|
10
|
+
script: DigitalScript | null;
|
|
11
|
+
currentChapter: DigitalChapter | null;
|
|
12
|
+
private debugMode;
|
|
13
|
+
constructor(debugMode?: boolean);
|
|
14
|
+
setScript(script: DigitalScript): void;
|
|
15
|
+
loadModel(url: string, id?: string): Promise<DigitalHuman>;
|
|
16
|
+
loadModels(urls: string[], ids?: string[]): Promise<DigitalHuman[]>;
|
|
17
|
+
loadAnimation(url: string): Promise<THREE.AnimationClip>;
|
|
18
|
+
loadAnimations(urls: string[]): Promise<THREE.AnimationClip[]>;
|
|
19
|
+
getAnimation(url: string): THREE.AnimationClip | null;
|
|
20
|
+
getDigitalHuman(url: string, id?: string): DigitalHuman | null;
|
|
21
|
+
playByChapter(chapter: DigitalChapter): Promise<any[]>;
|
|
22
|
+
loadItems(urls: string[]): Promise<any[]>;
|
|
23
|
+
loadItem(url: string): Promise<any>;
|
|
24
|
+
getDigitalItem(url: string): any | null;
|
|
25
|
+
pause(): void;
|
|
26
|
+
continue(): void;
|
|
27
|
+
reset(): void;
|
|
28
|
+
setTimelineTo(time: number): void;
|
|
29
|
+
/**
|
|
30
|
+
* 销毁 playground
|
|
31
|
+
*/
|
|
32
|
+
dispose(): void;
|
|
33
|
+
}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
var d = Object.defineProperty;
|
|
2
|
+
var g = (n, t, e) => t in n ? d(n, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : n[t] = e;
|
|
3
|
+
var r = (n, t, e) => (g(n, typeof t != "symbol" ? t + "" : t, e), e);
|
|
4
|
+
var o = (n, t, e) => new Promise((a, i) => {
|
|
5
|
+
var l = (m) => {
|
|
6
|
+
try {
|
|
7
|
+
s(e.next(m));
|
|
8
|
+
} catch (p) {
|
|
9
|
+
i(p);
|
|
10
|
+
}
|
|
11
|
+
}, h = (m) => {
|
|
12
|
+
try {
|
|
13
|
+
s(e.throw(m));
|
|
14
|
+
} catch (p) {
|
|
15
|
+
i(p);
|
|
16
|
+
}
|
|
17
|
+
}, s = (m) => m.done ? a(m.value) : Promise.resolve(m.value).then(l, h);
|
|
18
|
+
s((e = e.apply(n, t)).next());
|
|
19
|
+
});
|
|
20
|
+
import { GLTFLoader as c } from "@realsee/five/gltf-loader";
|
|
21
|
+
import { DigitalHuman as u } from "./DigitalHuman.js";
|
|
22
|
+
import "three";
|
|
23
|
+
import "./DigitalStateMachine.js";
|
|
24
|
+
import "./Trace.js";
|
|
25
|
+
class k {
|
|
26
|
+
constructor(t = !1) {
|
|
27
|
+
r(this, "gltfLoader");
|
|
28
|
+
r(this, "digitalHumanMap");
|
|
29
|
+
r(this, "digitalItemMap");
|
|
30
|
+
r(this, "skeletalAnimationMap");
|
|
31
|
+
r(this, "script");
|
|
32
|
+
r(this, "currentChapter");
|
|
33
|
+
r(this, "debugMode");
|
|
34
|
+
this.gltfLoader = new c(), this.digitalHumanMap = /* @__PURE__ */ new Map(), this.digitalItemMap = /* @__PURE__ */ new Map(), this.skeletalAnimationMap = /* @__PURE__ */ new Map(), this.script = null, this.currentChapter = null, this.debugMode = t;
|
|
35
|
+
}
|
|
36
|
+
setScript(t) {
|
|
37
|
+
this.script = t;
|
|
38
|
+
}
|
|
39
|
+
loadModel(t, e) {
|
|
40
|
+
return o(this, null, function* () {
|
|
41
|
+
const a = e ? `${t}_${e}` : t;
|
|
42
|
+
if (this.digitalHumanMap.has(a)) {
|
|
43
|
+
const i = this.digitalHumanMap.get(a);
|
|
44
|
+
return Promise.resolve(i);
|
|
45
|
+
} else
|
|
46
|
+
return new Promise((i, l) => {
|
|
47
|
+
t.endsWith(".gltf") || t.endsWith(".glb") ? this.gltfLoader.load(t, ({ scene: h }) => {
|
|
48
|
+
const s = new u(h, this);
|
|
49
|
+
this.digitalHumanMap.set(a, s), i(s);
|
|
50
|
+
}) : l(new Error("不支持的模型格式"));
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
loadModels(t, e) {
|
|
55
|
+
return o(this, null, function* () {
|
|
56
|
+
return e && e.length === t.length ? Promise.all(t.map((a, i) => this.loadModel(a, e[i]))) : Promise.all(t.map((a) => this.loadModel(a)));
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
// 加载骨骼动画,暂且认为一个glb只包含一个骨骼动画
|
|
60
|
+
loadAnimation(t) {
|
|
61
|
+
return o(this, null, function* () {
|
|
62
|
+
if (this.skeletalAnimationMap.has(t)) {
|
|
63
|
+
const e = this.skeletalAnimationMap.get(t);
|
|
64
|
+
return Promise.resolve(e);
|
|
65
|
+
} else
|
|
66
|
+
return new Promise((e, a) => {
|
|
67
|
+
this.gltfLoader.load(t, ({ animations: i }) => {
|
|
68
|
+
const l = i[0];
|
|
69
|
+
this.skeletalAnimationMap.set(t, l), e(l);
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
loadAnimations(t) {
|
|
75
|
+
return o(this, null, function* () {
|
|
76
|
+
return Promise.all(t.map((e) => this.loadAnimation(e)));
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
getAnimation(t) {
|
|
80
|
+
return this.skeletalAnimationMap.get(t) || null;
|
|
81
|
+
}
|
|
82
|
+
getDigitalHuman(t, e) {
|
|
83
|
+
const a = e ? `${t}_${e}` : t;
|
|
84
|
+
return this.digitalHumanMap.get(a) || null;
|
|
85
|
+
}
|
|
86
|
+
playByChapter(t) {
|
|
87
|
+
return o(this, null, function* () {
|
|
88
|
+
if (!t || !Array.isArray(t.players))
|
|
89
|
+
throw new Error("Invalid chapter: chapter or chapter.players is undefined");
|
|
90
|
+
this.currentChapter = t;
|
|
91
|
+
const e = t.players.filter((i) => i.type === "model");
|
|
92
|
+
this.digitalHumanMap.forEach((i) => {
|
|
93
|
+
i.model.visible = !1, i.container.visible = !1;
|
|
94
|
+
});
|
|
95
|
+
const a = [];
|
|
96
|
+
for (let i = 0; i < e.length; i++) {
|
|
97
|
+
const l = e[i], h = `${l.model}_${l.id}`, s = this.digitalHumanMap.get(h);
|
|
98
|
+
s && (s.model.visible = !0, s.container.visible = !0, a.push(s.play({ keyframes: l.keyframes, items: [], effects: [] })));
|
|
99
|
+
}
|
|
100
|
+
return Promise.all(a);
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
loadItems(t) {
|
|
104
|
+
return o(this, null, function* () {
|
|
105
|
+
return Promise.all(t.map((e) => this.loadItem(e)));
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
loadItem(t) {
|
|
109
|
+
return o(this, null, function* () {
|
|
110
|
+
if (this.digitalItemMap.has(t)) {
|
|
111
|
+
const e = this.digitalItemMap.get(t);
|
|
112
|
+
return Promise.resolve(e);
|
|
113
|
+
} else
|
|
114
|
+
return new Promise((e, a) => {
|
|
115
|
+
t.endsWith(".gltf") || t.endsWith(".glb") ? this.gltfLoader.load(t, ({ scene: i }) => {
|
|
116
|
+
this.digitalItemMap.set(t, i), e(i);
|
|
117
|
+
}) : a(new Error("不支持的模型格式"));
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
getDigitalItem(t) {
|
|
122
|
+
return this.digitalItemMap.get(t) || null;
|
|
123
|
+
}
|
|
124
|
+
pause() {
|
|
125
|
+
this.digitalHumanMap.forEach((t) => {
|
|
126
|
+
t.pauseAnimation();
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
continue() {
|
|
130
|
+
this.digitalHumanMap.forEach((t) => {
|
|
131
|
+
t.continueAnimation();
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
reset() {
|
|
135
|
+
this.digitalHumanMap.forEach((t) => {
|
|
136
|
+
t.reset();
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
setTimelineTo(t) {
|
|
140
|
+
this.digitalHumanMap.forEach((e) => {
|
|
141
|
+
e.state.currentTime = t;
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* 销毁 playground
|
|
146
|
+
*/
|
|
147
|
+
dispose() {
|
|
148
|
+
this.digitalHumanMap.forEach((t) => {
|
|
149
|
+
t.reset();
|
|
150
|
+
}), this.digitalHumanMap.clear(), this.digitalItemMap.clear(), this.skeletalAnimationMap.clear();
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
export {
|
|
154
|
+
k as DigitalPlayground
|
|
155
|
+
};
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import * as THREE from 'three';
|
|
2
|
+
interface DigitalScript {
|
|
3
|
+
name: string;
|
|
4
|
+
uuid: string;
|
|
5
|
+
assets: {
|
|
6
|
+
models: string[];
|
|
7
|
+
animations: string[];
|
|
8
|
+
};
|
|
9
|
+
chapters: DigitalChapter[];
|
|
10
|
+
}
|
|
11
|
+
interface DigitalDataPlayer {
|
|
12
|
+
name: string;
|
|
13
|
+
type: 'data';
|
|
14
|
+
data: DigitalModelKeyframe[];
|
|
15
|
+
}
|
|
16
|
+
interface DigitalModelPlayerItem {
|
|
17
|
+
name: string;
|
|
18
|
+
initialMatrix: number[];
|
|
19
|
+
attachedBone: string;
|
|
20
|
+
model: string;
|
|
21
|
+
keyframes: DigitalItemKeyframe[];
|
|
22
|
+
}
|
|
23
|
+
interface DigitalEffectKeyframe {
|
|
24
|
+
timeStamp: number;
|
|
25
|
+
image: string;
|
|
26
|
+
visible: boolean;
|
|
27
|
+
}
|
|
28
|
+
interface DigitalModelPlayerEffect {
|
|
29
|
+
type: 'frameSequence';
|
|
30
|
+
position: number[];
|
|
31
|
+
keyframes: DigitalEffectKeyframe[];
|
|
32
|
+
}
|
|
33
|
+
interface DigitalModelPlayer {
|
|
34
|
+
id: string;
|
|
35
|
+
name: string;
|
|
36
|
+
type: 'model';
|
|
37
|
+
model: string;
|
|
38
|
+
keyframes: DigitalModelKeyframe[];
|
|
39
|
+
items: DigitalModelPlayerItem[];
|
|
40
|
+
effects: DigitalModelPlayerEffect[];
|
|
41
|
+
}
|
|
42
|
+
interface DigitalSubTitlePlayer {
|
|
43
|
+
name: string;
|
|
44
|
+
type: 'subTitle';
|
|
45
|
+
keyframes: DigitalSubTitleKeyframe[];
|
|
46
|
+
}
|
|
47
|
+
interface DigitalCameraPlayer {
|
|
48
|
+
name: string;
|
|
49
|
+
type: 'camera';
|
|
50
|
+
keyframes: DigitalCameraKeyframe[];
|
|
51
|
+
}
|
|
52
|
+
interface DigitalChapter {
|
|
53
|
+
name: string;
|
|
54
|
+
players: Array<DigitalModelPlayer | DigitalSubTitlePlayer | DigitalCameraPlayer>;
|
|
55
|
+
}
|
|
56
|
+
interface DigitalItemKeyframe {
|
|
57
|
+
timeStamp: number;
|
|
58
|
+
visible: boolean;
|
|
59
|
+
}
|
|
60
|
+
interface DigitalCameraKeyframe {
|
|
61
|
+
timeStamp: number;
|
|
62
|
+
matrix: number[];
|
|
63
|
+
fov: number;
|
|
64
|
+
}
|
|
65
|
+
interface DigitalSubTitleKeyframe {
|
|
66
|
+
visible: boolean;
|
|
67
|
+
timeStamp: number;
|
|
68
|
+
title: string;
|
|
69
|
+
content: string;
|
|
70
|
+
audio?: string;
|
|
71
|
+
image?: string;
|
|
72
|
+
}
|
|
73
|
+
interface DigitalModelKeyframe {
|
|
74
|
+
visible: boolean;
|
|
75
|
+
timeStamp: number;
|
|
76
|
+
animation?: {
|
|
77
|
+
url: string;
|
|
78
|
+
repeat: boolean;
|
|
79
|
+
isOver?: boolean;
|
|
80
|
+
switchDuration?: number;
|
|
81
|
+
};
|
|
82
|
+
position: number[];
|
|
83
|
+
interpolationType?: 'linear' | 'parabola';
|
|
84
|
+
quaternion: number[];
|
|
85
|
+
scale: number[];
|
|
86
|
+
adddon?: {
|
|
87
|
+
text?: string;
|
|
88
|
+
audio?: string;
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
interface DigitalDataKeyframe {
|
|
92
|
+
timeStamp: number;
|
|
93
|
+
data: any;
|
|
94
|
+
}
|
|
95
|
+
interface DigitalModelState {
|
|
96
|
+
translation: THREE.Vector3;
|
|
97
|
+
quaternion: THREE.Quaternion;
|
|
98
|
+
scale: THREE.Vector3;
|
|
99
|
+
animation?: DigitalModelKeyframe['animation'];
|
|
100
|
+
keyframeIndex: number;
|
|
101
|
+
visible: boolean;
|
|
102
|
+
isFinal: boolean;
|
|
103
|
+
}
|
|
104
|
+
interface DigitalSubTitleState {
|
|
105
|
+
title: string;
|
|
106
|
+
content: string;
|
|
107
|
+
audio?: string;
|
|
108
|
+
image?: string;
|
|
109
|
+
keyframeIndex: number;
|
|
110
|
+
}
|
|
111
|
+
interface DigitalCameraState {
|
|
112
|
+
matrix: number[];
|
|
113
|
+
fov: number;
|
|
114
|
+
transitionType: 'linear' | 'instant';
|
|
115
|
+
}
|
|
116
|
+
interface DigitalDataState {
|
|
117
|
+
currentFrameData: DigitalDataKeyframe['data'];
|
|
118
|
+
nextFrameData: DigitalDataKeyframe['data'] | null;
|
|
119
|
+
progress: number;
|
|
120
|
+
}
|
|
121
|
+
interface DigitalItemState {
|
|
122
|
+
timeStamp: number;
|
|
123
|
+
visible: boolean;
|
|
124
|
+
}
|
|
125
|
+
interface DigitalEffectState {
|
|
126
|
+
image: string;
|
|
127
|
+
visible: boolean;
|
|
128
|
+
}
|
|
129
|
+
type KeyframeType<T> = T extends 'model' ? DigitalModelKeyframe : T extends 'camera' ? DigitalCameraKeyframe : T extends 'subtitle' ? DigitalSubTitleKeyframe : T extends 'data' ? DigitalDataKeyframe : T extends 'item' ? DigitalItemKeyframe : T extends 'effect' ? DigitalEffectKeyframe : never;
|
|
130
|
+
type StateType<T> = T extends 'model' ? DigitalModelState : T extends 'camera' ? DigitalCameraState : T extends 'subtitle' ? DigitalSubTitleState : T extends 'data' ? DigitalDataState : T extends 'item' ? DigitalItemState : T extends 'effect' ? DigitalEffectState : never;
|
|
131
|
+
declare class DigitalStateMachine {
|
|
132
|
+
constructor();
|
|
133
|
+
getStateByTime<T extends 'model' | 'camera' | 'subtitle' | 'data' | 'item' | 'effect'>(time: number, keyframes: Array<KeyframeType<T>>, type: T): StateType<T>;
|
|
134
|
+
private getDataStateByTime;
|
|
135
|
+
private getEffectStateByTime;
|
|
136
|
+
private getItemStateByTime;
|
|
137
|
+
private getCameraStateByTime;
|
|
138
|
+
private getSubtitleStateByTime;
|
|
139
|
+
private getModelStateByTime;
|
|
140
|
+
private getKeyframeIndexByTime;
|
|
141
|
+
}
|
|
142
|
+
export { DigitalStateMachine };
|
|
143
|
+
export type { DigitalModelPlayerEffect, DigitalEffectKeyframe, DigitalDataState, DigitalModelPlayerItem, DigitalDataPlayer, DigitalCameraKeyframe, DigitalChapter, DigitalModelKeyframe, DigitalScript, DigitalSubTitleKeyframe, DigitalModelPlayer, DigitalSubTitlePlayer, DigitalCameraPlayer, DigitalModelState, DigitalSubTitleState, DigitalCameraState, KeyframeType, StateType, };
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import * as n from "three";
|
|
2
|
+
class T {
|
|
3
|
+
constructor() {
|
|
4
|
+
}
|
|
5
|
+
getStateByTime(r, t, e) {
|
|
6
|
+
switch (e) {
|
|
7
|
+
case "model":
|
|
8
|
+
return this.getModelStateByTime(r, t);
|
|
9
|
+
case "camera":
|
|
10
|
+
return this.getCameraStateByTime(r, t);
|
|
11
|
+
case "subtitle":
|
|
12
|
+
return this.getSubtitleStateByTime(r, t);
|
|
13
|
+
case "data":
|
|
14
|
+
return this.getDataStateByTime(r, t);
|
|
15
|
+
case "item":
|
|
16
|
+
return this.getItemStateByTime(r, t);
|
|
17
|
+
case "effect":
|
|
18
|
+
return this.getEffectStateByTime(r, t);
|
|
19
|
+
default:
|
|
20
|
+
throw new Error(`Unsupported type: ${e}`);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
getDataStateByTime(r, t) {
|
|
24
|
+
const e = this.getKeyframeIndexByTime(r, t);
|
|
25
|
+
if (e === t.length - 1)
|
|
26
|
+
return {
|
|
27
|
+
currentFrameData: t[e].data,
|
|
28
|
+
nextFrameData: null,
|
|
29
|
+
progress: 0
|
|
30
|
+
};
|
|
31
|
+
{
|
|
32
|
+
const a = t[e].data, o = t[e + 1].data, i = t[e + 1].timeStamp - t[e].timeStamp, l = (r - t[e].timeStamp) / i;
|
|
33
|
+
return {
|
|
34
|
+
currentFrameData: a,
|
|
35
|
+
nextFrameData: o,
|
|
36
|
+
progress: l
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
getEffectStateByTime(r, t) {
|
|
41
|
+
const e = this.getKeyframeIndexByTime(r, t);
|
|
42
|
+
return {
|
|
43
|
+
image: t[e].image,
|
|
44
|
+
visible: t[e].visible
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
getItemStateByTime(r, t) {
|
|
48
|
+
const e = this.getKeyframeIndexByTime(r, t);
|
|
49
|
+
return {
|
|
50
|
+
timeStamp: t[e].timeStamp,
|
|
51
|
+
visible: t[e].visible
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
getCameraStateByTime(r, t) {
|
|
55
|
+
const e = this.getKeyframeIndexByTime(r, t);
|
|
56
|
+
return {
|
|
57
|
+
matrix: t[e].matrix,
|
|
58
|
+
fov: t[e].fov,
|
|
59
|
+
transitionType: "linear"
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
getSubtitleStateByTime(r, t) {
|
|
63
|
+
const e = this.getKeyframeIndexByTime(r, t);
|
|
64
|
+
return {
|
|
65
|
+
title: t[e].title,
|
|
66
|
+
content: t[e].content,
|
|
67
|
+
audio: t[e].audio,
|
|
68
|
+
image: t[e].image,
|
|
69
|
+
keyframeIndex: e
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
getModelStateByTime(r, t) {
|
|
73
|
+
var l;
|
|
74
|
+
const e = this.getKeyframeIndexByTime(r, t);
|
|
75
|
+
if (e === t.length - 1)
|
|
76
|
+
return {
|
|
77
|
+
translation: new n.Vector3().fromArray(t[e].position),
|
|
78
|
+
quaternion: new n.Quaternion().fromArray(t[e].quaternion),
|
|
79
|
+
scale: new n.Vector3().fromArray(t[e].scale),
|
|
80
|
+
keyframeIndex: e,
|
|
81
|
+
animation: t[e].animation,
|
|
82
|
+
visible: t[e].visible,
|
|
83
|
+
isFinal: !0
|
|
84
|
+
};
|
|
85
|
+
const a = t[e], o = t[e + 1], i = r - a.timeStamp;
|
|
86
|
+
if (((l = o.interpolationType) != null ? l : "linear") === "parabola") {
|
|
87
|
+
const u = o.timeStamp - a.timeStamp, s = Math.min(i / u, 1), p = S(
|
|
88
|
+
new n.Vector3().fromArray(a.position),
|
|
89
|
+
new n.Vector3().fromArray(o.position)
|
|
90
|
+
)(s), y = s, w = new n.Quaternion().copy(
|
|
91
|
+
new n.Quaternion().fromArray(a.quaternion).slerp(new n.Quaternion().fromArray(o.quaternion), y)
|
|
92
|
+
), x = new n.Vector3().lerpVectors(
|
|
93
|
+
new n.Vector3().fromArray(a.scale),
|
|
94
|
+
new n.Vector3().fromArray(o.scale),
|
|
95
|
+
s
|
|
96
|
+
);
|
|
97
|
+
return {
|
|
98
|
+
translation: p,
|
|
99
|
+
quaternion: w,
|
|
100
|
+
scale: x,
|
|
101
|
+
keyframeIndex: e,
|
|
102
|
+
animation: a.animation,
|
|
103
|
+
visible: a.visible,
|
|
104
|
+
isFinal: !1
|
|
105
|
+
};
|
|
106
|
+
} else {
|
|
107
|
+
const u = o.timeStamp - a.timeStamp, s = Math.min(i / u, 1), d = new n.Vector3().lerpVectors(
|
|
108
|
+
new n.Vector3().fromArray(a.position),
|
|
109
|
+
new n.Vector3().fromArray(o.position),
|
|
110
|
+
s
|
|
111
|
+
), p = s, y = new n.Quaternion().copy(
|
|
112
|
+
new n.Quaternion().fromArray(a.quaternion).slerp(new n.Quaternion().fromArray(o.quaternion), p)
|
|
113
|
+
), w = new n.Vector3().lerpVectors(
|
|
114
|
+
new n.Vector3().fromArray(a.scale),
|
|
115
|
+
new n.Vector3().fromArray(o.scale),
|
|
116
|
+
s
|
|
117
|
+
);
|
|
118
|
+
return {
|
|
119
|
+
translation: d,
|
|
120
|
+
quaternion: y,
|
|
121
|
+
scale: w,
|
|
122
|
+
keyframeIndex: e,
|
|
123
|
+
animation: a.animation,
|
|
124
|
+
visible: a.visible,
|
|
125
|
+
isFinal: !1
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
getKeyframeIndexByTime(r, t) {
|
|
130
|
+
r < 0 && (r = 0);
|
|
131
|
+
let e = 0, a = t.length - 1, o = -1;
|
|
132
|
+
for (; e <= a; ) {
|
|
133
|
+
const i = Math.floor((e + a) / 2);
|
|
134
|
+
if (t[i].timeStamp === r) {
|
|
135
|
+
o = i;
|
|
136
|
+
break;
|
|
137
|
+
} else
|
|
138
|
+
t[i].timeStamp < r ? e = i + 1 : a = i - 1;
|
|
139
|
+
}
|
|
140
|
+
return o !== -1 ? o : a;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
function S(c, r) {
|
|
144
|
+
return (e) => {
|
|
145
|
+
const a = Math.sqrt(Math.pow(r.x - c.x, 2) + Math.pow(r.z - c.z, 2)), o = e * a, i = new n.Vector2(c.x, c.z).add(
|
|
146
|
+
new n.Vector2(r.x, r.z).sub(new n.Vector2(c.x, c.z)).normalize().multiplyScalar(o)
|
|
147
|
+
), m = (r.y - c.y) / (Math.pow(r.x - c.x, 2) + Math.pow(r.z - c.z, 2)) * Math.pow(o, 2) + c.y;
|
|
148
|
+
return new n.Vector3(i.x, m, i.y);
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
export {
|
|
152
|
+
T as DigitalStateMachine
|
|
153
|
+
};
|