@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.
Files changed (512) hide show
  1. package/dist/PanoTagPlugin/controller/Tag/MaskTag.d.ts +69 -13
  2. package/dist/PanoTagPlugin/controller/Tag/MaskTag.shaders.d.ts +3 -1
  3. package/dist/PanoTagPlugin/controller/index.d.ts +19 -1
  4. package/dist/index.cjs.js +121 -127
  5. package/dist/index.js +4345 -4093
  6. package/dist/index.umd.js +115 -121
  7. package/libs/PanoTagPlugin/controller/Tag/MaskTag.d.ts +69 -13
  8. package/libs/PanoTagPlugin/controller/Tag/MaskTag.js +452 -244
  9. package/libs/PanoTagPlugin/controller/Tag/MaskTag.shaders.d.ts +3 -1
  10. package/libs/PanoTagPlugin/controller/Tag/MaskTag.shaders.js +88 -6
  11. package/libs/PanoTagPlugin/controller/Tag/MaskTag1.d.ts +202 -0
  12. package/libs/PanoTagPlugin/controller/Tag/MaskTag1.js +617 -0
  13. package/libs/PanoTagPlugin/controller/index.d.ts +19 -1
  14. package/libs/PanoTagPlugin/controller/index.js +183 -133
  15. package/libs/base/BasePlugin.js +1 -1
  16. package/libs/shared-utils/logger.js +1 -1
  17. package/package.json +1 -1
  18. package/docs/.nojekyll +0 -1
  19. package/docs/assets/custom.css +0 -0
  20. package/docs/assets/highlight.css +0 -127
  21. package/docs/assets/icons.js +0 -18
  22. package/docs/assets/icons.svg +0 -1
  23. package/docs/assets/main.js +0 -60
  24. package/docs/assets/navigation.js +0 -1
  25. package/docs/assets/search.js +0 -1
  26. package/docs/assets/style.css +0 -1493
  27. package/docs/classes/AreaMakerPluginType.AreaMakerController.html +0 -59
  28. package/docs/classes/AreaMakerPluginType.AreaMakerItem.html +0 -71
  29. package/docs/classes/CSS3DRender.html +0 -100
  30. package/docs/classes/GuideLineItem.GuideLineItem.html +0 -21
  31. package/docs/classes/GuideLineModeItem.GuideLineModeItem.html +0 -70
  32. package/docs/classes/ModelMakerPluginInstance.html +0 -116
  33. package/docs/classes/ModelMakerPluginType.ModelMakerBoxItem.html +0 -52
  34. package/docs/classes/ModelMakerPluginType.ModelMakerPolygonItem.html +0 -52
  35. package/docs/classes/ModelMakerPluginType.ModelMakerPrismItem.html +0 -53
  36. package/docs/classes/ModelRoomLabelController.html +0 -19
  37. package/docs/classes/MoveController.html +0 -45
  38. package/docs/classes/Object3DHelperController.html +0 -45
  39. package/docs/classes/PaintBrush.html +0 -15
  40. package/docs/classes/PanoMeasurePluginLine.html +0 -24
  41. package/docs/classes/PanoMeasurePluginModel.html +0 -23
  42. package/docs/classes/PanoMeasurePluginPoint.html +0 -7
  43. package/docs/classes/PanoMeasurePluginPolyline.html +0 -27
  44. package/docs/classes/PanoTagPluginController.html +0 -119
  45. package/docs/classes/Sculpt.html +0 -77
  46. package/docs/classes/Util.BetterTween.html +0 -6
  47. package/docs/classes/Util.FiveDomEvents.html +0 -13
  48. package/docs/classes/Util.FivePuppet.html +0 -20
  49. package/docs/classes/Util.Interval.html +0 -11
  50. package/docs/classes/Util.LegacyPointHelper.html +0 -7
  51. package/docs/classes/Util.LightTag.html +0 -47
  52. package/docs/classes/Util.LineSegments.html +0 -4
  53. package/docs/classes/Util.Magnifier.html +0 -26
  54. package/docs/classes/Util.Object3D.html +0 -8
  55. package/docs/classes/Util.PointDomHelper.html +0 -8
  56. package/docs/classes/Util.PointHelper.html +0 -10
  57. package/docs/classes/Util.PointSelector.html +0 -66
  58. package/docs/classes/Util.PointSelectorHelper.html +0 -14
  59. package/docs/classes/Util.Rectangle.html +0 -12
  60. package/docs/classes/Util.sculpt.BaseEditor.html +0 -17
  61. package/docs/classes/Util.sculpt.BoxMesh.html +0 -48
  62. package/docs/classes/Util.sculpt.BoxMeshEditor.html +0 -18
  63. package/docs/classes/Util.sculpt.CircleMesh.html +0 -26
  64. package/docs/classes/Util.sculpt.CircleMeshEditor.html +0 -18
  65. package/docs/classes/Util.sculpt.CircleWithEdgeMesh.html +0 -26
  66. package/docs/classes/Util.sculpt.CylinderMesh.html +0 -25
  67. package/docs/classes/Util.sculpt.CylinderMeshEditor.html +0 -18
  68. package/docs/classes/Util.sculpt.LineMesh.html +0 -34
  69. package/docs/classes/Util.sculpt.PointMesh.html +0 -24
  70. package/docs/classes/Util.sculpt.PolygonMesh.html +0 -40
  71. package/docs/classes/Util.sculpt.PrismMesh.html +0 -48
  72. package/docs/classes/Util.sculpt.PrismMeshEditor.html +0 -18
  73. package/docs/classes/Util.sculpt.RectangleMesh.html +0 -41
  74. package/docs/classes/Util.sculpt.RectangleMeshEditor.html +0 -18
  75. package/docs/classes/Util.sculpt.RectangleWithEdgeMesh.html +0 -44
  76. package/docs/classes/WalkController.html +0 -42
  77. package/docs/enums/CameraMovementEffect.html +0 -4
  78. package/docs/enums/ContentType.html +0 -34
  79. package/docs/enums/DIRECTION.html +0 -5
  80. package/docs/enums/DISPLAY_STRATEGY_TYPE.html +0 -5
  81. package/docs/enums/DimensionType.html +0 -4
  82. package/docs/enums/FLOOR_PLAN_ATTACHED_TO.html +0 -4
  83. package/docs/enums/ITEM_LABEL_PLUGIN_DISPLAY_STRATEGY_TYPE.html +0 -5
  84. package/docs/enums/PaintBrushTypeEnum.html +0 -4
  85. package/docs/enums/PointType.html +0 -4
  86. package/docs/enums/Rotation.html +0 -5
  87. package/docs/functions/AreaMakerPlugin.html +0 -1
  88. package/docs/functions/CSS3DRenderPlugin.html +0 -1
  89. package/docs/functions/CameraMovementPlugin.html +0 -2
  90. package/docs/functions/CruisePlugin.html +0 -1
  91. package/docs/functions/CurrentPanoImagePlugin.html +0 -1
  92. package/docs/functions/FloorplanGuidePlugin.html +0 -1
  93. package/docs/functions/GuideLinePlugin.html +0 -1
  94. package/docs/functions/ItemLabelPlugin.html +0 -1
  95. package/docs/functions/MapviewFloorplanPlugin.html +0 -1
  96. package/docs/functions/MeasurePlugin.html +0 -1
  97. package/docs/functions/ModelChassisCompassPlugin.html +0 -2
  98. package/docs/functions/ModelEntryDoorGuidePlugin.html +0 -2
  99. package/docs/functions/ModelFloorplanPlugin.html +0 -1
  100. package/docs/functions/ModelItemLabelPlugin.html +0 -1
  101. package/docs/functions/ModelMakerPlugin.html +0 -1
  102. package/docs/functions/ModelRoomLabelPlugin.html +0 -1
  103. package/docs/functions/ModelTVVideoPlugin.html +0 -1
  104. package/docs/functions/ModelViewPlugin.html +0 -2
  105. package/docs/functions/MovePlugin.html +0 -1
  106. package/docs/functions/Object3DHelperPlugin.html +0 -1
  107. package/docs/functions/PanoCompassPlugin.html +0 -1
  108. package/docs/functions/PanoCursorRaycasterPlugin.html +0 -2
  109. package/docs/functions/PanoDoorLabelPlugin.html +0 -1
  110. package/docs/functions/PanoFloorplanRadarPlugin.html +0 -1
  111. package/docs/functions/PanoMeasurePlugin.html +0 -1
  112. package/docs/functions/PanoRulerPlugin.html +0 -2
  113. package/docs/functions/PanoRulerProPlugin.html +0 -2
  114. package/docs/functions/PanoSpatialTagPlugin.html +0 -2
  115. package/docs/functions/PanoTagPlugin.html +0 -1
  116. package/docs/functions/PanoVideoPlugin.html +0 -10
  117. package/docs/functions/PipelinePlugin.html +0 -1
  118. package/docs/functions/SculptPlugin.html +0 -2
  119. package/docs/functions/SculptPluginForFive.html +0 -2
  120. package/docs/functions/TopviewFloorplanPlugin.html +0 -1
  121. package/docs/functions/Util.awaitNextFrame.html +0 -1
  122. package/docs/functions/Util.blink.html +0 -13
  123. package/docs/functions/Util.blinkWithPreset.html +0 -6
  124. package/docs/functions/Util.bounding.html +0 -1
  125. package/docs/functions/Util.boundingBox.html +0 -1
  126. package/docs/functions/Util.boundingSphere.html +0 -1
  127. package/docs/functions/Util.boxVertex.html +0 -7
  128. package/docs/functions/Util.boxVertexes.html +0 -1
  129. package/docs/functions/Util.checkFiveModelLoaded.html +0 -2
  130. package/docs/functions/Util.cleanup.html +0 -3
  131. package/docs/functions/Util.convexHull.html +0 -2
  132. package/docs/functions/Util.equal.html +0 -5
  133. package/docs/functions/Util.fiveModelIsLoaded.html +0 -2
  134. package/docs/functions/Util.generatePolygonGeometry.html +0 -2
  135. package/docs/functions/Util.getCoordsFromClient.html +0 -1
  136. package/docs/functions/Util.getCoordsFromElement.html +0 -1
  137. package/docs/functions/Util.getFrameTime.html +0 -3
  138. package/docs/functions/Util.getGeometryArea.html +0 -1
  139. package/docs/functions/Util.getGeometryInfo.html +0 -1
  140. package/docs/functions/Util.getIntersectFromRelativePosition.html +0 -1
  141. package/docs/functions/Util.getRaycasterFromFivePointer.html +0 -1
  142. package/docs/functions/Util.initialCSS3DRender.html +0 -1
  143. package/docs/functions/Util.inside.html +0 -1
  144. package/docs/functions/Util.isModelLike.html +0 -1
  145. package/docs/functions/Util.isNil.html +0 -2
  146. package/docs/functions/Util.isPanoramaLike.html +0 -1
  147. package/docs/functions/Util.lookObject.html +0 -7
  148. package/docs/functions/Util.lookPoint.html +0 -5
  149. package/docs/functions/Util.nextFrame.html +0 -1
  150. package/docs/functions/Util.notNil.html +0 -2
  151. package/docs/functions/Util.reblink.html +0 -13
  152. package/docs/functions/Util.replaceStaticPrefix.html +0 -8
  153. package/docs/functions/Util.requestAnimationFrameInterval.html +0 -5
  154. package/docs/functions/Util.sculpt.createBox.html +0 -1
  155. package/docs/functions/Util.sculpt.createCircle.html +0 -1
  156. package/docs/functions/Util.sculpt.createCylinder.html +0 -1
  157. package/docs/functions/Util.sculpt.createLine.html +0 -2
  158. package/docs/functions/Util.sculpt.createPoint.html +0 -1
  159. package/docs/functions/Util.sculpt.createPolygon.html +0 -1
  160. package/docs/functions/Util.sculpt.createPrism.html +0 -1
  161. package/docs/functions/Util.sculpt.createRectangle.html +0 -2
  162. package/docs/functions/Util.sculpt.transformUnit.html +0 -1
  163. package/docs/functions/Util.sculpt.transformUnitSquare.html +0 -1
  164. package/docs/functions/Util.tag.html +0 -1
  165. package/docs/functions/Util.triangleArea.html +0 -2
  166. package/docs/functions/Util.triangleCenter.html +0 -2
  167. package/docs/functions/Util.tweenProgress.html +0 -1
  168. package/docs/functions/Util.uuid.html +0 -2
  169. package/docs/functions/Util.waitFiveModelLoaded.html +0 -2
  170. package/docs/functions/Util.worldBounding.html +0 -1
  171. package/docs/functions/Util.worldBoundingBox.html +0 -1
  172. package/docs/functions/Util.worldBoundingSphere.html +0 -1
  173. package/docs/functions/createPolyline.html +0 -2
  174. package/docs/functions/pluginFlag.html +0 -1
  175. package/docs/functions/validatePolygon.html +0 -1
  176. package/docs/hierarchy.html +0 -1
  177. package/docs/index.html +0 -70
  178. package/docs/interfaces/AreaMakerPluginType.AnimeOptions.html +0 -4
  179. package/docs/interfaces/AreaMakerPluginType.Config.html +0 -8
  180. package/docs/interfaces/AreaMakerPluginType.EventMap.html +0 -25
  181. package/docs/interfaces/AreaMakerPluginType.Params.html +0 -4
  182. package/docs/interfaces/AreaMakerPluginType.ServerAreaMakerItem.html +0 -20
  183. package/docs/interfaces/AreaMakerPluginType.ServerAreaMakerItemV1.html +0 -13
  184. package/docs/interfaces/AreaMakerPluginType.ServerDataV1.html +0 -9
  185. package/docs/interfaces/AreaMakerPluginType.ServerDataV2.html +0 -3
  186. package/docs/interfaces/AreaMakerPluginType.ShowHideOptions.html +0 -3
  187. package/docs/interfaces/AreaMakerPluginType.State.html +0 -8
  188. package/docs/interfaces/BoxAnimationConfig.html +0 -6
  189. package/docs/interfaces/BoxPosition.html +0 -8
  190. package/docs/interfaces/CSS3DRenderPluginEventMap.html +0 -9
  191. package/docs/interfaces/CSS3DRenderPluginState.html +0 -7
  192. package/docs/interfaces/CameraMovementPluginExportType.html +0 -11
  193. package/docs/interfaces/ContentTypeMapInterface.html +0 -73
  194. package/docs/interfaces/CruisePluginTypes.Config.html +0 -7
  195. package/docs/interfaces/CruisePluginTypes.CruiseKeyframe.html +0 -8
  196. package/docs/interfaces/CruisePluginTypes.EventMap.html +0 -33
  197. package/docs/interfaces/CruisePluginTypes.GuildLineConfig.html +0 -6
  198. package/docs/interfaces/CruisePluginTypes.MoveAction.html +0 -16
  199. package/docs/interfaces/CruisePluginTypes.MoveWithKeyframesAction.html +0 -19
  200. package/docs/interfaces/CruisePluginTypes.MoveWithPanoIndexAction.html +0 -20
  201. package/docs/interfaces/CruisePluginTypes.PluginData.html +0 -8
  202. package/docs/interfaces/CruisePluginTypes.PluginServerData.html +0 -2
  203. package/docs/interfaces/CruisePluginTypes.PluginState.html +0 -15
  204. package/docs/interfaces/CurrentPanoImagePluginType.Config.html +0 -13
  205. package/docs/interfaces/CurrentPanoImagePluginType.EventMap.html +0 -15
  206. package/docs/interfaces/CurrentPanoImagePluginType.Params.html +0 -4
  207. package/docs/interfaces/CurrentPanoImagePluginType.ShowHideOptions.html +0 -3
  208. package/docs/interfaces/CurrentPanoImagePluginType.State.html +0 -7
  209. package/docs/interfaces/FloorplanBounding.html +0 -9
  210. package/docs/interfaces/FloorplanData.html +0 -7
  211. package/docs/interfaces/FloorplanEntrance.html +0 -14
  212. package/docs/interfaces/FloorplanExtraObject.html +0 -9
  213. package/docs/interfaces/FloorplanExtraObject3D.html +0 -5
  214. package/docs/interfaces/FloorplanFloorData.html +0 -9
  215. package/docs/interfaces/FloorplanImagePosition.html +0 -4
  216. package/docs/interfaces/FloorplanObserver.html +0 -8
  217. package/docs/interfaces/FloorplanOutlineItem.html +0 -6
  218. package/docs/interfaces/FloorplanPosition.html +0 -4
  219. package/docs/interfaces/FloorplanRoomItem.html +0 -24
  220. package/docs/interfaces/FloorplanRoomLabelItem.html +0 -6
  221. package/docs/interfaces/FloorplanServerBounding.html +0 -9
  222. package/docs/interfaces/FloorplanServerComputedData.html +0 -6
  223. package/docs/interfaces/FloorplanServerData.html +0 -4
  224. package/docs/interfaces/FloorplanServerDoorItem.html +0 -6
  225. package/docs/interfaces/FloorplanServerDoorPosition.html +0 -4
  226. package/docs/interfaces/FloorplanServerEntrance.html +0 -14
  227. package/docs/interfaces/FloorplanServerFloorData.html +0 -8
  228. package/docs/interfaces/FloorplanServerImagePosition.html +0 -4
  229. package/docs/interfaces/FloorplanServerObserver.html +0 -8
  230. package/docs/interfaces/FloorplanServerOutlineItem.html +0 -6
  231. package/docs/interfaces/FloorplanServerPosition.html +0 -4
  232. package/docs/interfaces/FloorplanServerRoomItem.html +0 -27
  233. package/docs/interfaces/FloorplanServerRoomLabelItem.html +0 -6
  234. package/docs/interfaces/GuideLineModeItem.GuideLineTagContainer.html +0 -4
  235. package/docs/interfaces/GuideLinePluginType.CatmullRomCurve3.html +0 -7
  236. package/docs/interfaces/GuideLinePluginType.EventMap.html +0 -13
  237. package/docs/interfaces/GuideLinePluginType.ExtraRouteData.html +0 -5
  238. package/docs/interfaces/GuideLinePluginType.GuideLineGeometryStyle.html +0 -8
  239. package/docs/interfaces/GuideLinePluginType.GuideLineItemContainer.html +0 -2
  240. package/docs/interfaces/GuideLinePluginType.GuideLineMaterialStyle.html +0 -32
  241. package/docs/interfaces/GuideLinePluginType.GuideLineMeshStyle.html +0 -4
  242. package/docs/interfaces/GuideLinePluginType.LineGeometriesConfig.html +0 -5
  243. package/docs/interfaces/GuideLinePluginType.ModelGuideLineStyle.html +0 -42
  244. package/docs/interfaces/GuideLinePluginType.ModelGuideLineTagData.html +0 -3
  245. package/docs/interfaces/GuideLinePluginType.PanoramaGuideLineStyle.html +0 -57
  246. package/docs/interfaces/GuideLinePluginType.PluginDataV2.html +0 -1
  247. package/docs/interfaces/GuideLinePluginType.PluginServerData.html +0 -2
  248. package/docs/interfaces/GuideLinePluginType.PluginState.html +0 -7
  249. package/docs/interfaces/GuideLinePluginType.Route.html +0 -13
  250. package/docs/interfaces/HelperOffset.html +0 -4
  251. package/docs/interfaces/ImagePlaneGroup.html +0 -3
  252. package/docs/interfaces/ItemLabelPluginData.html +0 -2
  253. package/docs/interfaces/ItemLabelPluginExportReturnsType.html +0 -7
  254. package/docs/interfaces/ItemLabelPluginParametersType.html +0 -5
  255. package/docs/interfaces/MinMax.html +0 -3
  256. package/docs/interfaces/ModelChassisCompassPluginData.html +0 -3
  257. package/docs/interfaces/ModelChassisCompassPluginExportType.html +0 -4
  258. package/docs/interfaces/ModelChassisCompassPluginParameterType.html +0 -3
  259. package/docs/interfaces/ModelEntryDoorGuidePluginData.html +0 -4
  260. package/docs/interfaces/ModelEntryDoorGuidePluginExportType.html +0 -4
  261. package/docs/interfaces/ModelItemLabelPluginData.html +0 -2
  262. package/docs/interfaces/ModelItemLabelPluginExportReturnsType.html +0 -7
  263. package/docs/interfaces/ModelItemLabelPluginParametersType.html +0 -3
  264. package/docs/interfaces/ModelMakerPluginType.BoxItemObjectData.html +0 -17
  265. package/docs/interfaces/ModelMakerPluginType.EventMap.html +0 -18
  266. package/docs/interfaces/ModelMakerPluginType.PrismItemObjectData.html +0 -23
  267. package/docs/interfaces/ModelMakerPluginType.ServerBaseItem.html +0 -11
  268. package/docs/interfaces/ModelMakerPluginType.ServerBoxItem.html +0 -10
  269. package/docs/interfaces/ModelMakerPluginType.ServerData.html +0 -3
  270. package/docs/interfaces/ModelMakerPluginType.ServerPrismItem.html +0 -10
  271. package/docs/interfaces/ModelMakerPluginType.ServerTrianglesItem.html +0 -10
  272. package/docs/interfaces/ModelMakerPluginType.State.html +0 -8
  273. package/docs/interfaces/ModelMakerPluginType.TrianglesItemObjectData.html +0 -11
  274. package/docs/interfaces/ModelRoomLabelPluginData.html +0 -2
  275. package/docs/interfaces/ModelTVVideoPluginData.html +0 -5
  276. package/docs/interfaces/ModelTVVideoPluginExportType.html +0 -4
  277. package/docs/interfaces/ModelTVVideoPluginParameterType.html +0 -2
  278. package/docs/interfaces/ModelViewPluginExportType.html +0 -8
  279. package/docs/interfaces/Object3DHelperState.html +0 -4
  280. package/docs/interfaces/ObjectHelperControllers.html +0 -5
  281. package/docs/interfaces/PaintBrushAction.html +0 -14
  282. package/docs/interfaces/PaintBrushConfigs.html +0 -8
  283. package/docs/interfaces/PaintBrushState.html +0 -6
  284. package/docs/interfaces/PanoCursorRaycasterPluginExportType.html +0 -16
  285. package/docs/interfaces/PanoCursorRaycasterPluginParameterType.html +0 -1
  286. package/docs/interfaces/PanoMeasureParameterType.html +0 -20
  287. package/docs/interfaces/PanoMeasurePluginLineJson.html +0 -4
  288. package/docs/interfaces/PanoMeasurePluginOpenParameter.html +0 -4
  289. package/docs/interfaces/PanoMeasurePluginPointJson.html +0 -3
  290. package/docs/interfaces/PanoMeasurePluginPolylineJson.html +0 -7
  291. package/docs/interfaces/PanoRulerPluginExportType.html +0 -6
  292. package/docs/interfaces/PanoRulerPluginOptions.html +0 -3
  293. package/docs/interfaces/PanoRulerPluginParameterType.html +0 -4
  294. package/docs/interfaces/PanoRulerProPluginExportType.html +0 -5
  295. package/docs/interfaces/PanoRulerProPluginOptions.html +0 -3
  296. package/docs/interfaces/PanoRulerProPluginParameterType.html +0 -3
  297. package/docs/interfaces/PanoRulerProPluginState.html +0 -4
  298. package/docs/interfaces/PanoSpatialTagPluginContentEvent.html +0 -1
  299. package/docs/interfaces/PanoSpatialTagPluginContentReplacement.html +0 -1
  300. package/docs/interfaces/PanoSpatialTagPluginData.html +0 -7
  301. package/docs/interfaces/PanoSpatialTagPluginDataElement.html +0 -6
  302. package/docs/interfaces/PanoSpatialTagPluginExportType.html +0 -9
  303. package/docs/interfaces/PanoSpatialTagPluginOriginElement.html +0 -6
  304. package/docs/interfaces/PanoSpatialTagPluginParameterType.html +0 -9
  305. package/docs/interfaces/PanoSpatialTagPluginPointElement.html +0 -7
  306. package/docs/interfaces/PanoSpatialTagPluginTagElement.html +0 -6
  307. package/docs/interfaces/PanoVideoPluginType.LoadParams.html +0 -3
  308. package/docs/interfaces/PanoVideoPluginType.PanoVideoItem.html +0 -8
  309. package/docs/interfaces/PanoVideoPluginType.PluginData.html +0 -2
  310. package/docs/interfaces/PanoVideoPluginType.PluginEventMap.html +0 -15
  311. package/docs/interfaces/PanoVideoPluginType.PluginState.html +0 -2
  312. package/docs/interfaces/PanoVideoPluginType.VideoItem.html +0 -14
  313. package/docs/interfaces/PanoVideoPluginType.VideoMeshParams.html +0 -13
  314. package/docs/interfaces/PluginEventMap.html +0 -16
  315. package/docs/interfaces/Point.html +0 -4
  316. package/docs/interfaces/Room.html +0 -5
  317. package/docs/interfaces/RoomInfo.html +0 -3
  318. package/docs/interfaces/RoomLabel.html +0 -16
  319. package/docs/interfaces/RoomRules.html +0 -1
  320. package/docs/interfaces/Rooms.html +0 -1
  321. package/docs/interfaces/Scissor.html +0 -13
  322. package/docs/interfaces/SculptConfig.html +0 -19
  323. package/docs/interfaces/State.html +0 -7
  324. package/docs/interfaces/TagCacheInterface.html +0 -9
  325. package/docs/interfaces/TagConfig.html +0 -174
  326. package/docs/interfaces/TagGLTFObjectGroup.html +0 -3
  327. package/docs/interfaces/TagIconAnimationConfig.html +0 -7
  328. package/docs/interfaces/TagIconUrl.html +0 -22
  329. package/docs/interfaces/TagObjectGroup.html +0 -3
  330. package/docs/interfaces/TagState.html +0 -3
  331. package/docs/interfaces/TagStyle.html +0 -17
  332. package/docs/interfaces/Tags.html +0 -8
  333. package/docs/interfaces/TemporaryState.html +0 -2
  334. package/docs/interfaces/Util.AnimeInstance.html +0 -14
  335. package/docs/interfaces/Util.BlinkAnimeOptions.html +0 -21
  336. package/docs/interfaces/Util.EventHandlerConfig.html +0 -21
  337. package/docs/interfaces/Util.FiveDomEvent.html +0 -7
  338. package/docs/interfaces/Util.FiveDomEventMap.html +0 -20
  339. package/docs/interfaces/Util.LegacyMouseGroupParameter.html +0 -4
  340. package/docs/interfaces/Util.MagnifierParameter.html +0 -13
  341. package/docs/interfaces/Util.MouseGroupParameter.html +0 -4
  342. package/docs/interfaces/Util.ObjectInitialState.html +0 -9
  343. package/docs/interfaces/Util.PointIntersection.html +0 -21
  344. package/docs/interfaces/Util.PointSelectorHelperConfig.html +0 -6
  345. package/docs/interfaces/Util.ReBlinkAnimeOptions.html +0 -27
  346. package/docs/modules/AreaMakerPluginType.html +0 -17
  347. package/docs/modules/CruisePluginTypes.html +0 -14
  348. package/docs/modules/CurrentPanoImagePluginType.html +0 -6
  349. package/docs/modules/GuideLineItem.html +0 -2
  350. package/docs/modules/GuideLineModeItem.html +0 -3
  351. package/docs/modules/GuideLinePluginType.html +0 -25
  352. package/docs/modules/ModelMakerPluginType.html +0 -19
  353. package/docs/modules/PanoVideoPluginType.html +0 -8
  354. package/docs/modules/SculptData.html +0 -9
  355. package/docs/modules/SculptType.html +0 -2
  356. package/docs/modules/Util.html +0 -91
  357. package/docs/modules/Util.sculpt.html +0 -27
  358. package/docs/modules.html +0 -287
  359. package/docs/types/AddObject3DHelperConfig.html +0 -19
  360. package/docs/types/AreaMakerPluginType.AreaMakerItemEventMap.html +0 -7
  361. package/docs/types/AreaMakerPluginType.ItemRenderer.html +0 -1
  362. package/docs/types/AreaMakerPluginType.PluginData.html +0 -2
  363. package/docs/types/AreaMakerPluginType.ServerData.html +0 -2
  364. package/docs/types/ArrayPosition.html +0 -1
  365. package/docs/types/AudioAppearance.html +0 -1
  366. package/docs/types/BoxTag.html +0 -2
  367. package/docs/types/CSS3DRenderExportType.html +0 -1
  368. package/docs/types/CSS3DRenderPluginExportType.html +0 -1
  369. package/docs/types/CSS3DRenderPluginParameterType.html +0 -1
  370. package/docs/types/ClassFunctionParameters.html +0 -1
  371. package/docs/types/Color.html +0 -1
  372. package/docs/types/ContentTypeConfigKey.html +0 -1
  373. package/docs/types/ContentTypeConfigKeySplit.html +0 -1
  374. package/docs/types/ContentTypeMap.html +0 -1
  375. package/docs/types/Create3DDomContainerReturnType.html +0 -1
  376. package/docs/types/Create3DElementReturnType.html +0 -1
  377. package/docs/types/CruisePluginExportType.html +0 -1
  378. package/docs/types/CruisePluginTypes.CruiseData.html +0 -6
  379. package/docs/types/CruisePluginTypes.MoveEffect.html +0 -1
  380. package/docs/types/CurrentPanoImagePluginExportType.html +0 -1
  381. package/docs/types/DeprecatedMediaPlaneProperty.html +0 -3
  382. package/docs/types/DeprecatedTagProperty.html +0 -3
  383. package/docs/types/Direction-1.html +0 -1
  384. package/docs/types/Direction4.html +0 -1
  385. package/docs/types/ElementRenderer.html +0 -2
  386. package/docs/types/FloorplanGuidePluginParameterType.html +0 -1
  387. package/docs/types/FloorplanGuidePluginReturnType.html +0 -1
  388. package/docs/types/FloorplanRuleLabels.html +0 -2
  389. package/docs/types/FloorplanServerRuleLabels.html +0 -1
  390. package/docs/types/GuideLinePluginExportType.html +0 -1
  391. package/docs/types/GuideLinePluginType.GuideLineItem.html +0 -2
  392. package/docs/types/GuideLinePluginType.GuideLineItemEventMap.html +0 -1
  393. package/docs/types/GuideLinePluginType.GuideLineModeItemMode.html +0 -1
  394. package/docs/types/GuideLinePluginType.GuideLineStyle.html +0 -2
  395. package/docs/types/GuideLinePluginType.ModelGuideLineTag.html +0 -2
  396. package/docs/types/GuideLinePluginType.PathItem.html +0 -2
  397. package/docs/types/GuideLinePluginType.PluginData.html +0 -2
  398. package/docs/types/GuideLinePluginType.RouteConfig.html +0 -4
  399. package/docs/types/HelperEventMap.html +0 -1
  400. package/docs/types/InternalHelperEventMap.html +0 -1
  401. package/docs/types/MapviewFloorplanPluginParameterType.html +0 -1
  402. package/docs/types/MapviewFloorplanPluginReturnType.html +0 -1
  403. package/docs/types/MaskPosition.html +0 -3
  404. package/docs/types/MaskTag.html +0 -2
  405. package/docs/types/MeasureEndReason.html +0 -1
  406. package/docs/types/MeasurePluginConfig.html +0 -5
  407. package/docs/types/MeasurePluginEventMap.html +0 -1
  408. package/docs/types/MediaData.html +0 -2
  409. package/docs/types/MediaStore.html +0 -1
  410. package/docs/types/ModelEntryDoorGuidePluginParameterType.html +0 -1
  411. package/docs/types/ModelFloorplanPluginParameterType.html +0 -1
  412. package/docs/types/ModelFloorplanPluginReturnType.html +0 -1
  413. package/docs/types/ModelId.html +0 -1
  414. package/docs/types/ModelMakerPluginType.ElementRenderer.html +0 -1
  415. package/docs/types/ModelMakerPluginType.ItemType.html +0 -2
  416. package/docs/types/ModelMakerPluginType.MarkerItem.html +0 -1
  417. package/docs/types/ModelMakerPluginType.ServerItem.html +0 -2
  418. package/docs/types/ModelRoomLabelPluginParameters.html +0 -1
  419. package/docs/types/ModelRoomLabelPluginReturnType.html +0 -1
  420. package/docs/types/MoveArgs.html +0 -2
  421. package/docs/types/MoveOpts.html +0 -2
  422. package/docs/types/Object3DHelperEventMap.html +0 -1
  423. package/docs/types/ObjectFit.html +0 -1
  424. package/docs/types/PaintBrushEventMap.html +0 -1
  425. package/docs/types/PanoCompassPluginData.html +0 -1
  426. package/docs/types/PanoCompassPluginExportType.html +0 -1
  427. package/docs/types/PanoCompassPluginParameterType.html +0 -1
  428. package/docs/types/PanoFloorplanRadarPluginParameterType.html +0 -1
  429. package/docs/types/PanoFloorplanRadarPluginReturnType.html +0 -1
  430. package/docs/types/PanoIndex.html +0 -1
  431. package/docs/types/PanoMeasurePluginEvent.html +0 -1
  432. package/docs/types/PanoMeasureReturnType.html +0 -1
  433. package/docs/types/PanoSpatialTagPluginId.html +0 -1
  434. package/docs/types/PanoTagPluginExportInterface.html +0 -1
  435. package/docs/types/PanoTagPluginParamsInterface.html +0 -1
  436. package/docs/types/PanoVideoPluginParameterType.html +0 -1
  437. package/docs/types/PanoVideoPluginReturnType.html +0 -1
  438. package/docs/types/PickTagContentTypeInContentTypeConfigKey.html +0 -2
  439. package/docs/types/PipelinePluginParameterType.html +0 -1
  440. package/docs/types/PipelinePluginReturnType.html +0 -1
  441. package/docs/types/PlaneTag.html +0 -2
  442. package/docs/types/Point2DTag.html +0 -2
  443. package/docs/types/Point3DTag.html +0 -2
  444. package/docs/types/PointTagInstance.html +0 -1
  445. package/docs/types/PolygonPosition.html +0 -3
  446. package/docs/types/PolygonTag.html +0 -2
  447. package/docs/types/Position.html +0 -1
  448. package/docs/types/PositionFrom.html +0 -1
  449. package/docs/types/RotateArgs.html +0 -2
  450. package/docs/types/RotateOpts.html +0 -2
  451. package/docs/types/RuleLabelsKey.html +0 -1
  452. package/docs/types/RuleLabelsValue.html +0 -1
  453. package/docs/types/ScaleCallback.html +0 -1
  454. package/docs/types/ScalePosition.html +0 -3
  455. package/docs/types/SculptData.BoxData.html +0 -1
  456. package/docs/types/SculptData.CircleData.html +0 -1
  457. package/docs/types/SculptData.CylinderData.html +0 -1
  458. package/docs/types/SculptData.PointData.html +0 -1
  459. package/docs/types/SculptData.PolygonData.html +0 -1
  460. package/docs/types/SculptData.PolylineData.html +0 -1
  461. package/docs/types/SculptData.PrismData.html +0 -1
  462. package/docs/types/SculptData.RectangleData.html +0 -1
  463. package/docs/types/SculptType.Theme.html +0 -10
  464. package/docs/types/StickType.html +0 -1
  465. package/docs/types/Tag.html +0 -17
  466. package/docs/types/Tag2D.html +0 -2
  467. package/docs/types/Tag3D.html +0 -2
  468. package/docs/types/TagClickParams.html +0 -1
  469. package/docs/types/TagConfigByKey.html +0 -1
  470. package/docs/types/TagContentType.html +0 -1
  471. package/docs/types/TagContentTypeMapping.html +0 -1
  472. package/docs/types/TagDimensionType.html +0 -1
  473. package/docs/types/TagElement.html +0 -2
  474. package/docs/types/TagEvents.html +0 -1
  475. package/docs/types/TagGLTFObject.html +0 -1
  476. package/docs/types/TagHooks.html +0 -1
  477. package/docs/types/TagId.html +0 -1
  478. package/docs/types/TagInstance.html +0 -1
  479. package/docs/types/TagPlacement.html +0 -5
  480. package/docs/types/TagPointType.html +0 -2
  481. package/docs/types/TagRendererMap.html +0 -1
  482. package/docs/types/TopviewFloorplanPluginParameterType.html +0 -1
  483. package/docs/types/TopviewFloorplanPluginReturnType.html +0 -1
  484. package/docs/types/Util.ActionIfNoIntersection.html +0 -1
  485. package/docs/types/Util.AdherePoint.html +0 -2
  486. package/docs/types/Util.PointSelectorConfig.html +0 -1
  487. package/docs/types/Util.SupportedTarget.html +0 -2
  488. package/docs/types/Util.Target.html +0 -2
  489. package/docs/types/Util.ThreeObject.html +0 -2
  490. package/docs/types/WorkCode.html +0 -1
  491. package/docs/variables/FLOOR_TYPE_MAP.html +0 -2
  492. package/docs/variables/PLUGIN.html +0 -1
  493. package/docs/variables/ROOM_FETILE_TYPE_MAP.html +0 -2
  494. package/docs/variables/ROOM_TYPE_MAP.html +0 -2
  495. package/docs/variables/Util.ANIME_PRESETS.html +0 -2
  496. package/docs/variables/Util.CURRENT_PANO_IMAGE_DEFAULT_IMAGE.html +0 -2
  497. package/docs/variables/Util.DEFAULT_ANIME_CONFIG.html +0 -2
  498. package/docs/variables/Util.DEFAULT_STATIC_PREFIX.html +0 -2
  499. package/docs/variables/Util.DNALOGEL_DEFAULT_ASSETS.html +0 -2
  500. package/docs/variables/Util.ENTRY_DOOR_DEFAULT_IMAGE.html +0 -2
  501. package/docs/variables/Util.FLOORPLAN_DEFAULT_IMAGE.html +0 -2
  502. package/docs/variables/Util.GUIDELINE_DEFAULT_ARROW_TEXTURE.html +0 -2
  503. package/docs/variables/Util.GUIDELINE_WHITE_ARROW_TEXTURE.html +0 -2
  504. package/docs/variables/Util.MODEL_CHASSIS_COMPASS_DEFAULT_MODEL.html +0 -2
  505. package/docs/variables/Util.MODEL_ENTRY_DOOR_GUIDE_PLUGIN_DEFAULT_MODEL.html +0 -2
  506. package/docs/variables/Util.PANO_COMPASS_DEFAULT_IMAGE.html +0 -2
  507. package/docs/variables/Util.PANO_SPATIAL_TAG_BLUR_IMAGE.html +0 -2
  508. package/docs/variables/Util.PANO_TAG_DEFAULT_LINK_ICON.html +0 -2
  509. package/docs/variables/defaultGlobalConfig.html +0 -1
  510. package/docs/variables/itemLabelPluginServerParams.html +0 -1
  511. package/docs/variables/modelItemLabelPluginServerParams.html +0 -1
  512. package/docs/variables/modelRoomLabelPluginServerParams.html +0 -1
