@realsee/dnalogel 3.78.0-alpha.1 → 3.78.0-alpha.3
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/dist/PanoTagPlugin/controller/Tag/MaskTag.d.ts +69 -13
- package/dist/PanoTagPlugin/controller/Tag/MaskTag.shaders.d.ts +3 -1
- package/dist/PanoTagPlugin/controller/index.d.ts +19 -1
- package/dist/index.cjs.js +121 -127
- package/dist/index.js +4345 -4093
- package/dist/index.umd.js +115 -121
- package/libs/PanoTagPlugin/controller/Tag/MaskTag.d.ts +69 -13
- package/libs/PanoTagPlugin/controller/Tag/MaskTag.js +452 -244
- package/libs/PanoTagPlugin/controller/Tag/MaskTag.shaders.d.ts +3 -1
- package/libs/PanoTagPlugin/controller/Tag/MaskTag.shaders.js +88 -6
- package/libs/PanoTagPlugin/controller/Tag/MaskTag1.d.ts +202 -0
- package/libs/PanoTagPlugin/controller/Tag/MaskTag1.js +617 -0
- package/libs/PanoTagPlugin/controller/index.d.ts +19 -1
- package/libs/PanoTagPlugin/controller/index.js +183 -133
- package/libs/base/BasePlugin.js +1 -1
- package/libs/shared-utils/logger.js +1 -1
- package/package.json +1 -1
- package/docs/.nojekyll +0 -1
- package/docs/assets/custom.css +0 -0
- package/docs/assets/highlight.css +0 -127
- package/docs/assets/icons.js +0 -18
- package/docs/assets/icons.svg +0 -1
- package/docs/assets/main.js +0 -60
- package/docs/assets/navigation.js +0 -1
- package/docs/assets/search.js +0 -1
- package/docs/assets/style.css +0 -1493
- package/docs/classes/AreaMakerPluginType.AreaMakerController.html +0 -59
- package/docs/classes/AreaMakerPluginType.AreaMakerItem.html +0 -71
- package/docs/classes/CSS3DRender.html +0 -100
- package/docs/classes/GuideLineItem.GuideLineItem.html +0 -21
- package/docs/classes/GuideLineModeItem.GuideLineModeItem.html +0 -70
- package/docs/classes/ModelMakerPluginInstance.html +0 -116
- package/docs/classes/ModelMakerPluginType.ModelMakerBoxItem.html +0 -52
- package/docs/classes/ModelMakerPluginType.ModelMakerPolygonItem.html +0 -52
- package/docs/classes/ModelMakerPluginType.ModelMakerPrismItem.html +0 -53
- package/docs/classes/ModelRoomLabelController.html +0 -19
- package/docs/classes/MoveController.html +0 -45
- package/docs/classes/Object3DHelperController.html +0 -45
- package/docs/classes/PaintBrush.html +0 -15
- package/docs/classes/PanoMeasurePluginLine.html +0 -24
- package/docs/classes/PanoMeasurePluginModel.html +0 -23
- package/docs/classes/PanoMeasurePluginPoint.html +0 -7
- package/docs/classes/PanoMeasurePluginPolyline.html +0 -27
- package/docs/classes/PanoTagPluginController.html +0 -119
- package/docs/classes/Sculpt.html +0 -77
- package/docs/classes/Util.BetterTween.html +0 -6
- package/docs/classes/Util.FiveDomEvents.html +0 -13
- package/docs/classes/Util.FivePuppet.html +0 -20
- package/docs/classes/Util.Interval.html +0 -11
- package/docs/classes/Util.LegacyPointHelper.html +0 -7
- package/docs/classes/Util.LightTag.html +0 -47
- package/docs/classes/Util.LineSegments.html +0 -4
- package/docs/classes/Util.Magnifier.html +0 -26
- package/docs/classes/Util.Object3D.html +0 -8
- package/docs/classes/Util.PointDomHelper.html +0 -8
- package/docs/classes/Util.PointHelper.html +0 -10
- package/docs/classes/Util.PointSelector.html +0 -66
- package/docs/classes/Util.PointSelectorHelper.html +0 -14
- package/docs/classes/Util.Rectangle.html +0 -12
- package/docs/classes/Util.sculpt.BaseEditor.html +0 -17
- package/docs/classes/Util.sculpt.BoxMesh.html +0 -48
- package/docs/classes/Util.sculpt.BoxMeshEditor.html +0 -18
- package/docs/classes/Util.sculpt.CircleMesh.html +0 -26
- package/docs/classes/Util.sculpt.CircleMeshEditor.html +0 -18
- package/docs/classes/Util.sculpt.CircleWithEdgeMesh.html +0 -26
- package/docs/classes/Util.sculpt.CylinderMesh.html +0 -25
- package/docs/classes/Util.sculpt.CylinderMeshEditor.html +0 -18
- package/docs/classes/Util.sculpt.LineMesh.html +0 -34
- package/docs/classes/Util.sculpt.PointMesh.html +0 -24
- package/docs/classes/Util.sculpt.PolygonMesh.html +0 -40
- package/docs/classes/Util.sculpt.PrismMesh.html +0 -48
- package/docs/classes/Util.sculpt.PrismMeshEditor.html +0 -18
- package/docs/classes/Util.sculpt.RectangleMesh.html +0 -41
- package/docs/classes/Util.sculpt.RectangleMeshEditor.html +0 -18
- package/docs/classes/Util.sculpt.RectangleWithEdgeMesh.html +0 -44
- package/docs/classes/WalkController.html +0 -42
- package/docs/enums/CameraMovementEffect.html +0 -4
- package/docs/enums/ContentType.html +0 -34
- package/docs/enums/DIRECTION.html +0 -5
- package/docs/enums/DISPLAY_STRATEGY_TYPE.html +0 -5
- package/docs/enums/DimensionType.html +0 -4
- package/docs/enums/FLOOR_PLAN_ATTACHED_TO.html +0 -4
- package/docs/enums/ITEM_LABEL_PLUGIN_DISPLAY_STRATEGY_TYPE.html +0 -5
- package/docs/enums/PaintBrushTypeEnum.html +0 -4
- package/docs/enums/PointType.html +0 -4
- package/docs/enums/Rotation.html +0 -5
- package/docs/functions/AreaMakerPlugin.html +0 -1
- package/docs/functions/CSS3DRenderPlugin.html +0 -1
- package/docs/functions/CameraMovementPlugin.html +0 -2
- package/docs/functions/CruisePlugin.html +0 -1
- package/docs/functions/CurrentPanoImagePlugin.html +0 -1
- package/docs/functions/FloorplanGuidePlugin.html +0 -1
- package/docs/functions/GuideLinePlugin.html +0 -1
- package/docs/functions/ItemLabelPlugin.html +0 -1
- package/docs/functions/MapviewFloorplanPlugin.html +0 -1
- package/docs/functions/MeasurePlugin.html +0 -1
- package/docs/functions/ModelChassisCompassPlugin.html +0 -2
- package/docs/functions/ModelEntryDoorGuidePlugin.html +0 -2
- package/docs/functions/ModelFloorplanPlugin.html +0 -1
- package/docs/functions/ModelItemLabelPlugin.html +0 -1
- package/docs/functions/ModelMakerPlugin.html +0 -1
- package/docs/functions/ModelRoomLabelPlugin.html +0 -1
- package/docs/functions/ModelTVVideoPlugin.html +0 -1
- package/docs/functions/ModelViewPlugin.html +0 -2
- package/docs/functions/MovePlugin.html +0 -1
- package/docs/functions/Object3DHelperPlugin.html +0 -1
- package/docs/functions/PanoCompassPlugin.html +0 -1
- package/docs/functions/PanoCursorRaycasterPlugin.html +0 -2
- package/docs/functions/PanoDoorLabelPlugin.html +0 -1
- package/docs/functions/PanoFloorplanRadarPlugin.html +0 -1
- package/docs/functions/PanoMeasurePlugin.html +0 -1
- package/docs/functions/PanoRulerPlugin.html +0 -2
- package/docs/functions/PanoRulerProPlugin.html +0 -2
- package/docs/functions/PanoSpatialTagPlugin.html +0 -2
- package/docs/functions/PanoTagPlugin.html +0 -1
- package/docs/functions/PanoVideoPlugin.html +0 -10
- package/docs/functions/PipelinePlugin.html +0 -1
- package/docs/functions/SculptPlugin.html +0 -2
- package/docs/functions/SculptPluginForFive.html +0 -2
- package/docs/functions/TopviewFloorplanPlugin.html +0 -1
- package/docs/functions/Util.awaitNextFrame.html +0 -1
- package/docs/functions/Util.blink.html +0 -13
- package/docs/functions/Util.blinkWithPreset.html +0 -6
- package/docs/functions/Util.bounding.html +0 -1
- package/docs/functions/Util.boundingBox.html +0 -1
- package/docs/functions/Util.boundingSphere.html +0 -1
- package/docs/functions/Util.boxVertex.html +0 -7
- package/docs/functions/Util.boxVertexes.html +0 -1
- package/docs/functions/Util.checkFiveModelLoaded.html +0 -2
- package/docs/functions/Util.cleanup.html +0 -3
- package/docs/functions/Util.convexHull.html +0 -2
- package/docs/functions/Util.equal.html +0 -5
- package/docs/functions/Util.fiveModelIsLoaded.html +0 -2
- package/docs/functions/Util.generatePolygonGeometry.html +0 -2
- package/docs/functions/Util.getCoordsFromClient.html +0 -1
- package/docs/functions/Util.getCoordsFromElement.html +0 -1
- package/docs/functions/Util.getFrameTime.html +0 -3
- package/docs/functions/Util.getGeometryArea.html +0 -1
- package/docs/functions/Util.getGeometryInfo.html +0 -1
- package/docs/functions/Util.getIntersectFromRelativePosition.html +0 -1
- package/docs/functions/Util.getRaycasterFromFivePointer.html +0 -1
- package/docs/functions/Util.initialCSS3DRender.html +0 -1
- package/docs/functions/Util.inside.html +0 -1
- package/docs/functions/Util.isModelLike.html +0 -1
- package/docs/functions/Util.isNil.html +0 -2
- package/docs/functions/Util.isPanoramaLike.html +0 -1
- package/docs/functions/Util.lookObject.html +0 -7
- package/docs/functions/Util.lookPoint.html +0 -5
- package/docs/functions/Util.nextFrame.html +0 -1
- package/docs/functions/Util.notNil.html +0 -2
- package/docs/functions/Util.reblink.html +0 -13
- package/docs/functions/Util.replaceStaticPrefix.html +0 -8
- package/docs/functions/Util.requestAnimationFrameInterval.html +0 -5
- package/docs/functions/Util.sculpt.createBox.html +0 -1
- package/docs/functions/Util.sculpt.createCircle.html +0 -1
- package/docs/functions/Util.sculpt.createCylinder.html +0 -1
- package/docs/functions/Util.sculpt.createLine.html +0 -2
- package/docs/functions/Util.sculpt.createPoint.html +0 -1
- package/docs/functions/Util.sculpt.createPolygon.html +0 -1
- package/docs/functions/Util.sculpt.createPrism.html +0 -1
- package/docs/functions/Util.sculpt.createRectangle.html +0 -2
- package/docs/functions/Util.sculpt.transformUnit.html +0 -1
- package/docs/functions/Util.sculpt.transformUnitSquare.html +0 -1
- package/docs/functions/Util.tag.html +0 -1
- package/docs/functions/Util.triangleArea.html +0 -2
- package/docs/functions/Util.triangleCenter.html +0 -2
- package/docs/functions/Util.tweenProgress.html +0 -1
- package/docs/functions/Util.uuid.html +0 -2
- package/docs/functions/Util.waitFiveModelLoaded.html +0 -2
- package/docs/functions/Util.worldBounding.html +0 -1
- package/docs/functions/Util.worldBoundingBox.html +0 -1
- package/docs/functions/Util.worldBoundingSphere.html +0 -1
- package/docs/functions/createPolyline.html +0 -2
- package/docs/functions/pluginFlag.html +0 -1
- package/docs/functions/validatePolygon.html +0 -1
- package/docs/hierarchy.html +0 -1
- package/docs/index.html +0 -70
- package/docs/interfaces/AreaMakerPluginType.AnimeOptions.html +0 -4
- package/docs/interfaces/AreaMakerPluginType.Config.html +0 -8
- package/docs/interfaces/AreaMakerPluginType.EventMap.html +0 -25
- package/docs/interfaces/AreaMakerPluginType.Params.html +0 -4
- package/docs/interfaces/AreaMakerPluginType.ServerAreaMakerItem.html +0 -20
- package/docs/interfaces/AreaMakerPluginType.ServerAreaMakerItemV1.html +0 -13
- package/docs/interfaces/AreaMakerPluginType.ServerDataV1.html +0 -9
- package/docs/interfaces/AreaMakerPluginType.ServerDataV2.html +0 -3
- package/docs/interfaces/AreaMakerPluginType.ShowHideOptions.html +0 -3
- package/docs/interfaces/AreaMakerPluginType.State.html +0 -8
- package/docs/interfaces/BoxAnimationConfig.html +0 -6
- package/docs/interfaces/BoxPosition.html +0 -8
- package/docs/interfaces/CSS3DRenderPluginEventMap.html +0 -9
- package/docs/interfaces/CSS3DRenderPluginState.html +0 -7
- package/docs/interfaces/CameraMovementPluginExportType.html +0 -11
- package/docs/interfaces/ContentTypeMapInterface.html +0 -73
- package/docs/interfaces/CruisePluginTypes.Config.html +0 -7
- package/docs/interfaces/CruisePluginTypes.CruiseKeyframe.html +0 -8
- package/docs/interfaces/CruisePluginTypes.EventMap.html +0 -33
- package/docs/interfaces/CruisePluginTypes.GuildLineConfig.html +0 -6
- package/docs/interfaces/CruisePluginTypes.MoveAction.html +0 -16
- package/docs/interfaces/CruisePluginTypes.MoveWithKeyframesAction.html +0 -19
- package/docs/interfaces/CruisePluginTypes.MoveWithPanoIndexAction.html +0 -20
- package/docs/interfaces/CruisePluginTypes.PluginData.html +0 -8
- package/docs/interfaces/CruisePluginTypes.PluginServerData.html +0 -2
- package/docs/interfaces/CruisePluginTypes.PluginState.html +0 -15
- package/docs/interfaces/CurrentPanoImagePluginType.Config.html +0 -13
- package/docs/interfaces/CurrentPanoImagePluginType.EventMap.html +0 -15
- package/docs/interfaces/CurrentPanoImagePluginType.Params.html +0 -4
- package/docs/interfaces/CurrentPanoImagePluginType.ShowHideOptions.html +0 -3
- package/docs/interfaces/CurrentPanoImagePluginType.State.html +0 -7
- package/docs/interfaces/FloorplanBounding.html +0 -9
- package/docs/interfaces/FloorplanData.html +0 -7
- package/docs/interfaces/FloorplanEntrance.html +0 -14
- package/docs/interfaces/FloorplanExtraObject.html +0 -9
- package/docs/interfaces/FloorplanExtraObject3D.html +0 -5
- package/docs/interfaces/FloorplanFloorData.html +0 -9
- package/docs/interfaces/FloorplanImagePosition.html +0 -4
- package/docs/interfaces/FloorplanObserver.html +0 -8
- package/docs/interfaces/FloorplanOutlineItem.html +0 -6
- package/docs/interfaces/FloorplanPosition.html +0 -4
- package/docs/interfaces/FloorplanRoomItem.html +0 -24
- package/docs/interfaces/FloorplanRoomLabelItem.html +0 -6
- package/docs/interfaces/FloorplanServerBounding.html +0 -9
- package/docs/interfaces/FloorplanServerComputedData.html +0 -6
- package/docs/interfaces/FloorplanServerData.html +0 -4
- package/docs/interfaces/FloorplanServerDoorItem.html +0 -6
- package/docs/interfaces/FloorplanServerDoorPosition.html +0 -4
- package/docs/interfaces/FloorplanServerEntrance.html +0 -14
- package/docs/interfaces/FloorplanServerFloorData.html +0 -8
- package/docs/interfaces/FloorplanServerImagePosition.html +0 -4
- package/docs/interfaces/FloorplanServerObserver.html +0 -8
- package/docs/interfaces/FloorplanServerOutlineItem.html +0 -6
- package/docs/interfaces/FloorplanServerPosition.html +0 -4
- package/docs/interfaces/FloorplanServerRoomItem.html +0 -27
- package/docs/interfaces/FloorplanServerRoomLabelItem.html +0 -6
- package/docs/interfaces/GuideLineModeItem.GuideLineTagContainer.html +0 -4
- package/docs/interfaces/GuideLinePluginType.CatmullRomCurve3.html +0 -7
- package/docs/interfaces/GuideLinePluginType.EventMap.html +0 -13
- package/docs/interfaces/GuideLinePluginType.ExtraRouteData.html +0 -5
- package/docs/interfaces/GuideLinePluginType.GuideLineGeometryStyle.html +0 -8
- package/docs/interfaces/GuideLinePluginType.GuideLineItemContainer.html +0 -2
- package/docs/interfaces/GuideLinePluginType.GuideLineMaterialStyle.html +0 -32
- package/docs/interfaces/GuideLinePluginType.GuideLineMeshStyle.html +0 -4
- package/docs/interfaces/GuideLinePluginType.LineGeometriesConfig.html +0 -5
- package/docs/interfaces/GuideLinePluginType.ModelGuideLineStyle.html +0 -42
- package/docs/interfaces/GuideLinePluginType.ModelGuideLineTagData.html +0 -3
- package/docs/interfaces/GuideLinePluginType.PanoramaGuideLineStyle.html +0 -57
- package/docs/interfaces/GuideLinePluginType.PluginDataV2.html +0 -1
- package/docs/interfaces/GuideLinePluginType.PluginServerData.html +0 -2
- package/docs/interfaces/GuideLinePluginType.PluginState.html +0 -7
- package/docs/interfaces/GuideLinePluginType.Route.html +0 -13
- package/docs/interfaces/HelperOffset.html +0 -4
- package/docs/interfaces/ImagePlaneGroup.html +0 -3
- package/docs/interfaces/ItemLabelPluginData.html +0 -2
- package/docs/interfaces/ItemLabelPluginExportReturnsType.html +0 -7
- package/docs/interfaces/ItemLabelPluginParametersType.html +0 -5
- package/docs/interfaces/MinMax.html +0 -3
- package/docs/interfaces/ModelChassisCompassPluginData.html +0 -3
- package/docs/interfaces/ModelChassisCompassPluginExportType.html +0 -4
- package/docs/interfaces/ModelChassisCompassPluginParameterType.html +0 -3
- package/docs/interfaces/ModelEntryDoorGuidePluginData.html +0 -4
- package/docs/interfaces/ModelEntryDoorGuidePluginExportType.html +0 -4
- package/docs/interfaces/ModelItemLabelPluginData.html +0 -2
- package/docs/interfaces/ModelItemLabelPluginExportReturnsType.html +0 -7
- package/docs/interfaces/ModelItemLabelPluginParametersType.html +0 -3
- package/docs/interfaces/ModelMakerPluginType.BoxItemObjectData.html +0 -17
- package/docs/interfaces/ModelMakerPluginType.EventMap.html +0 -18
- package/docs/interfaces/ModelMakerPluginType.PrismItemObjectData.html +0 -23
- package/docs/interfaces/ModelMakerPluginType.ServerBaseItem.html +0 -11
- package/docs/interfaces/ModelMakerPluginType.ServerBoxItem.html +0 -10
- package/docs/interfaces/ModelMakerPluginType.ServerData.html +0 -3
- package/docs/interfaces/ModelMakerPluginType.ServerPrismItem.html +0 -10
- package/docs/interfaces/ModelMakerPluginType.ServerTrianglesItem.html +0 -10
- package/docs/interfaces/ModelMakerPluginType.State.html +0 -8
- package/docs/interfaces/ModelMakerPluginType.TrianglesItemObjectData.html +0 -11
- package/docs/interfaces/ModelRoomLabelPluginData.html +0 -2
- package/docs/interfaces/ModelTVVideoPluginData.html +0 -5
- package/docs/interfaces/ModelTVVideoPluginExportType.html +0 -4
- package/docs/interfaces/ModelTVVideoPluginParameterType.html +0 -2
- package/docs/interfaces/ModelViewPluginExportType.html +0 -8
- package/docs/interfaces/Object3DHelperState.html +0 -4
- package/docs/interfaces/ObjectHelperControllers.html +0 -5
- package/docs/interfaces/PaintBrushAction.html +0 -14
- package/docs/interfaces/PaintBrushConfigs.html +0 -8
- package/docs/interfaces/PaintBrushState.html +0 -6
- package/docs/interfaces/PanoCursorRaycasterPluginExportType.html +0 -16
- package/docs/interfaces/PanoCursorRaycasterPluginParameterType.html +0 -1
- package/docs/interfaces/PanoMeasureParameterType.html +0 -20
- package/docs/interfaces/PanoMeasurePluginLineJson.html +0 -4
- package/docs/interfaces/PanoMeasurePluginOpenParameter.html +0 -4
- package/docs/interfaces/PanoMeasurePluginPointJson.html +0 -3
- package/docs/interfaces/PanoMeasurePluginPolylineJson.html +0 -7
- package/docs/interfaces/PanoRulerPluginExportType.html +0 -6
- package/docs/interfaces/PanoRulerPluginOptions.html +0 -3
- package/docs/interfaces/PanoRulerPluginParameterType.html +0 -4
- package/docs/interfaces/PanoRulerProPluginExportType.html +0 -5
- package/docs/interfaces/PanoRulerProPluginOptions.html +0 -3
- package/docs/interfaces/PanoRulerProPluginParameterType.html +0 -3
- package/docs/interfaces/PanoRulerProPluginState.html +0 -4
- package/docs/interfaces/PanoSpatialTagPluginContentEvent.html +0 -1
- package/docs/interfaces/PanoSpatialTagPluginContentReplacement.html +0 -1
- package/docs/interfaces/PanoSpatialTagPluginData.html +0 -7
- package/docs/interfaces/PanoSpatialTagPluginDataElement.html +0 -6
- package/docs/interfaces/PanoSpatialTagPluginExportType.html +0 -9
- package/docs/interfaces/PanoSpatialTagPluginOriginElement.html +0 -6
- package/docs/interfaces/PanoSpatialTagPluginParameterType.html +0 -9
- package/docs/interfaces/PanoSpatialTagPluginPointElement.html +0 -7
- package/docs/interfaces/PanoSpatialTagPluginTagElement.html +0 -6
- package/docs/interfaces/PanoVideoPluginType.LoadParams.html +0 -3
- package/docs/interfaces/PanoVideoPluginType.PanoVideoItem.html +0 -8
- package/docs/interfaces/PanoVideoPluginType.PluginData.html +0 -2
- package/docs/interfaces/PanoVideoPluginType.PluginEventMap.html +0 -15
- package/docs/interfaces/PanoVideoPluginType.PluginState.html +0 -2
- package/docs/interfaces/PanoVideoPluginType.VideoItem.html +0 -14
- package/docs/interfaces/PanoVideoPluginType.VideoMeshParams.html +0 -13
- package/docs/interfaces/PluginEventMap.html +0 -16
- package/docs/interfaces/Point.html +0 -4
- package/docs/interfaces/Room.html +0 -5
- package/docs/interfaces/RoomInfo.html +0 -3
- package/docs/interfaces/RoomLabel.html +0 -16
- package/docs/interfaces/RoomRules.html +0 -1
- package/docs/interfaces/Rooms.html +0 -1
- package/docs/interfaces/Scissor.html +0 -13
- package/docs/interfaces/SculptConfig.html +0 -19
- package/docs/interfaces/State.html +0 -7
- package/docs/interfaces/TagCacheInterface.html +0 -9
- package/docs/interfaces/TagConfig.html +0 -174
- package/docs/interfaces/TagGLTFObjectGroup.html +0 -3
- package/docs/interfaces/TagIconAnimationConfig.html +0 -7
- package/docs/interfaces/TagIconUrl.html +0 -22
- package/docs/interfaces/TagObjectGroup.html +0 -3
- package/docs/interfaces/TagState.html +0 -3
- package/docs/interfaces/TagStyle.html +0 -17
- package/docs/interfaces/Tags.html +0 -8
- package/docs/interfaces/TemporaryState.html +0 -2
- package/docs/interfaces/Util.AnimeInstance.html +0 -14
- package/docs/interfaces/Util.BlinkAnimeOptions.html +0 -21
- package/docs/interfaces/Util.EventHandlerConfig.html +0 -21
- package/docs/interfaces/Util.FiveDomEvent.html +0 -7
- package/docs/interfaces/Util.FiveDomEventMap.html +0 -20
- package/docs/interfaces/Util.LegacyMouseGroupParameter.html +0 -4
- package/docs/interfaces/Util.MagnifierParameter.html +0 -13
- package/docs/interfaces/Util.MouseGroupParameter.html +0 -4
- package/docs/interfaces/Util.ObjectInitialState.html +0 -9
- package/docs/interfaces/Util.PointIntersection.html +0 -21
- package/docs/interfaces/Util.PointSelectorHelperConfig.html +0 -6
- package/docs/interfaces/Util.ReBlinkAnimeOptions.html +0 -27
- package/docs/modules/AreaMakerPluginType.html +0 -17
- package/docs/modules/CruisePluginTypes.html +0 -14
- package/docs/modules/CurrentPanoImagePluginType.html +0 -6
- package/docs/modules/GuideLineItem.html +0 -2
- package/docs/modules/GuideLineModeItem.html +0 -3
- package/docs/modules/GuideLinePluginType.html +0 -25
- package/docs/modules/ModelMakerPluginType.html +0 -19
- package/docs/modules/PanoVideoPluginType.html +0 -8
- package/docs/modules/SculptData.html +0 -9
- package/docs/modules/SculptType.html +0 -2
- package/docs/modules/Util.html +0 -91
- package/docs/modules/Util.sculpt.html +0 -27
- package/docs/modules.html +0 -287
- package/docs/types/AddObject3DHelperConfig.html +0 -19
- package/docs/types/AreaMakerPluginType.AreaMakerItemEventMap.html +0 -7
- package/docs/types/AreaMakerPluginType.ItemRenderer.html +0 -1
- package/docs/types/AreaMakerPluginType.PluginData.html +0 -2
- package/docs/types/AreaMakerPluginType.ServerData.html +0 -2
- package/docs/types/ArrayPosition.html +0 -1
- package/docs/types/AudioAppearance.html +0 -1
- package/docs/types/BoxTag.html +0 -2
- package/docs/types/CSS3DRenderExportType.html +0 -1
- package/docs/types/CSS3DRenderPluginExportType.html +0 -1
- package/docs/types/CSS3DRenderPluginParameterType.html +0 -1
- package/docs/types/ClassFunctionParameters.html +0 -1
- package/docs/types/Color.html +0 -1
- package/docs/types/ContentTypeConfigKey.html +0 -1
- package/docs/types/ContentTypeConfigKeySplit.html +0 -1
- package/docs/types/ContentTypeMap.html +0 -1
- package/docs/types/Create3DDomContainerReturnType.html +0 -1
- package/docs/types/Create3DElementReturnType.html +0 -1
- package/docs/types/CruisePluginExportType.html +0 -1
- package/docs/types/CruisePluginTypes.CruiseData.html +0 -6
- package/docs/types/CruisePluginTypes.MoveEffect.html +0 -1
- package/docs/types/CurrentPanoImagePluginExportType.html +0 -1
- package/docs/types/DeprecatedMediaPlaneProperty.html +0 -3
- package/docs/types/DeprecatedTagProperty.html +0 -3
- package/docs/types/Direction-1.html +0 -1
- package/docs/types/Direction4.html +0 -1
- package/docs/types/ElementRenderer.html +0 -2
- package/docs/types/FloorplanGuidePluginParameterType.html +0 -1
- package/docs/types/FloorplanGuidePluginReturnType.html +0 -1
- package/docs/types/FloorplanRuleLabels.html +0 -2
- package/docs/types/FloorplanServerRuleLabels.html +0 -1
- package/docs/types/GuideLinePluginExportType.html +0 -1
- package/docs/types/GuideLinePluginType.GuideLineItem.html +0 -2
- package/docs/types/GuideLinePluginType.GuideLineItemEventMap.html +0 -1
- package/docs/types/GuideLinePluginType.GuideLineModeItemMode.html +0 -1
- package/docs/types/GuideLinePluginType.GuideLineStyle.html +0 -2
- package/docs/types/GuideLinePluginType.ModelGuideLineTag.html +0 -2
- package/docs/types/GuideLinePluginType.PathItem.html +0 -2
- package/docs/types/GuideLinePluginType.PluginData.html +0 -2
- package/docs/types/GuideLinePluginType.RouteConfig.html +0 -4
- package/docs/types/HelperEventMap.html +0 -1
- package/docs/types/InternalHelperEventMap.html +0 -1
- package/docs/types/MapviewFloorplanPluginParameterType.html +0 -1
- package/docs/types/MapviewFloorplanPluginReturnType.html +0 -1
- package/docs/types/MaskPosition.html +0 -3
- package/docs/types/MaskTag.html +0 -2
- package/docs/types/MeasureEndReason.html +0 -1
- package/docs/types/MeasurePluginConfig.html +0 -5
- package/docs/types/MeasurePluginEventMap.html +0 -1
- package/docs/types/MediaData.html +0 -2
- package/docs/types/MediaStore.html +0 -1
- package/docs/types/ModelEntryDoorGuidePluginParameterType.html +0 -1
- package/docs/types/ModelFloorplanPluginParameterType.html +0 -1
- package/docs/types/ModelFloorplanPluginReturnType.html +0 -1
- package/docs/types/ModelId.html +0 -1
- package/docs/types/ModelMakerPluginType.ElementRenderer.html +0 -1
- package/docs/types/ModelMakerPluginType.ItemType.html +0 -2
- package/docs/types/ModelMakerPluginType.MarkerItem.html +0 -1
- package/docs/types/ModelMakerPluginType.ServerItem.html +0 -2
- package/docs/types/ModelRoomLabelPluginParameters.html +0 -1
- package/docs/types/ModelRoomLabelPluginReturnType.html +0 -1
- package/docs/types/MoveArgs.html +0 -2
- package/docs/types/MoveOpts.html +0 -2
- package/docs/types/Object3DHelperEventMap.html +0 -1
- package/docs/types/ObjectFit.html +0 -1
- package/docs/types/PaintBrushEventMap.html +0 -1
- package/docs/types/PanoCompassPluginData.html +0 -1
- package/docs/types/PanoCompassPluginExportType.html +0 -1
- package/docs/types/PanoCompassPluginParameterType.html +0 -1
- package/docs/types/PanoFloorplanRadarPluginParameterType.html +0 -1
- package/docs/types/PanoFloorplanRadarPluginReturnType.html +0 -1
- package/docs/types/PanoIndex.html +0 -1
- package/docs/types/PanoMeasurePluginEvent.html +0 -1
- package/docs/types/PanoMeasureReturnType.html +0 -1
- package/docs/types/PanoSpatialTagPluginId.html +0 -1
- package/docs/types/PanoTagPluginExportInterface.html +0 -1
- package/docs/types/PanoTagPluginParamsInterface.html +0 -1
- package/docs/types/PanoVideoPluginParameterType.html +0 -1
- package/docs/types/PanoVideoPluginReturnType.html +0 -1
- package/docs/types/PickTagContentTypeInContentTypeConfigKey.html +0 -2
- package/docs/types/PipelinePluginParameterType.html +0 -1
- package/docs/types/PipelinePluginReturnType.html +0 -1
- package/docs/types/PlaneTag.html +0 -2
- package/docs/types/Point2DTag.html +0 -2
- package/docs/types/Point3DTag.html +0 -2
- package/docs/types/PointTagInstance.html +0 -1
- package/docs/types/PolygonPosition.html +0 -3
- package/docs/types/PolygonTag.html +0 -2
- package/docs/types/Position.html +0 -1
- package/docs/types/PositionFrom.html +0 -1
- package/docs/types/RotateArgs.html +0 -2
- package/docs/types/RotateOpts.html +0 -2
- package/docs/types/RuleLabelsKey.html +0 -1
- package/docs/types/RuleLabelsValue.html +0 -1
- package/docs/types/ScaleCallback.html +0 -1
- package/docs/types/ScalePosition.html +0 -3
- package/docs/types/SculptData.BoxData.html +0 -1
- package/docs/types/SculptData.CircleData.html +0 -1
- package/docs/types/SculptData.CylinderData.html +0 -1
- package/docs/types/SculptData.PointData.html +0 -1
- package/docs/types/SculptData.PolygonData.html +0 -1
- package/docs/types/SculptData.PolylineData.html +0 -1
- package/docs/types/SculptData.PrismData.html +0 -1
- package/docs/types/SculptData.RectangleData.html +0 -1
- package/docs/types/SculptType.Theme.html +0 -10
- package/docs/types/StickType.html +0 -1
- package/docs/types/Tag.html +0 -17
- package/docs/types/Tag2D.html +0 -2
- package/docs/types/Tag3D.html +0 -2
- package/docs/types/TagClickParams.html +0 -1
- package/docs/types/TagConfigByKey.html +0 -1
- package/docs/types/TagContentType.html +0 -1
- package/docs/types/TagContentTypeMapping.html +0 -1
- package/docs/types/TagDimensionType.html +0 -1
- package/docs/types/TagElement.html +0 -2
- package/docs/types/TagEvents.html +0 -1
- package/docs/types/TagGLTFObject.html +0 -1
- package/docs/types/TagHooks.html +0 -1
- package/docs/types/TagId.html +0 -1
- package/docs/types/TagInstance.html +0 -1
- package/docs/types/TagPlacement.html +0 -5
- package/docs/types/TagPointType.html +0 -2
- package/docs/types/TagRendererMap.html +0 -1
- package/docs/types/TopviewFloorplanPluginParameterType.html +0 -1
- package/docs/types/TopviewFloorplanPluginReturnType.html +0 -1
- package/docs/types/Util.ActionIfNoIntersection.html +0 -1
- package/docs/types/Util.AdherePoint.html +0 -2
- package/docs/types/Util.PointSelectorConfig.html +0 -1
- package/docs/types/Util.SupportedTarget.html +0 -2
- package/docs/types/Util.Target.html +0 -2
- package/docs/types/Util.ThreeObject.html +0 -2
- package/docs/types/WorkCode.html +0 -1
- package/docs/variables/FLOOR_TYPE_MAP.html +0 -2
- package/docs/variables/PLUGIN.html +0 -1
- package/docs/variables/ROOM_FETILE_TYPE_MAP.html +0 -2
- package/docs/variables/ROOM_TYPE_MAP.html +0 -2
- package/docs/variables/Util.ANIME_PRESETS.html +0 -2
- package/docs/variables/Util.CURRENT_PANO_IMAGE_DEFAULT_IMAGE.html +0 -2
- package/docs/variables/Util.DEFAULT_ANIME_CONFIG.html +0 -2
- package/docs/variables/Util.DEFAULT_STATIC_PREFIX.html +0 -2
- package/docs/variables/Util.DNALOGEL_DEFAULT_ASSETS.html +0 -2
- package/docs/variables/Util.ENTRY_DOOR_DEFAULT_IMAGE.html +0 -2
- package/docs/variables/Util.FLOORPLAN_DEFAULT_IMAGE.html +0 -2
- package/docs/variables/Util.GUIDELINE_DEFAULT_ARROW_TEXTURE.html +0 -2
- package/docs/variables/Util.GUIDELINE_WHITE_ARROW_TEXTURE.html +0 -2
- package/docs/variables/Util.MODEL_CHASSIS_COMPASS_DEFAULT_MODEL.html +0 -2
- package/docs/variables/Util.MODEL_ENTRY_DOOR_GUIDE_PLUGIN_DEFAULT_MODEL.html +0 -2
- package/docs/variables/Util.PANO_COMPASS_DEFAULT_IMAGE.html +0 -2
- package/docs/variables/Util.PANO_SPATIAL_TAG_BLUR_IMAGE.html +0 -2
- package/docs/variables/Util.PANO_TAG_DEFAULT_LINK_ICON.html +0 -2
- package/docs/variables/defaultGlobalConfig.html +0 -1
- package/docs/variables/itemLabelPluginServerParams.html +0 -1
- package/docs/variables/modelItemLabelPluginServerParams.html +0 -1
- package/docs/variables/modelRoomLabelPluginServerParams.html +0 -1
|
@@ -1,34 +1,36 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
var
|
|
5
|
-
for (var e in
|
|
6
|
-
|
|
7
|
-
if (
|
|
8
|
-
for (var e of
|
|
9
|
-
|
|
10
|
-
return
|
|
1
|
+
var F = Object.defineProperty;
|
|
2
|
+
var R = Object.getOwnPropertySymbols;
|
|
3
|
+
var B = Object.prototype.hasOwnProperty, A = Object.prototype.propertyIsEnumerable;
|
|
4
|
+
var E = (m, c, e) => c in m ? F(m, c, { enumerable: !0, configurable: !0, writable: !0, value: e }) : m[c] = e, v = (m, c) => {
|
|
5
|
+
for (var e in c || (c = {}))
|
|
6
|
+
B.call(c, e) && E(m, e, c[e]);
|
|
7
|
+
if (R)
|
|
8
|
+
for (var e of R(c))
|
|
9
|
+
A.call(c, e) && E(m, e, c[e]);
|
|
10
|
+
return m;
|
|
11
11
|
};
|
|
12
|
-
var
|
|
13
|
-
var
|
|
14
|
-
var
|
|
12
|
+
var x = (m, c, e) => (E(m, typeof c != "symbol" ? c + "" : c, e), e);
|
|
13
|
+
var S = (m, c, e) => new Promise((s, t) => {
|
|
14
|
+
var o = (l) => {
|
|
15
15
|
try {
|
|
16
|
-
|
|
17
|
-
} catch (
|
|
18
|
-
|
|
16
|
+
r(e.next(l));
|
|
17
|
+
} catch (n) {
|
|
18
|
+
t(n);
|
|
19
19
|
}
|
|
20
|
-
},
|
|
20
|
+
}, i = (l) => {
|
|
21
21
|
try {
|
|
22
|
-
|
|
23
|
-
} catch (
|
|
24
|
-
|
|
22
|
+
r(e.throw(l));
|
|
23
|
+
} catch (n) {
|
|
24
|
+
t(n);
|
|
25
25
|
}
|
|
26
|
-
},
|
|
27
|
-
|
|
26
|
+
}, r = (l) => l.done ? s(l.value) : Promise.resolve(l.value).then(o, i);
|
|
27
|
+
r((e = e.apply(m, c)).next());
|
|
28
28
|
});
|
|
29
|
-
import { BaseTag as
|
|
30
|
-
import * as
|
|
31
|
-
import {
|
|
29
|
+
import { BaseTag as D } from "./BaseTag.js";
|
|
30
|
+
import * as g from "three";
|
|
31
|
+
import { anime as $ } from "../../../vendor/animejs/lib/anime.es.js";
|
|
32
|
+
import { maskVertexShader as z, maskFragmentShaderMulti as G } from "./MaskTag.shaders.js";
|
|
33
|
+
import { transformPosition as L } from "../../../shared-utils/five/transformPosition.js";
|
|
32
34
|
import "../../../shared-utils/Subscribe.js";
|
|
33
35
|
import "../../utils/tag/calculateTagConfig.js";
|
|
34
36
|
import "../../../vendor/object-assign-deep/objectAssignDeep.js";
|
|
@@ -43,7 +45,6 @@ import "../../../shared-utils/five/getFiveModel.js";
|
|
|
43
45
|
import "../../../shared-utils/Utils/FiveUtil.js";
|
|
44
46
|
import "../../../shared-utils/Utils/BaseUtil.js";
|
|
45
47
|
import "../../../shared-utils/Utils/WorkUtil.js";
|
|
46
|
-
import "../../../shared-utils/five/transformPosition.js";
|
|
47
48
|
import "../../../shared-utils/three/temp.js";
|
|
48
49
|
import "../../../shared-utils/three/core/Raycaster.js";
|
|
49
50
|
import "../../../shared-utils/dom/resizeObserver.js";
|
|
@@ -67,7 +68,6 @@ import "../../../shared-utils/isNil.js";
|
|
|
67
68
|
import "../../../shared-utils/three/core/Five_LineMaterial2.js";
|
|
68
69
|
import "../../../shared-utils/three/core/Sphere.js";
|
|
69
70
|
import "../../../shared-utils/three/blink.js";
|
|
70
|
-
import "../../../vendor/animejs/lib/anime.es.js";
|
|
71
71
|
import "../../../shared-utils/util.js";
|
|
72
72
|
import "../../../vendor/@tweenjs/tween/dist/tween.esm.js.js";
|
|
73
73
|
import "../../../CSS3DRenderPlugin/utils/three/CSS3DRender.js";
|
|
@@ -114,94 +114,263 @@ import "../../../shared-utils/five/getFloorIndex.js";
|
|
|
114
114
|
import "../../../shared-utils/safeObj.js";
|
|
115
115
|
import "../../utils/Cache.js";
|
|
116
116
|
import "../../../shared-utils/promise/withResolvers.js";
|
|
117
|
-
function
|
|
118
|
-
if (Array.isArray(
|
|
119
|
-
return
|
|
120
|
-
if (typeof
|
|
121
|
-
return [
|
|
122
|
-
if (typeof
|
|
123
|
-
let
|
|
124
|
-
if (
|
|
125
|
-
const e = parseInt(
|
|
126
|
-
if (!isNaN(e) && !isNaN(
|
|
127
|
-
return [e,
|
|
117
|
+
function w(m) {
|
|
118
|
+
if (Array.isArray(m))
|
|
119
|
+
return m;
|
|
120
|
+
if (typeof m == "number")
|
|
121
|
+
return [m >> 16 & 255, m >> 8 & 255, m & 255];
|
|
122
|
+
if (typeof m == "string") {
|
|
123
|
+
let c = m.trim().replace(/^#/, "");
|
|
124
|
+
if (c.length === 3 && (c = c[0] + c[0] + c[1] + c[1] + c[2] + c[2]), c.length === 6) {
|
|
125
|
+
const e = parseInt(c.substring(0, 2), 16), s = parseInt(c.substring(2, 4), 16), t = parseInt(c.substring(4, 6), 16);
|
|
126
|
+
if (!isNaN(e) && !isNaN(s) && !isNaN(t))
|
|
127
|
+
return [e, s, t];
|
|
128
128
|
}
|
|
129
|
-
console.warn("[MaskTag] Invalid hex color string:",
|
|
129
|
+
console.warn("[MaskTag] Invalid hex color string:", m);
|
|
130
130
|
}
|
|
131
131
|
return [0, 0, 0];
|
|
132
132
|
}
|
|
133
|
-
const h = class extends
|
|
134
|
-
constructor(e,
|
|
135
|
-
|
|
133
|
+
const h = class extends D {
|
|
134
|
+
constructor(e, s) {
|
|
135
|
+
var i;
|
|
136
|
+
super(e, s);
|
|
136
137
|
/**
|
|
137
138
|
* mask 图片 URL 或 Canvas 元素(2:1 全景图格式)
|
|
138
139
|
*/
|
|
139
|
-
|
|
140
|
+
x(this, "maskUrl");
|
|
140
141
|
/**
|
|
141
142
|
* 目标颜色(RGB 格式)
|
|
142
143
|
*/
|
|
143
|
-
|
|
144
|
+
x(this, "targetColor");
|
|
144
145
|
/**
|
|
145
146
|
* mask 渲染的 mesh 对象(使用 Sphere)
|
|
146
147
|
*/
|
|
147
|
-
|
|
148
|
+
x(this, "maskMesh");
|
|
148
149
|
/**
|
|
149
150
|
* mask 纹理对象
|
|
150
151
|
*/
|
|
151
|
-
|
|
152
|
+
x(this, "maskTexture");
|
|
152
153
|
/**
|
|
153
154
|
* 是否正在加载 mask
|
|
154
155
|
*/
|
|
155
|
-
|
|
156
|
+
x(this, "loadingMask", !1);
|
|
156
157
|
/**
|
|
157
158
|
* 资源是否已释放
|
|
158
159
|
*/
|
|
159
|
-
|
|
160
|
+
x(this, "_disposed", !1);
|
|
160
161
|
/**
|
|
161
162
|
* 标签样式配置
|
|
162
163
|
*/
|
|
163
|
-
|
|
164
|
+
x(this, "tagStyle");
|
|
164
165
|
/**
|
|
165
166
|
* 点击事件清理函数
|
|
166
167
|
*/
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
168
|
+
x(this, "clickEventDispose");
|
|
169
|
+
/** 当前 tag 在共享 style 纹理中的下标(color 即 id) */
|
|
170
|
+
x(this, "sharedStyleIndex", -1);
|
|
171
|
+
/** 共享 mesh 的 registry key,用于 updateMaskStyle / dispose 查找 entry */
|
|
172
|
+
x(this, "_sharedMeshKey", null);
|
|
173
|
+
const t = (i = s.mask) != null ? i : s.maskUrl;
|
|
174
|
+
this.maskUrl = t instanceof HTMLCanvasElement || typeof t == "string" && t ? t : "";
|
|
175
|
+
const o = s.color;
|
|
176
|
+
this.targetColor = w(o), o || console.warn(`[MaskTag] No color provided for tag ${s.id}, using default [0, 0, 0]`), this.tagStyle = s.style, this.updateVisible(), this.currentVisible && this.initializeMaskMesh();
|
|
177
|
+
}
|
|
178
|
+
getColorKey() {
|
|
179
|
+
return `${this.targetColor[0]},${this.targetColor[1]},${this.targetColor[2]}`;
|
|
180
|
+
}
|
|
181
|
+
/** 同点位共用一个 mesh,key 仅用 panoIndex(string/canvas 切换时不会因 key 不同而重复创建) */
|
|
182
|
+
static getMeshKey(e) {
|
|
183
|
+
return String(e);
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* 初始化/挂载到同点位共享 mesh,用 appendStyleToMaterial 注册本 tag 的 style(color 即 id)
|
|
187
|
+
*/
|
|
188
|
+
initializeMaskMesh() {
|
|
189
|
+
return S(this, null, function* () {
|
|
190
|
+
var s;
|
|
191
|
+
if (this._disposed || !this.maskUrl)
|
|
192
|
+
return;
|
|
193
|
+
const e = (s = this.fiveState) == null ? void 0 : s.panoIndex;
|
|
194
|
+
if (typeof e == "number") {
|
|
195
|
+
this.loadingMask = !0;
|
|
196
|
+
try {
|
|
197
|
+
const t = yield h.loadMaskTexture(this.maskUrl);
|
|
198
|
+
this.maskTexture = t;
|
|
199
|
+
const o = h.getMeshKey(e);
|
|
200
|
+
this._sharedMeshKey = o;
|
|
201
|
+
let i = h.sharedMeshRegistry.get(o);
|
|
202
|
+
const r = this.getColorKey(), l = this.buildStyleForMaterial();
|
|
203
|
+
i ? i.maskSource !== this.maskUrl && (h.releaseMaskTexture(i.maskSource), i.maskTexture = t, i.maskSource = this.maskUrl, i.material.uniforms.map.value = t) : (i = h.createSharedMesh(t, this.maskUrl, this.plugin), h.sharedMeshRegistry.set(o, i), this.plugin.imagePlaneGroup.add(i.mesh));
|
|
204
|
+
const n = i.styleIndexByColorKey.get(r);
|
|
205
|
+
n !== void 0 ? (this.sharedStyleIndex = n, this.maskMesh = i.mesh, this.updateStyleSlotInMaterial(i.material, n, l)) : (i.tagsByColorKey.set(r, this), this.appendStyleToMaterial(i.material, l), this.sharedStyleIndex = i.tagsByColorKey.size - 1, i.styleIndexByColorKey.set(r, this.sharedStyleIndex), this.maskMesh = i.mesh), this.setupSharedMeshRaycast(i), this.updateMeshTransform(), this.setupClickEvents(), this.updateScreenPosition(), i.mesh.visible = !0;
|
|
206
|
+
} finally {
|
|
207
|
+
this.loadingMask = !1;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
/** 构建用于 mergedTexture 的 style 对象(color 作 id),tolerance 0–255 */
|
|
213
|
+
buildStyleForMaterial() {
|
|
214
|
+
const e = this.getMaskStyle(), s = e.tolerance, t = s <= 1 ? s * 255 : s;
|
|
215
|
+
return {
|
|
216
|
+
color: [this.targetColor[0], this.targetColor[1], this.targetColor[2], 1],
|
|
217
|
+
tolerance: t,
|
|
218
|
+
highlightColor: e.highlightColor,
|
|
219
|
+
opacity: this.enabled && this.visible ? e.opacity : 0
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
static createSharedMesh(e, s, t) {
|
|
223
|
+
const r = Math.max(1, Math.ceil(Math.sqrt(0))), l = 1, n = new Float32Array(r * l * 4), a = new g.DataTexture(n, r, l, g.RGBAFormat, g.FloatType);
|
|
224
|
+
a.needsUpdate = !0;
|
|
225
|
+
const d = new g.ShaderMaterial({
|
|
226
|
+
vertexShader: z,
|
|
227
|
+
fragmentShader: G,
|
|
228
|
+
uniforms: {
|
|
229
|
+
map: { value: e },
|
|
230
|
+
mergedTexture: { value: a },
|
|
231
|
+
groupCount: { value: 0 },
|
|
232
|
+
textureWidth: { value: r },
|
|
233
|
+
pixelsPerGroup: { value: 3 }
|
|
234
|
+
},
|
|
235
|
+
depthWrite: !1,
|
|
236
|
+
depthTest: !1,
|
|
237
|
+
transparent: !0
|
|
238
|
+
}), u = new g.SphereGeometry(1, 60, 40);
|
|
239
|
+
u.rotateY(-Math.PI / 2), u.scale(-1, 1, 1);
|
|
240
|
+
const p = new g.Mesh(u, d);
|
|
241
|
+
return p.renderOrder = -1e3, p.__maskMesh = !0, {
|
|
242
|
+
mesh: p,
|
|
243
|
+
material: d,
|
|
244
|
+
maskTexture: e,
|
|
245
|
+
maskSource: s,
|
|
246
|
+
tagsByColorKey: /* @__PURE__ */ new Map(),
|
|
247
|
+
styleIndexByColorKey: /* @__PURE__ */ new Map()
|
|
248
|
+
};
|
|
249
|
+
}
|
|
250
|
+
/** 仅更新材质中某一 slot 的 style(用于 enable/disable/updateMaskStyle) */
|
|
251
|
+
updateStyleSlotInMaterial(e, s, t) {
|
|
252
|
+
const i = e.uniforms.mergedTexture.value, r = i.image.data, n = s * 3, a = n * 4;
|
|
253
|
+
r[a] = t.color[0] / 255, r[a + 1] = t.color[1] / 255, r[a + 2] = t.color[2] / 255, r[a + 3] = t.color[3];
|
|
254
|
+
const d = (n + 1) * 4;
|
|
255
|
+
r[d] = t.tolerance / 255, r[d + 1] = t.highlightColor[0] / 255, r[d + 2] = t.highlightColor[1] / 255, r[d + 3] = t.highlightColor[2] / 255;
|
|
256
|
+
const u = (n + 2) * 4;
|
|
257
|
+
r[u] = t.opacity, i.needsUpdate = !0, this.five.needsRender = !0;
|
|
258
|
+
}
|
|
259
|
+
setupSharedMeshRaycast(e) {
|
|
260
|
+
const s = e.mesh;
|
|
261
|
+
if (s.__maskRaycastSet)
|
|
262
|
+
return;
|
|
263
|
+
s.__maskRaycastSet = !0;
|
|
264
|
+
let t = null, o = null;
|
|
265
|
+
const i = () => {
|
|
266
|
+
const l = e.maskTexture;
|
|
267
|
+
if (!(l != null && l.image))
|
|
268
|
+
return null;
|
|
269
|
+
if (o === l && t)
|
|
270
|
+
return t;
|
|
271
|
+
o = l;
|
|
272
|
+
try {
|
|
273
|
+
const n = document.createElement("canvas"), a = n.getContext("2d");
|
|
274
|
+
if (!a)
|
|
275
|
+
return null;
|
|
276
|
+
const d = l.image;
|
|
277
|
+
return n.width = d.width, n.height = d.height, a.drawImage(d, 0, 0), t = a.getImageData(0, 0, d.width, d.height), t;
|
|
278
|
+
} catch (n) {
|
|
279
|
+
return null;
|
|
280
|
+
}
|
|
281
|
+
}, r = s.raycast.bind(s);
|
|
282
|
+
s.raycast = (l, n) => {
|
|
283
|
+
var k, I;
|
|
284
|
+
const a = [];
|
|
285
|
+
if (r(l, a), a.length === 0)
|
|
286
|
+
return;
|
|
287
|
+
const d = a[0];
|
|
288
|
+
if (!d.uv || !((k = e.maskTexture) != null && k.image))
|
|
289
|
+
return;
|
|
290
|
+
const u = i();
|
|
291
|
+
if (!u)
|
|
292
|
+
return;
|
|
293
|
+
const p = Math.floor(d.uv.x * u.width), y = (Math.floor((1 - d.uv.y) * u.height) * u.width + p) * 4, f = [u.data[y], u.data[y + 1], u.data[y + 2]], M = 0.5 / 255;
|
|
294
|
+
for (const [, T] of e.tagsByColorKey) {
|
|
295
|
+
if (!T.enabled || ((I = T.config) == null ? void 0 : I.clickable) === !1)
|
|
296
|
+
continue;
|
|
297
|
+
const [K, P, U] = T.targetColor;
|
|
298
|
+
if (Math.abs(f[0] / 255 - K / 255) + Math.abs(f[1] / 255 - P / 255) + Math.abs(f[2] / 255 - U / 255) <= M) {
|
|
299
|
+
s.userData.__lastHitTag = T, n.push(d);
|
|
300
|
+
return;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
};
|
|
172
304
|
}
|
|
173
305
|
/**
|
|
174
306
|
* 计算法向量
|
|
175
307
|
* Mask 标签返回向上的法向量(因为是贴在 cube 面上)
|
|
176
308
|
*/
|
|
177
309
|
computeNormal() {
|
|
178
|
-
return new
|
|
310
|
+
return new g.Vector3(0, 1, 0);
|
|
179
311
|
}
|
|
180
312
|
/**
|
|
181
|
-
*
|
|
182
|
-
* 返回 maskMesh 用于 blink 动画
|
|
313
|
+
* 不把共享 mesh 作为 blink 目标,闪烁通过本 tag 的 style opacity 动画实现
|
|
183
314
|
*/
|
|
184
315
|
getAdditionalBlinkTargets() {
|
|
185
|
-
return
|
|
316
|
+
return null;
|
|
317
|
+
}
|
|
318
|
+
/**
|
|
319
|
+
* 闪烁仅针对本 tag:通过改变本 tag 在 merged texture 中的 opacity 实现
|
|
320
|
+
*/
|
|
321
|
+
blink(e) {
|
|
322
|
+
return S(this, null, function* () {
|
|
323
|
+
var a, d, u;
|
|
324
|
+
if (!this.maskMesh || this._sharedMeshKey === null || this.sharedStyleIndex < 0)
|
|
325
|
+
return;
|
|
326
|
+
const s = h.sharedMeshRegistry.get(this._sharedMeshKey);
|
|
327
|
+
if (!s)
|
|
328
|
+
return;
|
|
329
|
+
const i = { opacity: this.buildStyleForMaterial().opacity }, r = (a = e == null ? void 0 : e.duration) != null ? a : 300, l = (d = e == null ? void 0 : e.loop) != null ? d : 4, n = $({
|
|
330
|
+
targets: i,
|
|
331
|
+
opacity: [0, 1],
|
|
332
|
+
duration: r,
|
|
333
|
+
easing: (u = e == null ? void 0 : e.easing) != null ? u : "easeInOutQuad",
|
|
334
|
+
direction: "alternate",
|
|
335
|
+
loop: l,
|
|
336
|
+
update: () => {
|
|
337
|
+
const p = this.buildStyleForMaterial();
|
|
338
|
+
p.opacity = i.opacity, this.updateStyleSlotInMaterial(s.material, this.sharedStyleIndex, p);
|
|
339
|
+
}
|
|
340
|
+
});
|
|
341
|
+
try {
|
|
342
|
+
yield n.finished;
|
|
343
|
+
} catch (p) {
|
|
344
|
+
} finally {
|
|
345
|
+
this.updateMaskStyle();
|
|
346
|
+
}
|
|
347
|
+
});
|
|
186
348
|
}
|
|
187
349
|
/**
|
|
188
350
|
* 更新标签数据
|
|
189
351
|
*/
|
|
190
|
-
set(e,
|
|
191
|
-
|
|
352
|
+
set(e, s = !0) {
|
|
353
|
+
var o, i;
|
|
354
|
+
super.set(e, s), e.style && (this.tagStyle = v(v({}, this.tagStyle), e.style), (o = e.style) != null && o.mask && this.updateMaskStyle());
|
|
355
|
+
const t = (i = e.mask) != null ? i : e.maskUrl;
|
|
356
|
+
t && t !== this.maskUrl && (this.maskUrl = t, this.updateSharedMeshTexture()), e.color !== void 0 && (this.targetColor = w(e.color), this.updateMaskStyle()), this.maskMesh && this.updateMaskStyle();
|
|
357
|
+
}
|
|
358
|
+
/** 供 rebuildEntryMaterial 使用:返回当前 tag 的 style 对象 */
|
|
359
|
+
getStyleForMaterial() {
|
|
360
|
+
return this.buildStyleForMaterial();
|
|
192
361
|
}
|
|
193
362
|
/**
|
|
194
363
|
* 重写 getVisible 方法
|
|
195
364
|
* Mask 标签仅在当前点位可见
|
|
196
365
|
*/
|
|
197
366
|
getVisible(e) {
|
|
198
|
-
var
|
|
367
|
+
var s;
|
|
199
368
|
try {
|
|
200
369
|
if (!this.enabled || !this.plugin.state.enabled || !this.fiveUtil.model || !this.maskUrl)
|
|
201
370
|
return !1;
|
|
202
|
-
const
|
|
203
|
-
return
|
|
204
|
-
} catch (
|
|
371
|
+
const t = v(v({}, this.five.getCurrentState()), e), { panoIndex: o } = t;
|
|
372
|
+
return o !== ((s = this.fiveState) == null ? void 0 : s.panoIndex) ? !1 : super.getVisible(t);
|
|
373
|
+
} catch (t) {
|
|
205
374
|
return !1;
|
|
206
375
|
}
|
|
207
376
|
}
|
|
@@ -210,24 +379,17 @@ const h = class extends P {
|
|
|
210
379
|
* 增加 Mask 特有的可见性检查逻辑,用于 whyHide 功能
|
|
211
380
|
*/
|
|
212
381
|
computeVisible(e) {
|
|
213
|
-
var
|
|
214
|
-
const
|
|
215
|
-
return
|
|
382
|
+
var o, i, r;
|
|
383
|
+
const s = v(v({}, this.five.getCurrentState()), e), { panoIndex: t } = s;
|
|
384
|
+
return t !== ((o = this.fiveState) == null ? void 0 : o.panoIndex) ? {
|
|
216
385
|
value: !1,
|
|
217
386
|
reason: {
|
|
218
387
|
type: "panoIndex mismatch",
|
|
219
|
-
detail: `Mask 标签仅在当前点位可见。当前点位: ${
|
|
220
|
-
currentPanoIndex:
|
|
221
|
-
tagPanoIndex: (
|
|
388
|
+
detail: `Mask 标签仅在当前点位可见。当前点位: ${t}, 标签点位: ${(i = this.fiveState) == null ? void 0 : i.panoIndex}`,
|
|
389
|
+
currentPanoIndex: t,
|
|
390
|
+
tagPanoIndex: (r = this.fiveState) == null ? void 0 : r.panoIndex
|
|
222
391
|
}
|
|
223
|
-
} : super.computeVisible(e)
|
|
224
|
-
value: !1,
|
|
225
|
-
reason: {
|
|
226
|
-
type: "maskUrl invalid",
|
|
227
|
-
detail: `Mask 标签 ${this.id} 的 maskUrl 无效`,
|
|
228
|
-
maskUrl: this.maskUrl
|
|
229
|
-
}
|
|
230
|
-
};
|
|
392
|
+
} : super.computeVisible(e);
|
|
231
393
|
}
|
|
232
394
|
/**
|
|
233
395
|
* 点击事件处理
|
|
@@ -241,9 +403,9 @@ const h = class extends P {
|
|
|
241
403
|
unfoldAndFoldOthers() {
|
|
242
404
|
if (this.isPopoverConfigEnabled())
|
|
243
405
|
return;
|
|
244
|
-
const e = this.can("fold"),
|
|
245
|
-
e &&
|
|
246
|
-
|
|
406
|
+
const e = this.can("fold"), s = this.can("unfold");
|
|
407
|
+
e && s && (this.state.unfolded = !this.state.unfolded, this.manuallyOperated = !0, this.plugin.addRenderQueue({ type: "TagContainerSvelte", keys: ["tags"] }), this.state.unfolded && this.plugin.tags.forEach((t) => {
|
|
408
|
+
t.id !== this.id && t.fold();
|
|
247
409
|
}));
|
|
248
410
|
}
|
|
249
411
|
/**
|
|
@@ -264,8 +426,8 @@ const h = class extends P {
|
|
|
264
426
|
setUnfold(e) {
|
|
265
427
|
if (this.isPopoverConfigEnabled())
|
|
266
428
|
return;
|
|
267
|
-
const
|
|
268
|
-
|
|
429
|
+
const s = this.can("fold"), t = this.can("unfold");
|
|
430
|
+
s && t && (this.state.unfolded = e, this.hooks.emit(e ? "unfolded" : "folded"), this.plugin.addRenderQueue({ type: "TagContainerSvelte", keys: ["tags"] }));
|
|
269
431
|
}
|
|
270
432
|
/**
|
|
271
433
|
* 更新屏幕位置
|
|
@@ -275,27 +437,25 @@ const h = class extends P {
|
|
|
275
437
|
this.screenPosition = null, this.plugin.addRenderQueue({ type: "TagContainerSvelte", keys: ["tags"] });
|
|
276
438
|
return;
|
|
277
439
|
}
|
|
278
|
-
const
|
|
440
|
+
const s = new g.Vector3(...this.position).clone().project(this.five.camera);
|
|
279
441
|
if (this.five.renderer) {
|
|
280
|
-
const
|
|
442
|
+
const t = this.five.renderer.getSize(new g.Vector2());
|
|
281
443
|
this.screenPosition = {
|
|
282
|
-
leftPx: (
|
|
283
|
-
topPx: (-
|
|
444
|
+
leftPx: (s.x + 1) / 2 * t.x,
|
|
445
|
+
topPx: (-s.y + 1) / 2 * t.y,
|
|
284
446
|
scale: 1
|
|
285
447
|
};
|
|
286
448
|
}
|
|
287
449
|
this.plugin.addRenderQueue({ type: "TagContainerSvelte", keys: ["tags"] });
|
|
288
450
|
}
|
|
289
451
|
/**
|
|
290
|
-
*
|
|
452
|
+
* 应用可见性变化(通过 style opacity 控制展示,共享 mesh 保持 visible)
|
|
291
453
|
*/
|
|
292
454
|
applyVisible() {
|
|
293
455
|
try {
|
|
294
|
-
if (!this.maskUrl)
|
|
295
|
-
console.warn(`[MaskTag] ${this.id} cannot apply visible: maskUrl is invalid`);
|
|
456
|
+
if (!this.maskUrl)
|
|
296
457
|
return;
|
|
297
|
-
|
|
298
|
-
this.visible && !this.maskMesh && !this.loadingMask && this.initializeMaskMesh(), this.maskMesh && (this.maskMesh.visible = this.visible, this.updateMeshTransform()), this.updateScreenPosition();
|
|
458
|
+
this.visible && !this.loadingMask && this.initializeMaskMesh(), this.maskMesh && (this.updateMaskStyle(), this.updateMeshTransform()), this.updateScreenPosition();
|
|
299
459
|
} catch (e) {
|
|
300
460
|
console.error(`[MaskTag] Error in applyVisible for tag ${this.id}:`, e);
|
|
301
461
|
}
|
|
@@ -305,113 +465,83 @@ const h = class extends P {
|
|
|
305
465
|
* 参考 itemMask 实现
|
|
306
466
|
*/
|
|
307
467
|
updateMeshTransform() {
|
|
308
|
-
var
|
|
468
|
+
var r;
|
|
309
469
|
if (!this.maskMesh)
|
|
310
470
|
return;
|
|
311
|
-
const e = (
|
|
471
|
+
const e = (r = this.fiveState) == null ? void 0 : r.panoIndex;
|
|
312
472
|
if (e === void 0)
|
|
313
473
|
return;
|
|
314
|
-
const
|
|
315
|
-
|
|
474
|
+
const s = this.workUtil.getObserver(e);
|
|
475
|
+
if (!s)
|
|
476
|
+
return;
|
|
477
|
+
this.maskMesh.position.copy(L(s.position, this.workUtil.transform)), this.maskMesh.quaternion.copy(s.quaternion);
|
|
478
|
+
const t = new g.Vector3(), o = new g.Quaternion(), i = new g.Vector3();
|
|
479
|
+
this.workUtil.transform.decompose(t, o, i), this.maskMesh.quaternion.multiply(o), this.five.needsRender = !0;
|
|
316
480
|
}
|
|
317
481
|
/**
|
|
318
|
-
*
|
|
482
|
+
* 步骤1:从材质中解析出 styleList
|
|
483
|
+
* @param {THREE.ShaderMaterial} material - 目标材质
|
|
484
|
+
* @returns {Array} 解析后的 styleList
|
|
319
485
|
*/
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
} finally {
|
|
333
|
-
this.loadingMask = !1;
|
|
334
|
-
}
|
|
335
|
-
});
|
|
486
|
+
parseStyleListFromMaterial(e) {
|
|
487
|
+
const s = e.uniforms, t = s.groupCount.value, o = s.pixelsPerGroup.value, r = s.mergedTexture.value.image.data, l = [];
|
|
488
|
+
for (let n = 0; n < t; n++) {
|
|
489
|
+
const a = n * o, d = a * 4, u = r[d] * 255, p = r[d + 1] * 255, C = r[d + 2] * 255, y = r[d + 3], f = (a + 1) * 4, M = r[f] * 255, k = r[f + 1] * 255, I = r[f + 2] * 255, T = r[f + 3] * 255, K = (a + 2) * 4, P = r[K];
|
|
490
|
+
l.push({
|
|
491
|
+
color: [Math.round(u), Math.round(p), Math.round(C), y],
|
|
492
|
+
tolerance: Math.round(M),
|
|
493
|
+
highlightColor: [Math.round(k), Math.round(I), Math.round(T)],
|
|
494
|
+
opacity: P
|
|
495
|
+
});
|
|
496
|
+
}
|
|
497
|
+
return l;
|
|
336
498
|
}
|
|
337
499
|
/**
|
|
338
|
-
*
|
|
500
|
+
* 步骤2:更新材质的样式纹理(追加新元素后)
|
|
501
|
+
* @param {THREE.ShaderMaterial} material - 目标材质
|
|
502
|
+
* @param {Array} newStyle - 要追加的新样式对象
|
|
339
503
|
*/
|
|
340
|
-
|
|
341
|
-
const t = this.
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
depthWrite: !1,
|
|
355
|
-
depthTest: !1,
|
|
356
|
-
transparent: !0
|
|
357
|
-
}), n = new m.SphereGeometry(1, 60, 40);
|
|
358
|
-
n.rotateY(-Math.PI / 2), n.scale(-1, 1, 1);
|
|
359
|
-
const i = new m.Mesh(n, a);
|
|
360
|
-
i.renderOrder = -1e3;
|
|
361
|
-
let l = null;
|
|
362
|
-
const u = () => {
|
|
363
|
-
if (l)
|
|
364
|
-
return l;
|
|
365
|
-
if (!e.image)
|
|
366
|
-
return null;
|
|
367
|
-
try {
|
|
368
|
-
const f = document.createElement("canvas"), d = f.getContext("2d");
|
|
369
|
-
if (!d)
|
|
370
|
-
return null;
|
|
371
|
-
const p = e.image;
|
|
372
|
-
return f.width = p.width, f.height = p.height, d.drawImage(p, 0, 0), l = d.getImageData(0, 0, p.width, p.height), l;
|
|
373
|
-
} catch (f) {
|
|
374
|
-
return console.error("[MaskTag] Failed to get image data:", f), null;
|
|
375
|
-
}
|
|
376
|
-
}, g = i.raycast.bind(i);
|
|
377
|
-
return i.raycast = (f, d) => {
|
|
378
|
-
const p = [];
|
|
379
|
-
if (g(f, p), p.length > 0) {
|
|
380
|
-
const y = p[0];
|
|
381
|
-
if (y.uv && e.image) {
|
|
382
|
-
const k = u();
|
|
383
|
-
if (k) {
|
|
384
|
-
const U = Math.floor(y.uv.x * k.width), T = (Math.floor((1 - y.uv.y) * k.height) * k.width + U) * 4, b = [k.data[T], k.data[T + 1], k.data[T + 2]];
|
|
385
|
-
Math.abs(b[0] / 255 - this.targetColor[0] / 255) + Math.abs(b[1] / 255 - this.targetColor[1] / 255) + Math.abs(b[2] / 255 - this.targetColor[2] / 255) < t.tolerance && d.push(y);
|
|
386
|
-
}
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
}, i.__maskTag = this.id, i.__maskMesh = !0, i;
|
|
504
|
+
appendStyleToMaterial(e, s) {
|
|
505
|
+
const t = this.parseStyleListFromMaterial(e);
|
|
506
|
+
Array.isArray(s) ? t.push(...s) : t.push(s);
|
|
507
|
+
const o = t.length, i = 3, l = o * i, n = 1, a = new Float32Array(l * n * 4);
|
|
508
|
+
t.forEach((p, C) => {
|
|
509
|
+
const y = C * i, f = y * 4;
|
|
510
|
+
a[f] = p.color[0] / 255, a[f + 1] = p.color[1] / 255, a[f + 2] = p.color[2] / 255, a[f + 3] = p.color[3];
|
|
511
|
+
const M = (y + 1) * 4;
|
|
512
|
+
a[M] = p.tolerance / 255, a[M + 1] = p.highlightColor[0] / 255, a[M + 2] = p.highlightColor[1] / 255, a[M + 3] = p.highlightColor[2] / 255;
|
|
513
|
+
const k = (y + 2) * 4;
|
|
514
|
+
a[k] = p.opacity, a[k + 1] = 0, a[k + 2] = 0, a[k + 3] = 0;
|
|
515
|
+
});
|
|
516
|
+
const d = e.uniforms.mergedTexture.value, u = d.image;
|
|
517
|
+
u.data = a, u.width = l, u.height = n, d.needsUpdate = !0, e.uniforms.groupCount.value = o, e.uniforms.textureWidth.value = l, console.log(`成功追加样式,当前总组数:${o}`);
|
|
390
518
|
}
|
|
391
519
|
/**
|
|
392
520
|
* 获取 Mask 样式配置(合并用户配置和默认值)
|
|
393
521
|
*/
|
|
394
522
|
getMaskStyle() {
|
|
395
|
-
var
|
|
396
|
-
const e = ((
|
|
397
|
-
let
|
|
398
|
-
return e.color !== void 0 ?
|
|
399
|
-
tolerance: (
|
|
523
|
+
var t, o, i;
|
|
524
|
+
const e = ((t = this.tagStyle) == null ? void 0 : t.mask) || {};
|
|
525
|
+
let s = [255, 255, 255];
|
|
526
|
+
return e.color !== void 0 ? s = w(e.color) : e.highlightColor !== void 0 && (s = w(e.highlightColor)), {
|
|
527
|
+
tolerance: (o = e.tolerance) != null ? o : 1e-3,
|
|
400
528
|
// 参考 itemMask 默认 0.001(归一化后的值)
|
|
401
|
-
highlightColor:
|
|
402
|
-
opacity: (
|
|
529
|
+
highlightColor: s,
|
|
530
|
+
opacity: (i = e.opacity) != null ? i : 0.6
|
|
403
531
|
// 默认 0.6(用于填充区域)
|
|
404
532
|
};
|
|
405
533
|
}
|
|
406
534
|
/**
|
|
407
|
-
*
|
|
535
|
+
* 设置点击事件(仅当 raycast 命中本 tag 的 color 时触发)
|
|
408
536
|
*/
|
|
409
537
|
setupClickEvents() {
|
|
410
|
-
|
|
538
|
+
var s;
|
|
539
|
+
if (!this.maskMesh || ((s = this.config) == null ? void 0 : s.clickable) === !1)
|
|
411
540
|
return;
|
|
412
541
|
this.cleanupClickEvents();
|
|
413
542
|
const e = (t) => {
|
|
414
|
-
|
|
543
|
+
var i, r;
|
|
544
|
+
((r = (i = this.maskMesh) == null ? void 0 : i.userData) == null ? void 0 : r.__lastHitTag) === this && this.plugin.hooks.emit("click", { event: t, target: "TagMaskModel", tag: this });
|
|
415
545
|
};
|
|
416
546
|
requestAnimationFrame(() => {
|
|
417
547
|
!this.maskMesh || !this.plugin.domEvents || (this.clickEventDispose = this.addObjectClickHandler(this, this.maskMesh, e));
|
|
@@ -424,25 +554,49 @@ const h = class extends P {
|
|
|
424
554
|
this.clickEventDispose && (this.clickEventDispose(), this.clickEventDispose = void 0);
|
|
425
555
|
}
|
|
426
556
|
/**
|
|
427
|
-
* 重新加载 mask
|
|
557
|
+
* 重新加载 mask 图:从旧点位 mesh 注销,再按新 maskUrl 初始化
|
|
558
|
+
*/
|
|
559
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars -- 保留参数与 set() 调用一致
|
|
560
|
+
reloadMask(e) {
|
|
561
|
+
var i;
|
|
562
|
+
const s = (i = this.fiveState) == null ? void 0 : i.panoIndex, t = this.getColorKey(), o = typeof s == "number" ? h.getMeshKey(s) : this._sharedMeshKey;
|
|
563
|
+
if (o) {
|
|
564
|
+
const r = h.sharedMeshRegistry.get(o);
|
|
565
|
+
r && (r.tagsByColorKey.delete(t), r.styleIndexByColorKey.delete(t), r.tagsByColorKey.size === 0 && (r.mesh.parent && r.mesh.parent.remove(r.mesh), r.mesh.geometry.dispose(), r.mesh.material.dispose(), r.material.uniforms.mergedTexture.value.dispose(), h.releaseMaskTexture(r.maskSource), h.sharedMeshRegistry.delete(o)));
|
|
566
|
+
}
|
|
567
|
+
this.maskMesh = void 0, this._sharedMeshKey = null, this.sharedStyleIndex = -1, this.maskTexture = void 0, this.visible && !this.loadingMask && this.initializeMaskMesh();
|
|
568
|
+
}
|
|
569
|
+
/**
|
|
570
|
+
* changeTagById 改 mask 时:只更新共享 mesh 的 texture,不 unregister
|
|
571
|
+
* 有 entry 则换图;无 entry 则走完整初始化
|
|
428
572
|
*/
|
|
429
|
-
|
|
430
|
-
return
|
|
431
|
-
|
|
573
|
+
updateSharedMeshTexture() {
|
|
574
|
+
return S(this, null, function* () {
|
|
575
|
+
var i;
|
|
576
|
+
if (this._disposed || !this.maskUrl)
|
|
577
|
+
return;
|
|
578
|
+
const e = (i = this.fiveState) == null ? void 0 : i.panoIndex;
|
|
579
|
+
if (typeof e != "number")
|
|
580
|
+
return;
|
|
581
|
+
const s = h.getMeshKey(e), t = h.sharedMeshRegistry.get(s);
|
|
582
|
+
if (!t) {
|
|
583
|
+
yield this.initializeMaskMesh();
|
|
584
|
+
return;
|
|
585
|
+
}
|
|
586
|
+
if (t.maskSource === this.maskUrl)
|
|
587
|
+
return;
|
|
588
|
+
const o = yield h.loadMaskTexture(this.maskUrl);
|
|
589
|
+
this.maskTexture = o, h.releaseMaskTexture(t.maskSource), t.maskTexture = o, t.maskSource = this.maskUrl, t.material.uniforms.map.value = o, this.five.needsRender = !0;
|
|
432
590
|
});
|
|
433
591
|
}
|
|
434
592
|
/**
|
|
435
|
-
*
|
|
593
|
+
* 更新当前 tag 在共享材质中的 style slot(color/style 控制展示)
|
|
436
594
|
*/
|
|
437
595
|
updateMaskStyle() {
|
|
438
|
-
if (!this.maskMesh)
|
|
596
|
+
if (!this.maskMesh || this._sharedMeshKey === null || this.sharedStyleIndex < 0)
|
|
439
597
|
return;
|
|
440
|
-
const e =
|
|
441
|
-
|
|
442
|
-
e.highlightColor[0] / 255,
|
|
443
|
-
e.highlightColor[1] / 255,
|
|
444
|
-
e.highlightColor[2] / 255
|
|
445
|
-
), t.uniforms.opacity.value = e.opacity), this.five.needsRender = !0;
|
|
598
|
+
const e = h.sharedMeshRegistry.get(this._sharedMeshKey);
|
|
599
|
+
e && this.updateStyleSlotInMaterial(e.material, this.sharedStyleIndex, this.buildStyleForMaterial());
|
|
446
600
|
}
|
|
447
601
|
/**
|
|
448
602
|
* 更新 Canvas 纹理(仅当 maskUrl 为 Canvas 时有效)
|
|
@@ -453,13 +607,22 @@ const h = class extends P {
|
|
|
453
607
|
console.warn("[MaskTag] updateCanvasTexture only works for Canvas-based masks");
|
|
454
608
|
return;
|
|
455
609
|
}
|
|
456
|
-
this.maskTexture instanceof
|
|
610
|
+
this.maskTexture instanceof g.CanvasTexture && (this.maskTexture.needsUpdate = !0, this.five.needsRender = !0, console.log("[MaskTag] Canvas texture updated"));
|
|
457
611
|
}
|
|
458
612
|
/**
|
|
459
|
-
*
|
|
613
|
+
* 清理当前标签:从共享材质中删除本 tag 的样式槽,并更新材质;
|
|
614
|
+
* 若该点位已无其他 tag 则销毁 mesh 并释放纹理。
|
|
460
615
|
*/
|
|
461
616
|
disposeMaskResources() {
|
|
462
|
-
|
|
617
|
+
if (this._disposed)
|
|
618
|
+
return;
|
|
619
|
+
this._disposed = !0, this.cleanupClickEvents();
|
|
620
|
+
const e = this._sharedMeshKey, s = this.getColorKey();
|
|
621
|
+
if (e) {
|
|
622
|
+
const t = h.sharedMeshRegistry.get(e);
|
|
623
|
+
t && (t.tagsByColorKey.delete(s), t.styleIndexByColorKey.delete(s), t.tagsByColorKey.size === 0 ? (t.mesh.parent && t.mesh.parent.remove(t.mesh), t.mesh.geometry.dispose(), t.mesh.material.dispose(), t.material.uniforms.mergedTexture.value.dispose(), h.releaseMaskTexture(t.maskSource), h.sharedMeshRegistry.delete(e)) : h.rebuildEntryMaterial(t));
|
|
624
|
+
}
|
|
625
|
+
this.maskMesh = void 0, this._sharedMeshKey = null, this.sharedStyleIndex = -1, this.maskTexture = void 0;
|
|
463
626
|
}
|
|
464
627
|
/**
|
|
465
628
|
* 清理 MaskTag 特有的资源(公开方法)
|
|
@@ -468,10 +631,16 @@ const h = class extends P {
|
|
|
468
631
|
this.disposeMaskResources();
|
|
469
632
|
}
|
|
470
633
|
/**
|
|
471
|
-
*
|
|
634
|
+
* 禁用标签(通过 style opacity=0 隐藏,不拆 mesh)
|
|
472
635
|
*/
|
|
473
636
|
disable() {
|
|
474
|
-
|
|
637
|
+
super.disable(), this.updateMaskStyle();
|
|
638
|
+
}
|
|
639
|
+
/**
|
|
640
|
+
* 启用标签(恢复 style 展示)
|
|
641
|
+
*/
|
|
642
|
+
enable() {
|
|
643
|
+
super.enable(), this.updateMaskStyle();
|
|
475
644
|
}
|
|
476
645
|
/**
|
|
477
646
|
* 销毁标签(重写父类方法)
|
|
@@ -479,6 +648,44 @@ const h = class extends P {
|
|
|
479
648
|
destroy() {
|
|
480
649
|
this.disposeMaskResources(), super.destroy();
|
|
481
650
|
}
|
|
651
|
+
/**
|
|
652
|
+
* 清除所有点位共享 mesh(重新 load 数据前调用)
|
|
653
|
+
*/
|
|
654
|
+
static clearSharedMeshRegistry() {
|
|
655
|
+
h.sharedMeshRegistry.forEach((e) => {
|
|
656
|
+
e.tagsByColorKey.forEach((s) => {
|
|
657
|
+
s.maskMesh = void 0, s._sharedMeshKey = null, s.sharedStyleIndex = -1;
|
|
658
|
+
}), e.mesh.parent && e.mesh.parent.remove(e.mesh), e.mesh.geometry.dispose(), e.mesh.material.dispose(), e.material.uniforms.mergedTexture.value.dispose(), h.releaseMaskTexture(e.maskSource);
|
|
659
|
+
}), h.sharedMeshRegistry.clear();
|
|
660
|
+
}
|
|
661
|
+
/**
|
|
662
|
+
* 将 style 列表写入材质(用于重建材质)
|
|
663
|
+
*/
|
|
664
|
+
static writeStyleListToMaterial(e, s) {
|
|
665
|
+
const t = s.length, o = 3, r = t * o, l = 1, n = new Float32Array(r * l * 4);
|
|
666
|
+
s.forEach((u, p) => {
|
|
667
|
+
const C = p * o, y = C * 4;
|
|
668
|
+
n[y] = u.color[0] / 255, n[y + 1] = u.color[1] / 255, n[y + 2] = u.color[2] / 255, n[y + 3] = u.color[3];
|
|
669
|
+
const f = (C + 1) * 4;
|
|
670
|
+
n[f] = u.tolerance / 255, n[f + 1] = u.highlightColor[0] / 255, n[f + 2] = u.highlightColor[1] / 255, n[f + 3] = u.highlightColor[2] / 255;
|
|
671
|
+
const M = (C + 2) * 4;
|
|
672
|
+
n[M] = u.opacity;
|
|
673
|
+
});
|
|
674
|
+
const a = e.uniforms.mergedTexture.value, d = a.image;
|
|
675
|
+
d.data = n, d.width = r, d.height = l, a.needsUpdate = !0, e.uniforms.groupCount.value = t, e.uniforms.textureWidth.value = r;
|
|
676
|
+
}
|
|
677
|
+
/**
|
|
678
|
+
* destroy 后重建该点位材质,更新剩余 tag 的 styleIndex
|
|
679
|
+
*/
|
|
680
|
+
static rebuildEntryMaterial(e) {
|
|
681
|
+
const s = Array.from(e.tagsByColorKey.values()).sort((o, i) => o.sharedStyleIndex - i.sharedStyleIndex);
|
|
682
|
+
if (s.length === 0)
|
|
683
|
+
return;
|
|
684
|
+
const t = s.map((o) => o.getStyleForMaterial());
|
|
685
|
+
h.writeStyleListToMaterial(e.material, t), s.forEach((o, i) => {
|
|
686
|
+
o.sharedStyleIndex = i, e.styleIndexByColorKey.set(`${o.targetColor[0]},${o.targetColor[1]},${o.targetColor[2]}`, i);
|
|
687
|
+
});
|
|
688
|
+
}
|
|
482
689
|
/**
|
|
483
690
|
* 获取 mask 的缓存 key
|
|
484
691
|
* @param maskSource mask URL 或 Canvas
|
|
@@ -488,8 +695,8 @@ const h = class extends P {
|
|
|
488
695
|
if (typeof e == "string")
|
|
489
696
|
return e;
|
|
490
697
|
{
|
|
491
|
-
let
|
|
492
|
-
return
|
|
698
|
+
let s = h.canvasSymbolMap.get(e);
|
|
699
|
+
return s || (s = Symbol("canvas-mask"), h.canvasSymbolMap.set(e, s)), s;
|
|
493
700
|
}
|
|
494
701
|
}
|
|
495
702
|
/**
|
|
@@ -498,48 +705,48 @@ const h = class extends P {
|
|
|
498
705
|
* @returns Promise<THREE.Texture>
|
|
499
706
|
*/
|
|
500
707
|
static loadMaskTexture(e) {
|
|
501
|
-
return
|
|
502
|
-
const
|
|
503
|
-
if (
|
|
504
|
-
return
|
|
505
|
-
const
|
|
708
|
+
return S(this, null, function* () {
|
|
709
|
+
const s = h.getMaskCacheKey(e), t = h.maskTextureCache.get(s);
|
|
710
|
+
if (t)
|
|
711
|
+
return t.refCount++, t.texture;
|
|
712
|
+
const o = performance.now(), i = new AbortController();
|
|
506
713
|
try {
|
|
507
|
-
let
|
|
714
|
+
let r;
|
|
508
715
|
if (typeof e == "string") {
|
|
509
|
-
const
|
|
510
|
-
|
|
511
|
-
if (
|
|
512
|
-
|
|
716
|
+
const a = new g.TextureLoader();
|
|
717
|
+
r = yield new Promise((d, u) => {
|
|
718
|
+
if (i.signal.aborted) {
|
|
719
|
+
u(new Error("Load aborted"));
|
|
513
720
|
return;
|
|
514
721
|
}
|
|
515
|
-
|
|
722
|
+
a.load(
|
|
516
723
|
e,
|
|
517
724
|
(p) => {
|
|
518
|
-
|
|
725
|
+
i.signal.aborted ? (p.dispose(), u(new Error("Load aborted"))) : d(p);
|
|
519
726
|
},
|
|
520
727
|
void 0,
|
|
521
728
|
(p) => {
|
|
522
|
-
|
|
729
|
+
u(p);
|
|
523
730
|
}
|
|
524
|
-
),
|
|
525
|
-
|
|
731
|
+
), i.signal.addEventListener("abort", () => {
|
|
732
|
+
u(new Error("Load aborted"));
|
|
526
733
|
});
|
|
527
734
|
});
|
|
528
735
|
} else
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
texture:
|
|
736
|
+
r = new g.CanvasTexture(e), r.needsUpdate = !0, console.log("[MaskTag] Created texture from canvas, size:", e.width, "x", e.height);
|
|
737
|
+
r.wrapS = g.ClampToEdgeWrapping, r.wrapT = g.ClampToEdgeWrapping, r.minFilter = g.LinearFilter, r.magFilter = g.LinearFilter, r.anisotropy = 4, r instanceof g.CanvasTexture && (r.needsUpdate = !0), h.maskTextureCache.set(s, {
|
|
738
|
+
texture: r,
|
|
532
739
|
refCount: 1,
|
|
533
|
-
abortController:
|
|
740
|
+
abortController: i
|
|
534
741
|
});
|
|
535
|
-
const l = performance.now() -
|
|
536
|
-
if (console.log(`[MaskTag Performance] Texture loaded in ${l.toFixed(2)}ms, source: ${
|
|
537
|
-
const
|
|
538
|
-
console.log(`[MaskTag Memory] Texture size: ${
|
|
742
|
+
const l = performance.now() - o, n = typeof e == "string" ? e.substring(0, 50) : "Canvas";
|
|
743
|
+
if (console.log(`[MaskTag Performance] Texture loaded in ${l.toFixed(2)}ms, source: ${n}`), r.image) {
|
|
744
|
+
const a = (r.image.width * r.image.height * 4 / 1048576).toFixed(2);
|
|
745
|
+
console.log(`[MaskTag Memory] Texture size: ${r.image.width}x${r.image.height}, estimated memory: ${a}MB`);
|
|
539
746
|
}
|
|
540
|
-
return
|
|
541
|
-
} catch (
|
|
542
|
-
throw console.error("[MaskTag] Failed to load mask texture:", typeof e == "string" ? e : "Canvas",
|
|
747
|
+
return r;
|
|
748
|
+
} catch (r) {
|
|
749
|
+
throw console.error("[MaskTag] Failed to load mask texture:", typeof e == "string" ? e : "Canvas", r), r;
|
|
543
750
|
}
|
|
544
751
|
});
|
|
545
752
|
}
|
|
@@ -548,11 +755,11 @@ const h = class extends P {
|
|
|
548
755
|
* @param maskSource mask 图片 URL 或 Canvas 元素
|
|
549
756
|
*/
|
|
550
757
|
static releaseMaskTexture(e) {
|
|
551
|
-
var
|
|
552
|
-
const
|
|
553
|
-
if (
|
|
554
|
-
const
|
|
555
|
-
console.log(`[MaskTag Memory] Releasing texture (refCount=0): ${
|
|
758
|
+
var o;
|
|
759
|
+
const s = h.getMaskCacheKey(e), t = h.maskTextureCache.get(s);
|
|
760
|
+
if (t && (t.refCount--, t.refCount <= 0)) {
|
|
761
|
+
const i = typeof e == "string" ? e.substring(0, 50) : "Canvas";
|
|
762
|
+
console.log(`[MaskTag Memory] Releasing texture (refCount=0): ${i}`), (o = t.abortController) == null || o.abort(), t.texture.dispose(), h.maskTextureCache.delete(s);
|
|
556
763
|
}
|
|
557
764
|
}
|
|
558
765
|
/**
|
|
@@ -560,26 +767,26 @@ const h = class extends P {
|
|
|
560
767
|
* @returns 缓存统计信息
|
|
561
768
|
*/
|
|
562
769
|
static getCacheStats() {
|
|
563
|
-
let e = 0,
|
|
564
|
-
const
|
|
565
|
-
return h.maskTextureCache.forEach((
|
|
566
|
-
e +=
|
|
567
|
-
let
|
|
568
|
-
if (
|
|
569
|
-
const
|
|
570
|
-
|
|
770
|
+
let e = 0, s = 0;
|
|
771
|
+
const t = [];
|
|
772
|
+
return h.maskTextureCache.forEach((o, i) => {
|
|
773
|
+
e += o.refCount;
|
|
774
|
+
let r = 0;
|
|
775
|
+
if (o.texture.image) {
|
|
776
|
+
const n = o.texture.image.width || 0, a = o.texture.image.height || 0;
|
|
777
|
+
r = n * a * 4 / (1024 * 1024), s += r;
|
|
571
778
|
}
|
|
572
|
-
const l = typeof
|
|
573
|
-
|
|
779
|
+
const l = typeof i == "string" ? i.substring(0, 80) : "[Canvas]";
|
|
780
|
+
t.push({
|
|
574
781
|
source: l,
|
|
575
|
-
refCount:
|
|
576
|
-
sizeMB: parseFloat(
|
|
782
|
+
refCount: o.refCount,
|
|
783
|
+
sizeMB: parseFloat(r.toFixed(2))
|
|
577
784
|
});
|
|
578
785
|
}), {
|
|
579
786
|
totalCached: h.maskTextureCache.size,
|
|
580
787
|
totalRefCount: e,
|
|
581
|
-
estimatedMemoryMB: parseFloat(
|
|
582
|
-
cacheEntries:
|
|
788
|
+
estimatedMemoryMB: parseFloat(s.toFixed(2)),
|
|
789
|
+
cacheEntries: t
|
|
583
790
|
};
|
|
584
791
|
}
|
|
585
792
|
/**
|
|
@@ -588,20 +795,21 @@ const h = class extends P {
|
|
|
588
795
|
*/
|
|
589
796
|
static clearAllCache() {
|
|
590
797
|
console.warn("[MaskTag] Clearing all texture cache"), h.maskTextureCache.forEach((e) => {
|
|
591
|
-
var
|
|
592
|
-
(
|
|
798
|
+
var s;
|
|
799
|
+
(s = e.abortController) == null || s.abort(), e.texture.dispose();
|
|
593
800
|
}), h.maskTextureCache.clear();
|
|
594
801
|
}
|
|
595
802
|
};
|
|
596
|
-
let
|
|
803
|
+
let b = h;
|
|
597
804
|
/**
|
|
598
805
|
* Mask 纹理缓存(静态,所有 MaskTag 实例共享)
|
|
599
806
|
* key: mask URL 或 canvas 的 symbol, value: { texture: THREE.Texture, refCount: number, abortController?: AbortController }
|
|
600
807
|
*/
|
|
601
|
-
|
|
808
|
+
x(b, "maskTextureCache", /* @__PURE__ */ new Map()), /**
|
|
602
809
|
* Canvas 到 Symbol 的映射(用于缓存 canvas 纹理)
|
|
603
810
|
*/
|
|
604
|
-
|
|
811
|
+
x(b, "canvasSymbolMap", /* @__PURE__ */ new WeakMap()), /** 同点位共用 mesh:key = meshKey(panoIndex + maskKey), value = 共享数据 */
|
|
812
|
+
x(b, "sharedMeshRegistry", /* @__PURE__ */ new Map());
|
|
605
813
|
export {
|
|
606
|
-
|
|
814
|
+
b as MaskTag
|
|
607
815
|
};
|