@@ -1,34 +1,36 @@
1
- var S = Object.defineProperty;
2
- var E = Object.getOwnPropertySymbols;
3
- var I = Object.prototype.hasOwnProperty, F = Object.prototype.propertyIsEnumerable;
4
- var w = (o, r, e) => r in o ? S(o, r, { enumerable: !0, configurable: !0, writable: !0, value: e }) : o[r] = e, M = (o, r) => {
5
- for (var e in r || (r = {}))
6
- I.call(r, e) && w(o, e, r[e]);
7
- if (E)
8
- for (var e of E(r))
9
- F.call(r, e) && w(o, e, r[e]);
10
- return o;
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 c = (o, r, e) => (w(o, typeof r != "symbol" ? r + "" : r, e), e);
13
- var v = (o, r, e) => new Promise((t, s) => {
14
- var a = (l) => {
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
- i(e.next(l));
17
- } catch (u) {
18
- s(u);
16
+ r(e.next(l));
17
+ } catch (n) {
18
+ t(n);
19
19
  }
20
- }, n = (l) => {
20
+ }, i = (l) => {
21
21
  try {
22
- i(e.throw(l));
23
- } catch (u) {
24
- s(u);
22
+ r(e.throw(l));
23
+ } catch (n) {
24
+ t(n);
25
25
  }
26
- }, i = (l) => l.done ? t(l.value) : Promise.resolve(l.value).then(a, n);
27
- i((e = e.apply(o, r)).next());
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 P } from "./BaseTag.js";
30
- import * as m from "three";
31
- import { maskVertexShader as V, maskFragmentShader as R } from "./MaskTag.shaders.js";
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 C(o) {
118
- if (Array.isArray(o))
119
- return o;
120
- if (typeof o == "number")
121
- return [o >> 16 & 255, o >> 8 & 255, o & 255];
122
- if (typeof o == "string") {
123
- let r = o.trim().replace(/^#/, "");
124
- if (r.length === 3 && (r = r[0] + r[0] + r[1] + r[1] + r[2] + r[2]), r.length === 6) {
125
- const e = parseInt(r.substring(0, 2), 16), t = parseInt(r.substring(2, 4), 16), s = parseInt(r.substring(4, 6), 16);
126
- if (!isNaN(e) && !isNaN(t) && !isNaN(s))
127
- return [e, t, s];
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:", o);
129
+ console.warn("[MaskTag] Invalid hex color string:", m);
130
130
  }
131
131
  return [0, 0, 0];
132
132
  }
133
- const h = class extends P {
134
- constructor(e, t) {
135
- super(e, t);
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
- c(this, "maskUrl");
140
+ x(this, "maskUrl");
140
141
  /**
141
142
  * 目标颜色(RGB 格式)
142
143
  */
143
- c(this, "targetColor");
144
+ x(this, "targetColor");
144
145
  /**
145
146
  * mask 渲染的 mesh 对象(使用 Sphere)
146
147
  */
147
- c(this, "maskMesh");
148
+ x(this, "maskMesh");
148
149
  /**
149
150
  * mask 纹理对象
150
151
  */
151
- c(this, "maskTexture");
152
+ x(this, "maskTexture");
152
153
  /**
153
154
  * 是否正在加载 mask
154
155
  */
155
- c(this, "loadingMask", !1);
156
+ x(this, "loadingMask", !1);
156
157
  /**
157
158
  * 资源是否已释放
158
159
  */
159
- c(this, "_disposed", !1);
160
+ x(this, "_disposed", !1);
160
161
  /**
161
162
  * 标签样式配置
162
163
  */
163
- c(this, "tagStyle");
164
+ x(this, "tagStyle");
164
165
  /**
165
166
  * 点击事件清理函数
166
167
  */
167
- c(this, "clickEventDispose");
168
- const s = t.mask;
169
- s instanceof HTMLCanvasElement ? this.maskUrl = s : typeof s == "string" && s ? this.maskUrl = s : this.maskUrl = "";
170
- const a = t.color;
171
- this.targetColor = C(a), a || console.warn(`[MaskTag] No color provided for tag ${t.id}, using default [0, 0, 0]`), this.tagStyle = t.style, this.updateVisible(), this.currentVisible ? this.initializeMaskMesh() : console.log(`[MaskTag] Tag ${t.id} is not visible initially`);
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 m.Vector3(0, 1, 0);
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 this.maskMesh || null;
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, t = !0) {
191
- super.set(e, t), e.style && (this.tagStyle = M(M({}, this.tagStyle), e.style)), e.mask && (this.maskUrl = e.mask, this.reloadMask()), e.color !== void 0 && (this.targetColor = C(e.color), this.updateMaskStyle());
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 t;
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 s = M(M({}, this.five.getCurrentState()), e), { panoIndex: a } = s;
203
- return a !== ((t = this.fiveState) == null ? void 0 : t.panoIndex) ? !1 : super.getVisible(s);
204
- } catch (s) {
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 a, n, i;
214
- const t = M(M({}, this.five.getCurrentState()), e), { panoIndex: s } = t;
215
- return this.maskUrl ? s !== ((a = this.fiveState) == null ? void 0 : a.panoIndex) ? {
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 标签仅在当前点位可见。当前点位: ${s}, 标签点位: ${(n = this.fiveState) == null ? void 0 : n.panoIndex}`,
220
- currentPanoIndex: s,
221
- tagPanoIndex: (i = this.fiveState) == null ? void 0 : i.panoIndex
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"), t = this.can("unfold");
245
- e && t && (this.state.unfolded = !this.state.unfolded, this.manuallyOperated = !0, this.plugin.addRenderQueue({ type: "TagContainerSvelte", keys: ["tags"] }), this.state.unfolded && this.plugin.tags.forEach((s) => {
246
- s.id !== this.id && s.fold();
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 t = this.can("fold"), s = this.can("unfold");
268
- t && s && (this.state.unfolded = e, this.hooks.emit(e ? "unfolded" : "folded"), this.plugin.addRenderQueue({ type: "TagContainerSvelte", keys: ["tags"] }));
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 t = new m.Vector3(...this.position).clone().project(this.five.camera);
440
+ const s = new g.Vector3(...this.position).clone().project(this.five.camera);
279
441
  if (this.five.renderer) {
280
- const s = this.five.renderer.getSize(new m.Vector2());
442
+ const t = this.five.renderer.getSize(new g.Vector2());
281
443
  this.screenPosition = {
282
- leftPx: (t.x + 1) / 2 * s.x,
283
- topPx: (-t.y + 1) / 2 * s.y,
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 s;
468
+ var r;
309
469
  if (!this.maskMesh)
310
470
  return;
311
- const e = (s = this.fiveState) == null ? void 0 : s.panoIndex;
471
+ const e = (r = this.fiveState) == null ? void 0 : r.panoIndex;
312
472
  if (e === void 0)
313
473
  return;
314
- const t = this.workUtil.getObserver(e);
315
- t && (this.maskMesh.position.copy(t.position), this.maskMesh.quaternion.copy(t.quaternion), this.five.needsRender = !0);
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
- * 初始化 Mask Mesh(使用 Sphere)
482
+ * 步骤1:从材质中解析出 styleList
483
+ * @param {THREE.ShaderMaterial} material - 目标材质
484
+ * @returns {Array} 解析后的 styleList
319
485
  */
320
- initializeMaskMesh() {
321
- return v(this, null, function* () {
322
- if (this.maskMesh || this.loadingMask || !this.maskUrl)
323
- return;
324
- this.loadingMask = !0;
325
- const e = performance.now();
326
- try {
327
- this.maskTexture = yield h.loadMaskTexture(this.maskUrl), this.maskMesh = this.createSphereMesh(this.maskTexture), this.plugin.imagePlaneGroup.add(this.maskMesh), this.applyVisible(), this.five.needsRender = !0, this.setupClickEvents(), this.updateScreenPosition();
328
- const t = performance.now() - e;
329
- console.log(`[MaskTag Performance] Mesh initialized in ${t.toFixed(2)}ms for tag ${this.id}`);
330
- } catch (t) {
331
- console.error("[MaskTag] Failed to initialize mask mesh:", t);
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
- * 创建 Sphere mesh(参考 itemMask 实现)
500
+ * 步骤2:更新材质的样式纹理(追加新元素后)
501
+ * @param {THREE.ShaderMaterial} material - 目标材质
502
+ * @param {Array} newStyle - 要追加的新样式对象
339
503
  */
340
- createSphereMesh(e) {
341
- const t = this.getMaskStyle(), s = new m.Vector4(this.targetColor[0] / 255, this.targetColor[1] / 255, this.targetColor[2] / 255, 1), a = new m.ShaderMaterial({
342
- vertexShader: V,
343
- fragmentShader: R,
344
- uniforms: {
345
- map: { value: e },
346
- color: { value: s },
347
- tolerance: { value: t.tolerance / 255 },
348
- // 归一化容差
349
- highlightColor: {
350
- value: new m.Vector3(t.highlightColor[0] / 255, t.highlightColor[1] / 255, t.highlightColor[2] / 255)
351
- },
352
- opacity: { value: t.opacity }
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 s, a, n;
396
- const e = ((s = this.tagStyle) == null ? void 0 : s.mask) || {};
397
- let t = [86, 134, 253];
398
- return e.color !== void 0 ? t = C(e.color) : e.highlightColor !== void 0 && (t = C(e.highlightColor)), {
399
- tolerance: (a = e.tolerance) != null ? a : 1e-3,
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: t,
402
- opacity: (n = e.opacity) != null ? n : 0.6
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
- if (!this.maskMesh || this.config.clickable === !1)
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
- this.plugin.hooks.emit("click", { event: t, target: "TagMaskModel", tag: this });
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
- reloadMask() {
430
- return v(this, null, function* () {
431
- this.maskMesh && (this.maskMesh.parent && this.maskMesh.parent.remove(this.maskMesh), this.maskMesh.geometry.dispose(), this.maskMesh.material && (Array.isArray(this.maskMesh.material) ? this.maskMesh.material.forEach((e) => e.dispose()) : this.maskMesh.material.dispose()), this.maskMesh = void 0), this.maskTexture && this.maskUrl && (h.releaseMaskTexture(this.maskUrl), this.maskTexture = void 0), yield this.initializeMaskMesh();
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
- * 更新 mask 样式
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 = this.getMaskStyle(), t = this.maskMesh.material;
441
- t.uniforms && (t.uniforms.color.value.set(this.targetColor[0] / 255, this.targetColor[1] / 255, this.targetColor[2] / 255, 1), t.uniforms.tolerance.value = e.tolerance / 255, t.uniforms.highlightColor.value.set(
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 m.CanvasTexture && (this.maskTexture.needsUpdate = !0, this.five.needsRender = !0, console.log("[MaskTag] Canvas texture updated"));
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
- * 清理 MaskTag 特有的资源(内部方法,避免重复调用)
613
+ * 清理当前标签:从共享材质中删除本 tag 的样式槽,并更新材质;
614
+ * 若该点位已无其他 tag 则销毁 mesh 并释放纹理。
460
615
  */
461
616
  disposeMaskResources() {
462
- this._disposed || (this._disposed = !0, this.cleanupClickEvents(), this.maskMesh && (this.maskMesh.parent && this.maskMesh.parent.remove(this.maskMesh), this.maskMesh.geometry.dispose(), this.maskMesh.material && (Array.isArray(this.maskMesh.material) ? this.maskMesh.material.forEach((e) => e.dispose()) : this.maskMesh.material.dispose()), this.maskMesh = void 0), this.maskTexture && this.maskUrl && (h.releaseMaskTexture(this.maskUrl), this.maskTexture = void 0));
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
- this.maskMesh && (this.maskMesh.visible = !1), super.disable();
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 t = h.canvasSymbolMap.get(e);
492
- return t || (t = Symbol("canvas-mask"), h.canvasSymbolMap.set(e, t)), t;
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 v(this, null, function* () {
502
- const t = h.getMaskCacheKey(e), s = h.maskTextureCache.get(t);
503
- if (s)
504
- return s.refCount++, s.texture;
505
- const a = performance.now(), n = new AbortController();
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 i;
714
+ let r;
508
715
  if (typeof e == "string") {
509
- const g = new m.TextureLoader();
510
- i = yield new Promise((f, d) => {
511
- if (n.signal.aborted) {
512
- d(new Error("Load aborted"));
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
- g.load(
722
+ a.load(
516
723
  e,
517
724
  (p) => {
518
- n.signal.aborted ? (p.dispose(), d(new Error("Load aborted"))) : f(p);
725
+ i.signal.aborted ? (p.dispose(), u(new Error("Load aborted"))) : d(p);
519
726
  },
520
727
  void 0,
521
728
  (p) => {
522
- d(p);
729
+ u(p);
523
730
  }
524
- ), n.signal.addEventListener("abort", () => {
525
- d(new Error("Load aborted"));
731
+ ), i.signal.addEventListener("abort", () => {
732
+ u(new Error("Load aborted"));
526
733
  });
527
734
  });
528
735
  } else
529
- i = new m.CanvasTexture(e), i.needsUpdate = !0, console.log("[MaskTag] Created texture from canvas, size:", e.width, "x", e.height);
530
- i.wrapS = m.ClampToEdgeWrapping, i.wrapT = m.ClampToEdgeWrapping, i.minFilter = m.LinearFilter, i.magFilter = m.LinearFilter, i.anisotropy = 4, i instanceof m.CanvasTexture && (i.needsUpdate = !0), h.maskTextureCache.set(t, {
531
- texture: i,
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: n
740
+ abortController: i
534
741
  });
535
- const l = performance.now() - a, u = typeof e == "string" ? e.substring(0, 50) : "Canvas";
536
- if (console.log(`[MaskTag Performance] Texture loaded in ${l.toFixed(2)}ms, source: ${u}`), i.image) {
537
- const g = (i.image.width * i.image.height * 4 / 1048576).toFixed(2);
538
- console.log(`[MaskTag Memory] Texture size: ${i.image.width}x${i.image.height}, estimated memory: ${g}MB`);
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 i;
541
- } catch (i) {
542
- throw console.error("[MaskTag] Failed to load mask texture:", typeof e == "string" ? e : "Canvas", i), i;
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 a;
552
- const t = h.getMaskCacheKey(e), s = h.maskTextureCache.get(t);
553
- if (s && (s.refCount--, s.refCount <= 0)) {
554
- const n = typeof e == "string" ? e.substring(0, 50) : "Canvas";
555
- console.log(`[MaskTag Memory] Releasing texture (refCount=0): ${n}`), (a = s.abortController) == null || a.abort(), s.texture.dispose(), h.maskTextureCache.delete(t);
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, t = 0;
564
- const s = [];
565
- return h.maskTextureCache.forEach((a, n) => {
566
- e += a.refCount;
567
- let i = 0;
568
- if (a.texture.image) {
569
- const u = a.texture.image.width || 0, g = a.texture.image.height || 0;
570
- i = u * g * 4 / (1024 * 1024), t += i;
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 n == "string" ? n.substring(0, 80) : "[Canvas]";
573
- s.push({
779
+ const l = typeof i == "string" ? i.substring(0, 80) : "[Canvas]";
780
+ t.push({
574
781
  source: l,
575
- refCount: a.refCount,
576
- sizeMB: parseFloat(i.toFixed(2))
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(t.toFixed(2)),
582
- cacheEntries: s
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 t;
592
- (t = e.abortController) == null || t.abort(), e.texture.dispose();
798
+ var s;
799
+ (s = e.abortController) == null || s.abort(), e.texture.dispose();
593
800
  }), h.maskTextureCache.clear();
594
801
  }
595
802
  };
596
- let x = h;
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
- c(x, "maskTextureCache", /* @__PURE__ */ new Map()), /**
808
+ x(b, "maskTextureCache", /* @__PURE__ */ new Map()), /**
602
809
  * Canvas 到 Symbol 的映射(用于缓存 canvas 纹理)
603
810
  */
604
- c(x, "canvasSymbolMap", /* @__PURE__ */ new WeakMap());
811
+ x(b, "canvasSymbolMap", /* @__PURE__ */ new WeakMap()), /** 同点位共用 mesh:key = meshKey(panoIndex + maskKey), value = 共享数据 */
812
+ x(b, "sharedMeshRegistry", /* @__PURE__ */ new Map());
605
813
  export {
606
- x as MaskTag
814
+ b as MaskTag
607
815
  };