@visactor/vstory 0.0.4-alpha.1 → 0.0.4

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 (531) hide show
  1. package/cjs/animate/typewirter.d.ts +3 -4
  2. package/cjs/animate/typewirter.js +44 -30
  3. package/cjs/animate/typewirter.js.map +1 -1
  4. package/cjs/constants/action.d.ts +9 -0
  5. package/cjs/constants/action.js +10 -2
  6. package/cjs/constants/action.js.map +1 -1
  7. package/cjs/constants/character.d.ts +0 -1
  8. package/cjs/constants/character.js +1 -2
  9. package/cjs/constants/character.js.map +1 -1
  10. package/cjs/dsl/constant/index.d.ts +13 -0
  11. package/cjs/dsl/constant/index.js +6 -1
  12. package/cjs/dsl/constant/index.js.map +1 -1
  13. package/cjs/dsl/story-chart/area.d.ts +2 -0
  14. package/cjs/dsl/story-chart/area.js +5 -1
  15. package/cjs/dsl/story-chart/area.js.map +1 -1
  16. package/cjs/dsl/story-chart/bar.d.ts +2 -0
  17. package/cjs/dsl/story-chart/bar.js +1 -1
  18. package/cjs/dsl/story-chart/bar.js.map +1 -1
  19. package/cjs/dsl/story-chart/chart.js +1 -2
  20. package/cjs/dsl/story-chart/line.d.ts +2 -0
  21. package/cjs/dsl/story-chart/line.js +1 -1
  22. package/cjs/dsl/story-chart/line.js.map +1 -1
  23. package/cjs/dsl/story-chart/pie.d.ts +2 -0
  24. package/cjs/dsl/story-chart/pie.js +3 -0
  25. package/cjs/dsl/story-chart/pie.js.map +1 -1
  26. package/cjs/dsl/story-processor/graphic/appear.js.map +1 -1
  27. package/cjs/dsl/story-processor/graphic/effect/appear.js +2 -7
  28. package/cjs/dsl/story-processor/graphic/effect/appear.js.map +1 -1
  29. package/cjs/dsl/story-processor/graphic/effect/typewriter.js +1 -1
  30. package/cjs/dsl/story-processor/graphic/effect/typewriter.js.map +1 -1
  31. package/cjs/dsl/story-processor/processor.js +1 -1
  32. package/cjs/dsl/types/Datum.js +2 -1
  33. package/cjs/dsl/types/index.js +1 -1
  34. package/cjs/dsl/utils/datum.js +1 -1
  35. package/cjs/dsl/utils/flicker.js +1 -1
  36. package/cjs/edit/edit-component/image-selection.js +1 -1
  37. package/cjs/edit/edit-component/index.js +1 -1
  38. package/cjs/edit/edit-component/layer-edit.js +0 -2
  39. package/cjs/edit/edit-component/rect-selection.js +1 -1
  40. package/cjs/edit/edit-component/richtext-selection.js +1 -1
  41. package/cjs/edit/edit-component/text-selection.js +1 -1
  42. package/cjs/index.d.ts +0 -1
  43. package/cjs/index.js +1 -2
  44. package/cjs/index.js.map +1 -1
  45. package/cjs/interface/type.js +1 -2
  46. package/cjs/player/interface/player.d.ts +5 -2
  47. package/cjs/player/interface/player.js.map +1 -1
  48. package/cjs/player/interface/scheduler.d.ts +1 -1
  49. package/cjs/player/interface/scheduler.js.map +1 -1
  50. package/cjs/player/player.d.ts +7 -2
  51. package/cjs/player/player.js +25 -19
  52. package/cjs/player/player.js.map +1 -1
  53. package/cjs/player/processor/chart/common/chartAppear.d.ts +5 -0
  54. package/cjs/player/processor/chart/common/chartAppear.js +11 -0
  55. package/cjs/player/processor/chart/common/chartAppear.js.map +1 -0
  56. package/cjs/player/processor/chart/common/commonAppear.d.ts +8 -0
  57. package/cjs/player/processor/chart/common/commonAppear.js +46 -0
  58. package/cjs/player/processor/chart/common/commonAppear.js.map +1 -0
  59. package/cjs/player/processor/chart/component/axisAppear.d.ts +2 -2
  60. package/cjs/player/processor/chart/component/axisAppear.js +2 -2
  61. package/cjs/player/processor/chart/component/axisAppear.js.map +1 -1
  62. package/cjs/player/processor/chart/component/commonAppear.d.ts +3 -3
  63. package/cjs/player/processor/chart/component/commonAppear.js +5 -17
  64. package/cjs/player/processor/chart/component/commonAppear.js.map +1 -1
  65. package/cjs/player/processor/chart/component/labelAppear.d.ts +2 -2
  66. package/cjs/player/processor/chart/component/labelAppear.js +1 -1
  67. package/cjs/player/processor/chart/component/labelAppear.js.map +1 -1
  68. package/cjs/player/processor/chart/component/legendsAppear.d.ts +4 -3
  69. package/cjs/player/processor/chart/component/legendsAppear.js +2 -3
  70. package/cjs/player/processor/chart/component/legendsAppear.js.map +1 -1
  71. package/cjs/player/processor/chart/component/titleAppear.d.ts +4 -3
  72. package/cjs/player/processor/chart/component/titleAppear.js +2 -3
  73. package/cjs/player/processor/chart/component/titleAppear.js.map +1 -1
  74. package/cjs/player/processor/chart/seriesmark/commonTransformMarkAppear.d.ts +3 -3
  75. package/cjs/player/processor/chart/seriesmark/commonTransformMarkAppear.js.map +1 -1
  76. package/cjs/player/processor/chart/seriesmark/{transformArcAppear.d.ts → transformArcVisibility.d.ts} +2 -2
  77. package/cjs/player/processor/chart/seriesmark/{transformArcAppear.js → transformArcVisibility.js} +5 -6
  78. package/cjs/player/processor/chart/seriesmark/transformArcVisibility.js.map +1 -0
  79. package/cjs/player/processor/chart/seriesmark/{transformRectAppear.d.ts → transformLineVisibility.d.ts} +2 -2
  80. package/cjs/player/processor/chart/seriesmark/transformLineVisibility.js +12 -0
  81. package/cjs/player/processor/chart/seriesmark/transformLineVisibility.js.map +1 -0
  82. package/cjs/player/processor/chart/seriesmark/{transformLineAppear.d.ts → transformRectVisibility.d.ts} +2 -2
  83. package/cjs/player/processor/chart/seriesmark/{transformRectAppear.js → transformRectVisibility.js} +6 -7
  84. package/cjs/player/processor/chart/seriesmark/transformRectVisibility.js.map +1 -0
  85. package/cjs/player/processor/chart/seriesmark/transformSymbolVisibility.d.ts +12 -0
  86. package/cjs/player/processor/chart/seriesmark/transformSymbolVisibility.js +12 -0
  87. package/cjs/player/processor/chart/seriesmark/transformSymbolVisibility.js.map +1 -0
  88. package/cjs/player/processor/chart/seriesmark/transformTextVisibility.d.ts +12 -0
  89. package/cjs/player/processor/chart/seriesmark/transformTextVisibility.js +12 -0
  90. package/cjs/player/processor/chart/seriesmark/transformTextVisibility.js.map +1 -0
  91. package/cjs/player/processor/chart/transformMap.d.ts +24 -18
  92. package/cjs/player/processor/chart/transformMap.js +8 -7
  93. package/cjs/player/processor/chart/transformMap.js.map +1 -1
  94. package/cjs/player/processor/chart/vchart.d.ts +62 -15
  95. package/cjs/player/processor/chart/vchart.js +98 -11
  96. package/cjs/player/processor/chart/vchart.js.map +1 -1
  97. package/cjs/player/processor/common/bounce-processor.d.ts +3 -0
  98. package/cjs/player/processor/common/bounce-processor.js +24 -0
  99. package/cjs/player/processor/common/bounce-processor.js.map +1 -0
  100. package/cjs/player/processor/common/common.d.ts +5 -0
  101. package/cjs/player/processor/common/common.js +20 -0
  102. package/cjs/player/processor/common/common.js.map +1 -0
  103. package/cjs/player/processor/common/fade-processor.d.ts +4 -0
  104. package/cjs/player/processor/common/fade-processor.js +36 -0
  105. package/cjs/player/processor/common/fade-processor.js.map +1 -0
  106. package/cjs/player/processor/common/move-processor.d.ts +8 -0
  107. package/cjs/player/processor/common/move-processor.js +155 -0
  108. package/cjs/player/processor/common/move-processor.js.map +1 -0
  109. package/cjs/player/processor/common/scale-processor.d.ts +8 -0
  110. package/cjs/player/processor/common/scale-processor.js +49 -0
  111. package/cjs/player/processor/common/scale-processor.js.map +1 -0
  112. package/cjs/player/processor/common/wipe-processor.d.ts +4 -0
  113. package/cjs/player/processor/common/wipe-processor.js +40 -0
  114. package/cjs/player/processor/common/wipe-processor.js.map +1 -0
  115. package/cjs/player/processor/common-processor.js +3 -0
  116. package/cjs/player/processor/common-processor.js.map +1 -0
  117. package/cjs/player/processor/component/common-component.d.ts +45 -9
  118. package/cjs/player/processor/component/common-component.js +98 -77
  119. package/cjs/player/processor/component/common-component.js.map +1 -1
  120. package/cjs/player/processor/component/image/image-visibility.d.ts +5 -0
  121. package/cjs/player/processor/component/image/image-visibility.js +16 -0
  122. package/cjs/player/processor/component/image/image-visibility.js.map +1 -0
  123. package/cjs/player/processor/component/line/line-visibility.d.ts +5 -0
  124. package/cjs/player/processor/component/line/line-visibility.js +16 -0
  125. package/cjs/player/processor/component/line/line-visibility.js.map +1 -0
  126. package/cjs/player/processor/component/rect/rect-visibility.d.ts +5 -0
  127. package/cjs/player/processor/component/rect/rect-visibility.js +16 -0
  128. package/cjs/player/processor/component/rect/rect-visibility.js.map +1 -0
  129. package/cjs/player/processor/component/shape/shape-visibility.d.ts +5 -0
  130. package/cjs/player/processor/component/shape/shape-visibility.js +16 -0
  131. package/cjs/player/processor/component/shape/shape-visibility.js.map +1 -0
  132. package/cjs/player/processor/component/text/text-visibility.d.ts +6 -0
  133. package/cjs/player/processor/component/text/text-visibility.js +41 -0
  134. package/cjs/player/processor/component/text/text-visibility.js.map +1 -0
  135. package/cjs/player/processor/component/timeline/timeline-visibility.d.ts +15 -0
  136. package/cjs/player/processor/component/timeline/timeline-visibility.js +79 -0
  137. package/cjs/player/processor/component/timeline/timeline-visibility.js.map +1 -0
  138. package/cjs/player/processor/component/utils.d.ts +3 -1
  139. package/cjs/player/processor/component/utils.js +16 -1
  140. package/cjs/player/processor/component/utils.js.map +1 -1
  141. package/cjs/player/processor/interface/action-processor.d.ts +6 -6
  142. package/cjs/player/processor/interface/action-processor.js.map +1 -1
  143. package/cjs/player/processor/interface/appear-action.d.ts +30 -18
  144. package/cjs/player/processor/interface/appear-action.js.map +1 -1
  145. package/cjs/player/processor/interface/common-action.d.ts +14 -0
  146. package/cjs/player/processor/interface/common-action.js +6 -0
  147. package/cjs/player/processor/interface/common-action.js.map +1 -0
  148. package/cjs/player/processor/interface/style-action.d.ts +34 -0
  149. package/cjs/player/processor/interface/style-action.js +6 -0
  150. package/cjs/player/processor/interface/style-action.js.map +1 -0
  151. package/cjs/player/processor/processor-item.d.ts +5 -5
  152. package/cjs/player/processor/processor-item.js.map +1 -1
  153. package/cjs/player/processor/processor.d.ts +3 -3
  154. package/cjs/player/processor/processor.js +2 -2
  155. package/cjs/player/processor/processor.js.map +1 -1
  156. package/cjs/player/processor/processorMap.d.ts +22 -21
  157. package/cjs/player/processor/processorMap.js +42 -8
  158. package/cjs/player/processor/processorMap.js.map +1 -1
  159. package/cjs/player/scheduler.d.ts +4 -3
  160. package/cjs/player/scheduler.js +7 -5
  161. package/cjs/player/scheduler.js.map +1 -1
  162. package/cjs/scene/action.js +0 -2
  163. package/cjs/story/canvas/canvas.js +1 -1
  164. package/cjs/story/character/base/base.d.ts +3 -4
  165. package/cjs/story/character/base/base.js +6 -3
  166. package/cjs/story/character/base/base.js.map +1 -1
  167. package/cjs/story/character/chart/character.d.ts +1 -0
  168. package/cjs/story/character/chart/character.js +3 -0
  169. package/cjs/story/character/chart/character.js.map +1 -1
  170. package/cjs/story/character/chart/graphic/vchart-graphic-render.js +3 -3
  171. package/cjs/story/character/chart/graphic/vchart-graphic-render.js.map +1 -1
  172. package/cjs/story/character/chart/graphic/vchart-graphic.d.ts +1 -0
  173. package/cjs/story/character/chart/graphic/vchart-graphic.js +5 -1
  174. package/cjs/story/character/chart/graphic/vchart-graphic.js.map +1 -1
  175. package/cjs/story/character/component/character-group/component-group-graphic.d.ts +1 -0
  176. package/cjs/story/character/component/character-group/component-group-graphic.js +8 -2
  177. package/cjs/story/character/component/character-group/component-group-graphic.js.map +1 -1
  178. package/cjs/story/character/component/character.d.ts +4 -3
  179. package/cjs/story/character/component/character.js +8 -5
  180. package/cjs/story/character/component/character.js.map +1 -1
  181. package/cjs/story/character/component/characters/character-richtext.d.ts +1 -6
  182. package/cjs/story/character/component/characters/character-richtext.js +0 -16
  183. package/cjs/story/character/component/characters/character-richtext.js.map +1 -1
  184. package/cjs/story/character/component/characters/character-text.js +1 -1
  185. package/cjs/story/character/component/characters/character-text.js.map +1 -1
  186. package/cjs/story/character/component/graphic/graphic-base-text.d.ts +23 -0
  187. package/cjs/story/character/component/graphic/{graphic-text.js → graphic-base-text.js} +38 -22
  188. package/cjs/story/character/component/graphic/graphic-base-text.js.map +1 -0
  189. package/cjs/story/character/component/graphic/graphic.d.ts +1 -1
  190. package/cjs/story/character/component/graphic/graphic.js.map +1 -1
  191. package/cjs/story/character/component/graphic/richtext.d.ts +1 -9
  192. package/cjs/story/character/component/graphic/richtext.js +0 -45
  193. package/cjs/story/character/component/graphic/richtext.js.map +1 -1
  194. package/cjs/story/character/component/graphic/text.d.ts +4 -3
  195. package/cjs/story/character/component/graphic/text.js +21 -6
  196. package/cjs/story/character/component/graphic/text.js.map +1 -1
  197. package/cjs/story/character/component/graphic/timeline.d.ts +6 -0
  198. package/cjs/story/character/component/graphic/timeline.js +7 -1
  199. package/cjs/story/character/component/graphic/timeline.js.map +1 -1
  200. package/cjs/story/character/dsl-interface.d.ts +2 -2
  201. package/cjs/story/character/dsl-interface.js.map +1 -1
  202. package/cjs/story/character/runtime-interface.d.ts +1 -0
  203. package/cjs/story/character/runtime-interface.js.map +1 -1
  204. package/cjs/story/character/visactor/character.d.ts +2 -3
  205. package/cjs/story/character/visactor/character.js.map +1 -1
  206. package/cjs/story/character/visactor/interface.d.ts +1 -0
  207. package/cjs/story/character/visactor/interface.js.map +1 -1
  208. package/cjs/story/character-tree/character-tree.d.ts +1 -0
  209. package/cjs/story/character-tree/character-tree.js +6 -0
  210. package/cjs/story/character-tree/character-tree.js.map +1 -1
  211. package/cjs/story/index.js +1 -2
  212. package/cjs/story/index.js.map +1 -1
  213. package/cjs/story/interface/dsl-interface.d.ts +5 -8
  214. package/cjs/story/interface/dsl-interface.js.map +1 -1
  215. package/cjs/story/interface/player.d.ts +1 -13
  216. package/cjs/story/interface/player.js +1 -4
  217. package/cjs/story/interface/player.js.map +1 -1
  218. package/cjs/story/interface/runtime-interface.d.ts +2 -0
  219. package/cjs/story/interface/runtime-interface.js.map +1 -1
  220. package/cjs/story/story.d.ts +2 -1
  221. package/cjs/story/story.js +7 -5
  222. package/cjs/story/story.js.map +1 -1
  223. package/cjs/util/space.js +1 -2
  224. package/cjs/util/vrender-api.js +2 -1
  225. package/dist/index.js +6584 -14631
  226. package/dist/index.min.js +20 -1
  227. package/es/animate/typewirter.d.ts +3 -4
  228. package/es/animate/typewirter.js +46 -30
  229. package/es/animate/typewirter.js.map +1 -1
  230. package/es/constants/action.d.ts +9 -0
  231. package/es/constants/action.js +11 -1
  232. package/es/constants/action.js.map +1 -1
  233. package/es/constants/character.d.ts +0 -1
  234. package/es/constants/character.js +1 -2
  235. package/es/constants/character.js.map +1 -1
  236. package/es/dsl/constant/index.d.ts +13 -0
  237. package/es/dsl/constant/index.js +6 -1
  238. package/es/dsl/constant/index.js.map +1 -1
  239. package/es/dsl/story-chart/area.d.ts +2 -0
  240. package/es/dsl/story-chart/area.js +5 -1
  241. package/es/dsl/story-chart/area.js.map +1 -1
  242. package/es/dsl/story-chart/bar.d.ts +2 -0
  243. package/es/dsl/story-chart/bar.js +1 -1
  244. package/es/dsl/story-chart/bar.js.map +1 -1
  245. package/es/dsl/story-chart/chart.js +1 -2
  246. package/es/dsl/story-chart/line.d.ts +2 -0
  247. package/es/dsl/story-chart/line.js +1 -1
  248. package/es/dsl/story-chart/line.js.map +1 -1
  249. package/es/dsl/story-chart/pie.d.ts +2 -0
  250. package/es/dsl/story-chart/pie.js +3 -0
  251. package/es/dsl/story-chart/pie.js.map +1 -1
  252. package/es/dsl/story-processor/graphic/appear.js.map +1 -1
  253. package/es/dsl/story-processor/graphic/effect/appear.js +1 -8
  254. package/es/dsl/story-processor/graphic/effect/appear.js.map +1 -1
  255. package/es/dsl/story-processor/graphic/effect/typewriter.js +1 -1
  256. package/es/dsl/story-processor/graphic/effect/typewriter.js.map +1 -1
  257. package/es/dsl/story-processor/processor.js +1 -1
  258. package/es/dsl/types/Datum.js +2 -1
  259. package/es/dsl/types/index.js +1 -1
  260. package/es/dsl/utils/datum.js +1 -1
  261. package/es/dsl/utils/flicker.js +1 -1
  262. package/es/edit/edit-component/image-selection.js +1 -1
  263. package/es/edit/edit-component/index.js +1 -1
  264. package/es/edit/edit-component/layer-edit.js +0 -2
  265. package/es/edit/edit-component/rect-selection.js +1 -1
  266. package/es/edit/edit-component/richtext-selection.js +1 -1
  267. package/es/edit/edit-component/text-selection.js +1 -1
  268. package/es/index.d.ts +0 -1
  269. package/es/index.js +1 -3
  270. package/es/index.js.map +1 -1
  271. package/es/interface/type.js +1 -2
  272. package/es/player/interface/player.d.ts +5 -2
  273. package/es/player/interface/player.js.map +1 -1
  274. package/es/player/interface/scheduler.d.ts +1 -1
  275. package/es/player/interface/scheduler.js.map +1 -1
  276. package/es/player/player.d.ts +7 -2
  277. package/es/player/player.js +27 -18
  278. package/es/player/player.js.map +1 -1
  279. package/es/player/processor/chart/common/chartAppear.d.ts +5 -0
  280. package/es/player/processor/chart/common/chartAppear.js +4 -0
  281. package/es/player/processor/chart/common/chartAppear.js.map +1 -0
  282. package/es/player/processor/chart/common/commonAppear.d.ts +8 -0
  283. package/es/player/processor/chart/common/commonAppear.js +36 -0
  284. package/es/player/processor/chart/common/commonAppear.js.map +1 -0
  285. package/es/player/processor/chart/component/axisAppear.d.ts +2 -2
  286. package/es/player/processor/chart/component/axisAppear.js +3 -1
  287. package/es/player/processor/chart/component/axisAppear.js.map +1 -1
  288. package/es/player/processor/chart/component/commonAppear.d.ts +3 -3
  289. package/es/player/processor/chart/component/commonAppear.js +3 -14
  290. package/es/player/processor/chart/component/commonAppear.js.map +1 -1
  291. package/es/player/processor/chart/component/labelAppear.d.ts +2 -2
  292. package/es/player/processor/chart/component/labelAppear.js +1 -1
  293. package/es/player/processor/chart/component/labelAppear.js.map +1 -1
  294. package/es/player/processor/chart/component/legendsAppear.d.ts +4 -3
  295. package/es/player/processor/chart/component/legendsAppear.js +2 -2
  296. package/es/player/processor/chart/component/legendsAppear.js.map +1 -1
  297. package/es/player/processor/chart/component/titleAppear.d.ts +4 -3
  298. package/es/player/processor/chart/component/titleAppear.js +2 -2
  299. package/es/player/processor/chart/component/titleAppear.js.map +1 -1
  300. package/es/player/processor/chart/seriesmark/commonTransformMarkAppear.d.ts +3 -3
  301. package/es/player/processor/chart/seriesmark/commonTransformMarkAppear.js.map +1 -1
  302. package/{cjs/player/processor/chart/seriesmark/transformSymbolAppear.d.ts → es/player/processor/chart/seriesmark/transformArcVisibility.d.ts} +3 -3
  303. package/es/player/processor/chart/seriesmark/{transformArcAppear.js → transformArcVisibility.js} +3 -4
  304. package/es/player/processor/chart/seriesmark/transformArcVisibility.js.map +1 -0
  305. package/es/player/processor/chart/seriesmark/transformLineVisibility.d.ts +12 -0
  306. package/es/player/processor/chart/seriesmark/transformLineVisibility.js +4 -0
  307. package/es/player/processor/chart/seriesmark/transformLineVisibility.js.map +1 -0
  308. package/es/player/processor/chart/seriesmark/transformRectVisibility.d.ts +12 -0
  309. package/es/player/processor/chart/seriesmark/{transformRectAppear.js → transformRectVisibility.js} +4 -5
  310. package/es/player/processor/chart/seriesmark/transformRectVisibility.js.map +1 -0
  311. package/es/player/processor/chart/seriesmark/transformSymbolVisibility.d.ts +12 -0
  312. package/es/player/processor/chart/seriesmark/transformSymbolVisibility.js +4 -0
  313. package/es/player/processor/chart/seriesmark/transformSymbolVisibility.js.map +1 -0
  314. package/es/player/processor/chart/seriesmark/transformTextVisibility.d.ts +12 -0
  315. package/es/player/processor/chart/seriesmark/transformTextVisibility.js +4 -0
  316. package/es/player/processor/chart/seriesmark/transformTextVisibility.js.map +1 -0
  317. package/es/player/processor/chart/transformMap.d.ts +24 -18
  318. package/es/player/processor/chart/transformMap.js +14 -11
  319. package/es/player/processor/chart/transformMap.js.map +1 -1
  320. package/es/player/processor/chart/vchart.d.ts +62 -15
  321. package/es/player/processor/chart/vchart.js +92 -9
  322. package/es/player/processor/chart/vchart.js.map +1 -1
  323. package/es/player/processor/common/bounce-processor.d.ts +3 -0
  324. package/es/player/processor/common/bounce-processor.js +20 -0
  325. package/es/player/processor/common/bounce-processor.js.map +1 -0
  326. package/es/player/processor/common/common.d.ts +5 -0
  327. package/es/player/processor/common/common.js +12 -0
  328. package/es/player/processor/common/common.js.map +1 -0
  329. package/es/player/processor/common/fade-processor.d.ts +4 -0
  330. package/es/player/processor/common/fade-processor.js +30 -0
  331. package/es/player/processor/common/fade-processor.js.map +1 -0
  332. package/es/player/processor/common/move-processor.d.ts +8 -0
  333. package/es/player/processor/common/move-processor.js +148 -0
  334. package/es/player/processor/common/move-processor.js.map +1 -0
  335. package/es/player/processor/common/scale-processor.d.ts +8 -0
  336. package/es/player/processor/common/scale-processor.js +43 -0
  337. package/es/player/processor/common/scale-processor.js.map +1 -0
  338. package/es/player/processor/common/wipe-processor.d.ts +4 -0
  339. package/es/player/processor/common/wipe-processor.js +36 -0
  340. package/es/player/processor/common/wipe-processor.js.map +1 -0
  341. package/es/player/processor/common-processor.js +3 -0
  342. package/es/player/processor/common-processor.js.map +1 -0
  343. package/es/player/processor/component/common-component.d.ts +45 -9
  344. package/es/player/processor/component/common-component.js +97 -73
  345. package/es/player/processor/component/common-component.js.map +1 -1
  346. package/es/player/processor/component/image/image-visibility.d.ts +5 -0
  347. package/es/player/processor/component/image/image-visibility.js +8 -0
  348. package/es/player/processor/component/image/image-visibility.js.map +1 -0
  349. package/es/player/processor/component/line/line-visibility.d.ts +5 -0
  350. package/es/player/processor/component/line/line-visibility.js +8 -0
  351. package/es/player/processor/component/line/line-visibility.js.map +1 -0
  352. package/es/player/processor/component/rect/rect-visibility.d.ts +5 -0
  353. package/es/player/processor/component/rect/rect-visibility.js +8 -0
  354. package/es/player/processor/component/rect/rect-visibility.js.map +1 -0
  355. package/es/player/processor/component/shape/shape-visibility.d.ts +5 -0
  356. package/es/player/processor/component/shape/shape-visibility.js +8 -0
  357. package/es/player/processor/component/shape/shape-visibility.js.map +1 -0
  358. package/es/player/processor/component/text/text-visibility.d.ts +6 -0
  359. package/es/player/processor/component/text/text-visibility.js +39 -0
  360. package/es/player/processor/component/text/text-visibility.js.map +1 -0
  361. package/es/player/processor/component/timeline/timeline-visibility.d.ts +15 -0
  362. package/es/player/processor/component/timeline/timeline-visibility.js +71 -0
  363. package/es/player/processor/component/timeline/timeline-visibility.js.map +1 -0
  364. package/es/player/processor/component/utils.d.ts +3 -1
  365. package/es/player/processor/component/utils.js +13 -0
  366. package/es/player/processor/component/utils.js.map +1 -1
  367. package/es/player/processor/interface/action-processor.d.ts +6 -6
  368. package/es/player/processor/interface/action-processor.js.map +1 -1
  369. package/es/player/processor/interface/appear-action.d.ts +30 -18
  370. package/es/player/processor/interface/appear-action.js.map +1 -1
  371. package/es/player/processor/interface/common-action.d.ts +14 -0
  372. package/es/player/processor/interface/common-action.js +2 -0
  373. package/es/player/processor/interface/common-action.js.map +1 -0
  374. package/es/player/processor/interface/style-action.d.ts +34 -0
  375. package/es/player/processor/interface/style-action.js +2 -0
  376. package/es/player/processor/interface/style-action.js.map +1 -0
  377. package/es/player/processor/processor-item.d.ts +5 -5
  378. package/es/player/processor/processor-item.js.map +1 -1
  379. package/es/player/processor/processor.d.ts +3 -3
  380. package/es/player/processor/processor.js +2 -2
  381. package/es/player/processor/processor.js.map +1 -1
  382. package/es/player/processor/processorMap.d.ts +22 -21
  383. package/es/player/processor/processorMap.js +51 -15
  384. package/es/player/processor/processorMap.js.map +1 -1
  385. package/es/player/scheduler.d.ts +4 -3
  386. package/es/player/scheduler.js +7 -5
  387. package/es/player/scheduler.js.map +1 -1
  388. package/es/scene/action.js +0 -2
  389. package/es/story/canvas/canvas.js +1 -1
  390. package/es/story/character/base/base.d.ts +3 -4
  391. package/es/story/character/base/base.js +6 -3
  392. package/es/story/character/base/base.js.map +1 -1
  393. package/es/story/character/chart/character.d.ts +1 -0
  394. package/es/story/character/chart/character.js +3 -0
  395. package/es/story/character/chart/character.js.map +1 -1
  396. package/es/story/character/chart/graphic/vchart-graphic-render.js +3 -3
  397. package/es/story/character/chart/graphic/vchart-graphic-render.js.map +1 -1
  398. package/es/story/character/chart/graphic/vchart-graphic.d.ts +1 -0
  399. package/es/story/character/chart/graphic/vchart-graphic.js +5 -1
  400. package/es/story/character/chart/graphic/vchart-graphic.js.map +1 -1
  401. package/es/story/character/component/character-group/component-group-graphic.d.ts +1 -0
  402. package/es/story/character/component/character-group/component-group-graphic.js +8 -2
  403. package/es/story/character/component/character-group/component-group-graphic.js.map +1 -1
  404. package/es/story/character/component/character.d.ts +4 -3
  405. package/es/story/character/component/character.js +8 -4
  406. package/es/story/character/component/character.js.map +1 -1
  407. package/es/story/character/component/characters/character-richtext.d.ts +1 -6
  408. package/es/story/character/component/characters/character-richtext.js +0 -12
  409. package/es/story/character/component/characters/character-richtext.js.map +1 -1
  410. package/es/story/character/component/characters/character-text.js +2 -2
  411. package/es/story/character/component/characters/character-text.js.map +1 -1
  412. package/es/story/character/component/graphic/graphic-base-text.d.ts +23 -0
  413. package/es/story/character/component/graphic/{graphic-text.js → graphic-base-text.js} +37 -21
  414. package/es/story/character/component/graphic/graphic-base-text.js.map +1 -0
  415. package/es/story/character/component/graphic/graphic.d.ts +1 -1
  416. package/es/story/character/component/graphic/graphic.js.map +1 -1
  417. package/es/story/character/component/graphic/richtext.d.ts +1 -9
  418. package/es/story/character/component/graphic/richtext.js +0 -41
  419. package/es/story/character/component/graphic/richtext.js.map +1 -1
  420. package/es/story/character/component/graphic/text.d.ts +4 -3
  421. package/es/story/character/component/graphic/text.js +21 -4
  422. package/es/story/character/component/graphic/text.js.map +1 -1
  423. package/es/story/character/component/graphic/timeline.d.ts +6 -0
  424. package/es/story/character/component/graphic/timeline.js +7 -1
  425. package/es/story/character/component/graphic/timeline.js.map +1 -1
  426. package/es/story/character/dsl-interface.d.ts +2 -2
  427. package/es/story/character/dsl-interface.js.map +1 -1
  428. package/es/story/character/runtime-interface.d.ts +1 -0
  429. package/es/story/character/runtime-interface.js.map +1 -1
  430. package/es/story/character/visactor/character.d.ts +2 -3
  431. package/es/story/character/visactor/character.js.map +1 -1
  432. package/es/story/character/visactor/interface.d.ts +1 -0
  433. package/es/story/character/visactor/interface.js.map +1 -1
  434. package/es/story/character-tree/character-tree.d.ts +1 -0
  435. package/es/story/character-tree/character-tree.js +6 -0
  436. package/es/story/character-tree/character-tree.js.map +1 -1
  437. package/es/story/index.js +0 -3
  438. package/es/story/index.js.map +1 -1
  439. package/es/story/interface/dsl-interface.d.ts +5 -8
  440. package/es/story/interface/dsl-interface.js.map +1 -1
  441. package/es/story/interface/player.d.ts +1 -13
  442. package/es/story/interface/player.js +2 -1
  443. package/es/story/interface/player.js.map +1 -1
  444. package/es/story/interface/runtime-interface.d.ts +2 -0
  445. package/es/story/interface/runtime-interface.js.map +1 -1
  446. package/es/story/story.d.ts +2 -1
  447. package/es/story/story.js +7 -5
  448. package/es/story/story.js.map +1 -1
  449. package/es/util/space.js +1 -2
  450. package/es/util/vrender-api.js +2 -1
  451. package/package.json +7 -7
  452. package/cjs/player/processor/chart/seriesmark/transformArcAppear.js.map +0 -1
  453. package/cjs/player/processor/chart/seriesmark/transformLineAppear.js +0 -14
  454. package/cjs/player/processor/chart/seriesmark/transformLineAppear.js.map +0 -1
  455. package/cjs/player/processor/chart/seriesmark/transformRectAppear.js.map +0 -1
  456. package/cjs/player/processor/chart/seriesmark/transformSymbolAppear.js +0 -14
  457. package/cjs/player/processor/chart/seriesmark/transformSymbolAppear.js.map +0 -1
  458. package/cjs/player/processor/chart/seriesmark/transformTextAppear.d.ts +0 -12
  459. package/cjs/player/processor/chart/seriesmark/transformTextAppear.js +0 -14
  460. package/cjs/player/processor/chart/seriesmark/transformTextAppear.js.map +0 -1
  461. package/cjs/player/processor/component/image/image-appear.d.ts +0 -5
  462. package/cjs/player/processor/component/image/image-appear.js +0 -16
  463. package/cjs/player/processor/component/image/image-appear.js.map +0 -1
  464. package/cjs/player/processor/component/line/line-appear.d.ts +0 -5
  465. package/cjs/player/processor/component/line/line-appear.js +0 -16
  466. package/cjs/player/processor/component/line/line-appear.js.map +0 -1
  467. package/cjs/player/processor/component/rect/rect-appear.d.ts +0 -5
  468. package/cjs/player/processor/component/rect/rect-appear.js +0 -16
  469. package/cjs/player/processor/component/rect/rect-appear.js.map +0 -1
  470. package/cjs/player/processor/component/shape/shape-appear.d.ts +0 -5
  471. package/cjs/player/processor/component/shape/shape-appear.js +0 -16
  472. package/cjs/player/processor/component/shape/shape-appear.js.map +0 -1
  473. package/cjs/player/processor/component/text/text-appear.d.ts +0 -7
  474. package/cjs/player/processor/component/text/text-appear.js +0 -34
  475. package/cjs/player/processor/component/text/text-appear.js.map +0 -1
  476. package/cjs/player/processor/component/timeline/timeline-appear.d.ts +0 -7
  477. package/cjs/player/processor/component/timeline/timeline-appear.js +0 -33
  478. package/cjs/player/processor/component/timeline/timeline-appear.js.map +0 -1
  479. package/cjs/story/character/component/graphic/graphic-text.d.ts +0 -18
  480. package/cjs/story/character/component/graphic/graphic-text.js.map +0 -1
  481. package/cjs/story/player/encode.js +0 -3
  482. package/cjs/story/player/encode.js.map +0 -1
  483. package/cjs/story/player/index.js +0 -3
  484. package/cjs/story/player/index.js.map +0 -1
  485. package/cjs/story/player/ticker.d.ts +0 -1
  486. package/cjs/story/player/ticker.js +0 -3
  487. package/cjs/story/player/ticker.js.map +0 -1
  488. package/es/player/processor/chart/seriesmark/transformArcAppear.d.ts +0 -12
  489. package/es/player/processor/chart/seriesmark/transformArcAppear.js.map +0 -1
  490. package/es/player/processor/chart/seriesmark/transformLineAppear.d.ts +0 -12
  491. package/es/player/processor/chart/seriesmark/transformLineAppear.js +0 -7
  492. package/es/player/processor/chart/seriesmark/transformLineAppear.js.map +0 -1
  493. package/es/player/processor/chart/seriesmark/transformRectAppear.d.ts +0 -12
  494. package/es/player/processor/chart/seriesmark/transformRectAppear.js.map +0 -1
  495. package/es/player/processor/chart/seriesmark/transformSymbolAppear.d.ts +0 -12
  496. package/es/player/processor/chart/seriesmark/transformSymbolAppear.js +0 -7
  497. package/es/player/processor/chart/seriesmark/transformSymbolAppear.js.map +0 -1
  498. package/es/player/processor/chart/seriesmark/transformTextAppear.d.ts +0 -12
  499. package/es/player/processor/chart/seriesmark/transformTextAppear.js +0 -7
  500. package/es/player/processor/chart/seriesmark/transformTextAppear.js.map +0 -1
  501. package/es/player/processor/component/image/image-appear.d.ts +0 -5
  502. package/es/player/processor/component/image/image-appear.js +0 -8
  503. package/es/player/processor/component/image/image-appear.js.map +0 -1
  504. package/es/player/processor/component/line/line-appear.d.ts +0 -5
  505. package/es/player/processor/component/line/line-appear.js +0 -8
  506. package/es/player/processor/component/line/line-appear.js.map +0 -1
  507. package/es/player/processor/component/rect/rect-appear.d.ts +0 -5
  508. package/es/player/processor/component/rect/rect-appear.js +0 -8
  509. package/es/player/processor/component/rect/rect-appear.js.map +0 -1
  510. package/es/player/processor/component/shape/shape-appear.d.ts +0 -5
  511. package/es/player/processor/component/shape/shape-appear.js +0 -8
  512. package/es/player/processor/component/shape/shape-appear.js.map +0 -1
  513. package/es/player/processor/component/text/text-appear.d.ts +0 -7
  514. package/es/player/processor/component/text/text-appear.js +0 -32
  515. package/es/player/processor/component/text/text-appear.js.map +0 -1
  516. package/es/player/processor/component/timeline/timeline-appear.d.ts +0 -7
  517. package/es/player/processor/component/timeline/timeline-appear.js +0 -27
  518. package/es/player/processor/component/timeline/timeline-appear.js.map +0 -1
  519. package/es/story/character/component/graphic/graphic-text.d.ts +0 -18
  520. package/es/story/character/component/graphic/graphic-text.js.map +0 -1
  521. package/es/story/player/encode.d.ts +0 -1
  522. package/es/story/player/encode.js +0 -3
  523. package/es/story/player/encode.js.map +0 -1
  524. package/es/story/player/index.d.ts +0 -1
  525. package/es/story/player/index.js +0 -3
  526. package/es/story/player/index.js.map +0 -1
  527. package/es/story/player/ticker.d.ts +0 -1
  528. package/es/story/player/ticker.js +0 -3
  529. package/es/story/player/ticker.js.map +0 -1
  530. /package/cjs/{story/player/encode.d.ts → player/processor/common-processor.d.ts} +0 -0
  531. /package/{cjs/story/player/index.d.ts → es/player/processor/common-processor.d.ts} +0 -0
@@ -1,44 +1,3 @@
1
- import { createRichText } from "@visactor/vrender";
2
1
 
3
- import { Graphic } from "./graphic";
4
2
 
5
- import { getLayoutFromWidget } from "../../../utils/layout";
6
-
7
- export class GraphicRichText extends Graphic {
8
- getInitialAttributes() {
9
- return {
10
- x: 0,
11
- y: 0,
12
- width: 120,
13
- height: 80,
14
- maxWidth: 120,
15
- maxHeight: 80,
16
- angle: 0,
17
- fontSize: 16,
18
- textAlign: "center",
19
- textBaseline: "middle",
20
- fill: "#000000",
21
- lineWidth: 2,
22
- ignoreBuf: !0,
23
- stroke: !1,
24
- ellipsis: !0,
25
- textConfig: []
26
- };
27
- }
28
- init() {
29
- var _a, _b;
30
- this._graphic || (this._graphic = createRichText(this._transformAttributes(Object.assign(Object.assign({}, this.getInitialAttributes()), null !== (_b = null === (_a = this._character.spec.options) || void 0 === _a ? void 0 : _a.graphic) && void 0 !== _b ? _b : {}))),
31
- this._graphic.name = `graphic-richtext-${this._character.id}`, this._character.getGraphicParent().add(this._graphic));
32
- }
33
- applyLayoutData(w) {
34
- const {x: x, y: y, width: width, height: height, angle: angle} = getLayoutFromWidget(w);
35
- this._graphic.setAttributes(this._transformAttributes({
36
- x: x,
37
- y: y,
38
- angle: angle,
39
- maxWidth: width,
40
- maxHeight: height
41
- }));
42
- }
43
- }
44
3
  //# sourceMappingURL=richtext.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/component/graphic/richtext.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,OAAO,eAAgB,SAAQ,OAAO;IAG1C,oBAAoB;QAClB,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,EAAE;YACV,QAAQ,EAAE,GAAG;YACb,SAAS,EAAE,EAAE;YACb,KAAK,EAAE,CAAC;YACR,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,QAAQ;YACtB,IAAI,EAAE,SAAS;YACf,SAAS,EAAE,CAAC;YACZ,SAAS,EAAE,IAAI;YACf,MAAM,EAAE,KAAK;YACb,QAAQ,EAAE,IAAI;YACd,UAAU,EAAE,EAAE;SACgB,CAAC;IACnC,CAAC;IAED,IAAI;;QACF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,cAAc,CAC5B,IAAI,CAAC,oBAAoB,iCACpB,IAAI,CAAC,oBAAoB,EAAE,GAC3B,CAAC,MAAA,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,0CAAE,OAAO,mCAAI,EAAE,CAAC,EAChD,CACH,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,oBAAoB,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;YAC9D,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvD;IACH,CAAC;IAED,eAAe,CAAC,CAAuB;QACrC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CACzB,IAAI,CAAC,oBAAoB,CAAC;YACxB,CAAC;YACD,CAAC;YACD,KAAK;YACL,QAAQ,EAAE,KAAK;YACf,SAAS,EAAE,MAAM;SAClB,CAAC,CACH,CAAC;IACJ,CAAC;CACF","file":"richtext.js","sourcesContent":["import type { IRichText, IRichTextAttribute } from '@visactor/vrender';\nimport { createRichText } from '@visactor/vrender';\nimport { Graphic } from './graphic';\nimport type { IWidgetData } from '../../dsl-interface';\nimport { getLayoutFromWidget } from '../../../utils/layout';\n\nexport class GraphicRichText extends Graphic {\n protected _graphic: IRichText;\n\n getInitialAttributes() {\n return {\n x: 0,\n y: 0,\n width: 120,\n height: 80,\n maxWidth: 120,\n maxHeight: 80,\n angle: 0,\n fontSize: 16,\n textAlign: 'center',\n textBaseline: 'middle',\n fill: '#000000',\n lineWidth: 2,\n ignoreBuf: true,\n stroke: false,\n ellipsis: true,\n textConfig: []\n } as Partial<IRichTextAttribute>;\n }\n\n init() {\n if (!this._graphic) {\n this._graphic = createRichText(\n this._transformAttributes({\n ...this.getInitialAttributes(),\n ...(this._character.spec.options?.graphic ?? {})\n })\n );\n this._graphic.name = `graphic-richtext-${this._character.id}`;\n this._character.getGraphicParent().add(this._graphic);\n }\n }\n\n applyLayoutData(w: Partial<IWidgetData>) {\n const { x, y, width, height, angle } = getLayoutFromWidget(w);\n this._graphic.setAttributes(\n this._transformAttributes({\n x,\n y,\n angle,\n maxWidth: width,\n maxHeight: height\n })\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character/component/graphic/richtext.ts"],"names":[],"mappings":"","file":"richtext.js","sourcesContent":["// import type { IRichText, IRichTextAttribute } from '@visactor/vrender';\n// import { createRichText } from '@visactor/vrender';\n// import { Graphic } from './graphic';\n// import type { IWidgetData } from '../../dsl-interface';\n// import { getLayoutFromWidget } from '../../../utils/layout';\n\n// export class GraphicRichText extends Graphic {\n// protected _graphic: IRichText;\n\n// getInitialAttributes() {\n// return {\n// x: 0,\n// y: 0,\n// width: 120,\n// height: 80,\n// maxWidth: 120,\n// maxHeight: 80,\n// angle: 0,\n// fontSize: 16,\n// textAlign: 'center',\n// textBaseline: 'middle',\n// fill: '#000000',\n// lineWidth: 2,\n// ignoreBuf: true,\n// stroke: false,\n// ellipsis: true,\n// textConfig: []\n// } as Partial<IRichTextAttribute>;\n// }\n\n// init() {\n// if (!this._graphic) {\n// this._graphic = createRichText(\n// this._transformAttributes({\n// ...this.getInitialAttributes(),\n// ...(this._character.spec.options?.graphic ?? {})\n// })\n// );\n// this._graphic.name = `graphic-richtext-${this._character.id}`;\n// this._character.getGraphicParent().add(this._graphic);\n// }\n// }\n\n// applyLayoutData(w: Partial<IWidgetData>) {\n// const { x, y, width, height, angle } = getLayoutFromWidget(w);\n// this._graphic.setAttributes(\n// this._transformAttributes({\n// x,\n// y,\n// angle,\n// maxWidth: width,\n// maxHeight: height\n// })\n// );\n// }\n// }\n"]}
@@ -1,9 +1,9 @@
1
- import type { IText } from '@visactor/vrender';
1
+ import type { IRichText } from '@visactor/vrender';
2
2
  import type { IPointLike } from '@visactor/vutils';
3
3
  import { Graphic } from './graphic';
4
4
  import type { IWidgetData } from '../../dsl-interface';
5
- export declare class GraphicPureText extends Graphic {
6
- protected _graphic: IText;
5
+ export declare class GraphicText extends Graphic {
6
+ protected _graphic: IRichText;
7
7
  getInitialAttributes(): {
8
8
  x: number;
9
9
  y: number;
@@ -19,6 +19,7 @@ export declare class GraphicPureText extends Graphic {
19
19
  stroke: boolean;
20
20
  shapePoints: IPointLike[];
21
21
  };
22
+ transformTextAttrsToRichTextConfig(): import("@visactor/vrender").IRichTextCharacter[];
22
23
  init(): void;
23
24
  applyLayoutData(w: Partial<IWidgetData>): void;
24
25
  }
@@ -1,10 +1,12 @@
1
- import { createText } from "@visactor/vrender";
1
+ import { createRichText } from "@visactor/vrender";
2
2
 
3
3
  import { Graphic } from "./graphic";
4
4
 
5
5
  import { getLayoutFromWidget } from "../../../utils/layout";
6
6
 
7
- export class GraphicPureText extends Graphic {
7
+ const richtextCombinedAttrs = [ "fill", "stroke", "fontSize", "fontFamily", "fontStyle", "fontWeight", "lineWidth", "opacity", "fillOpacity", "strokeOpacity" ];
8
+
9
+ export class GraphicText extends Graphic {
8
10
  getInitialAttributes() {
9
11
  return {
10
12
  x: 0,
@@ -22,10 +24,25 @@ export class GraphicPureText extends Graphic {
22
24
  shapePoints: []
23
25
  };
24
26
  }
27
+ transformTextAttrsToRichTextConfig() {
28
+ var _a, _b;
29
+ const textAttr = null !== (_b = null === (_a = this._character.spec.options) || void 0 === _a ? void 0 : _a.graphic) && void 0 !== _b ? _b : {};
30
+ let textConfig = textAttr.textConfig;
31
+ if ((!textConfig || !textConfig.length) && textAttr.text) {
32
+ const textList = Array.isArray(textAttr.text) ? textAttr.text : [ textAttr.text ];
33
+ textConfig = textList.map(((item, i) => ({
34
+ textAlign: textAttr.textAlign,
35
+ textBaseline: textAttr.textBaseline,
36
+ text: item + (i < textList.length - 1 ? "\n" : "")
37
+ })));
38
+ }
39
+ return textConfig;
40
+ }
25
41
  init() {
26
42
  var _a, _b;
27
- this._graphic || (this._graphic = createText(this._transformAttributes(Object.assign(Object.assign({}, this.getInitialAttributes()), null !== (_b = null === (_a = this._character.spec.options) || void 0 === _a ? void 0 : _a.graphic) && void 0 !== _b ? _b : {}))),
28
- this._graphic.name = `graphic-text-${this._character.id}`, this._character.getGraphicParent().add(this._graphic));
43
+ this._graphic || (this._graphic = createRichText(this._transformAttributes(Object.assign(Object.assign(Object.assign({}, this.getInitialAttributes()), null !== (_b = null === (_a = this._character.spec.options) || void 0 === _a ? void 0 : _a.graphic) && void 0 !== _b ? _b : {}), {
44
+ textConfig: this.transformTextAttrsToRichTextConfig()
45
+ }))), this._graphic.name = `graphic-text-${this._character.id}`, this._character.getGraphicParent().add(this._graphic));
29
46
  }
30
47
  applyLayoutData(w) {
31
48
  const {x: x, y: y, width: width, height: height, angle: angle} = getLayoutFromWidget(w);
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/component/graphic/text.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,OAAO,eAAgB,SAAQ,OAAO;IAG1C,oBAAoB;QAClB,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,CAAC;YACR,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,QAAQ;YACtB,IAAI,EAAE,SAAS;YACf,SAAS,EAAE,CAAC;YACZ,SAAS,EAAE,IAAI;YACf,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,EAAkB;SAChC,CAAC;IACJ,CAAC;IAED,IAAI;;QACF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,UAAU,CACxB,IAAI,CAAC,oBAAoB,iCACpB,IAAI,CAAC,oBAAoB,EAAE,GAC3B,CAAC,MAAA,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,0CAAE,OAAO,mCAAI,EAAE,CAAC,EAChD,CACH,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,gBAAgB,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;YAC1D,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvD;IACH,CAAC;IAED,eAAe,CAAC,CAAuB;QACrC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CACzB,IAAI,CAAC,oBAAoB,CAAC;YACxB,CAAC;YACD,CAAC;YACD,KAAK;YACL,KAAK;YACL,MAAM;YACN,YAAY,EAAE,KAAK;YACnB,WAAW,EAAE,MAAM;SACpB,CAAC,CACH,CAAC;IACJ,CAAC;CACF","file":"text.js","sourcesContent":["import type { IText } from '@visactor/vrender';\nimport { createText } from '@visactor/vrender';\nimport type { IPointLike } from '@visactor/vutils';\nimport { Graphic } from './graphic';\nimport type { IWidgetData } from '../../dsl-interface';\nimport { getLayoutFromWidget } from '../../../utils/layout';\n\nexport class GraphicPureText extends Graphic {\n protected _graphic: IText;\n\n getInitialAttributes() {\n return {\n x: 0,\n y: 0,\n width: 120,\n height: 80,\n angle: 0,\n fontSize: 16,\n textAlign: 'center',\n textBaseline: 'middle',\n fill: '#000000',\n lineWidth: 2,\n ignoreBuf: true,\n stroke: false,\n shapePoints: [] as IPointLike[]\n };\n }\n\n init() {\n if (!this._graphic) {\n this._graphic = createText(\n this._transformAttributes({\n ...this.getInitialAttributes(),\n ...(this._character.spec.options?.graphic ?? {})\n })\n );\n this._graphic.name = `graphic-text-${this._character.id}`;\n this._character.getGraphicParent().add(this._graphic);\n }\n }\n\n applyLayoutData(w: Partial<IWidgetData>) {\n const { x, y, width, height, angle } = getLayoutFromWidget(w);\n this._graphic.setAttributes(\n this._transformAttributes({\n x,\n y,\n angle,\n width,\n height,\n maxLineWidth: width,\n heightLimit: height\n })\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character/component/graphic/text.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAc,MAAM,mBAAmB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,qBAAqB,GAAG;IAC5B,MAAM;IACN,QAAQ;IACR,UAAU;IACV,YAAY;IACZ,WAAW;IACX,YAAY;IACZ,WAAW;IACX,SAAS;IACT,aAAa;IACb,eAAe;CAChB,CAAC;AAEF,MAAM,OAAO,WAAY,SAAQ,OAAO;IAGtC,oBAAoB;QAClB,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,EAAE;YACV,KAAK,EAAE,CAAC;YACR,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,QAAQ;YACtB,IAAI,EAAE,SAAS;YACf,SAAS,EAAE,CAAC;YACZ,SAAS,EAAE,IAAI;YACf,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,EAAkB;SAChC,CAAC;IACJ,CAAC;IAED,kCAAkC;;QAChC,MAAM,QAAQ,GAAG,CAAC,MAAA,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,0CAAE,OAAO,mCAAI,EAAE,CAA8B,CAAC;QAC5F,IAAI,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC;QAGrC,IAAI,CAAC,CAAC,UAAU,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,IAAI,EAAE;YACvD,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAChF,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;gBACpC,OAAO;oBACL,SAAS,EAAE,QAAQ,CAAC,SAAS;oBAC7B,YAAY,EAAE,QAAQ,CAAC,YAAY;oBAEnC,IAAI,EAAE,IAAI,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;iBACnD,CAAC;YACJ,CAAC,CAAC,CAAC;SACJ;QAED,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,IAAI;;QACF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,cAAc,CAC5B,IAAI,CAAC,oBAAoB,+CACpB,IAAI,CAAC,oBAAoB,EAAE,GAC3B,CAAC,MAAA,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,0CAAE,OAAO,mCAAI,EAAE,CAAC,KAChD,UAAU,EAAE,IAAI,CAAC,kCAAkC,EAAE,IACrD,CACH,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,gBAAgB,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;YAC1D,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvD;IACH,CAAC;IAED,eAAe,CAAC,CAAuB;QACrC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CACzB,IAAI,CAAC,oBAAoB,CAAC;YACxB,CAAC;YACD,CAAC;YACD,KAAK;YACL,KAAK;YACL,MAAM;YACN,YAAY,EAAE,KAAK;YACnB,WAAW,EAAE,MAAM;SACpB,CAAC,CACH,CAAC;IACJ,CAAC;CACF","file":"text.js","sourcesContent":["import type { IRichText, IRichTextGraphicAttribute, IText } from '@visactor/vrender';\nimport { createRichText, createText } from '@visactor/vrender';\nimport type { IPointLike } from '@visactor/vutils';\nimport { Graphic } from './graphic';\nimport type { IWidgetData } from '../../dsl-interface';\nimport { getLayoutFromWidget } from '../../../utils/layout';\n\nconst richtextCombinedAttrs = [\n 'fill',\n 'stroke',\n 'fontSize',\n 'fontFamily',\n 'fontStyle',\n 'fontWeight',\n 'lineWidth',\n 'opacity',\n 'fillOpacity',\n 'strokeOpacity'\n];\n\nexport class GraphicText extends Graphic {\n protected _graphic: IRichText;\n\n getInitialAttributes() {\n return {\n x: 0,\n y: 0,\n width: 120,\n height: 80,\n angle: 0,\n fontSize: 16,\n textAlign: 'center',\n textBaseline: 'middle',\n fill: '#000000',\n lineWidth: 2,\n ignoreBuf: true,\n stroke: false,\n shapePoints: [] as IPointLike[]\n };\n }\n\n transformTextAttrsToRichTextConfig() {\n const textAttr = (this._character.spec.options?.graphic ?? {}) as IRichTextGraphicAttribute;\n let textConfig = textAttr.textConfig;\n\n // 如果是纯文本定义方式\n if (!(textConfig && textConfig.length) && textAttr.text) {\n const textList = Array.isArray(textAttr.text) ? textAttr.text : [textAttr.text];\n textConfig = textList.map((item, i) => {\n return {\n textAlign: textAttr.textAlign,\n textBaseline: textAttr.textBaseline,\n // ...((textAttr || {}) as any),\n text: item + (i < textList.length - 1 ? '\\n' : '')\n };\n });\n }\n\n return textConfig;\n }\n\n init() {\n if (!this._graphic) {\n this._graphic = createRichText(\n this._transformAttributes({\n ...this.getInitialAttributes(),\n ...(this._character.spec.options?.graphic ?? {}),\n textConfig: this.transformTextAttrsToRichTextConfig()\n })\n );\n this._graphic.name = `graphic-text-${this._character.id}`;\n this._character.getGraphicParent().add(this._graphic);\n }\n }\n\n applyLayoutData(w: Partial<IWidgetData>) {\n const { x, y, width, height, angle } = getLayoutFromWidget(w);\n this._graphic.setAttributes(\n this._transformAttributes({\n x,\n y,\n angle,\n width,\n height,\n maxLineWidth: width,\n heightLimit: height\n })\n );\n }\n}\n"]}
@@ -7,6 +7,12 @@ export declare class GraphicTimeline extends Graphic {
7
7
  x: number;
8
8
  y: number;
9
9
  clipRange: number;
10
+ activeSymbolStyle: {
11
+ size: number;
12
+ };
13
+ activeLineStyle: {
14
+ lineWidth: number;
15
+ };
10
16
  };
11
17
  init(): void;
12
18
  applyLayoutData(w: Partial<IWidgetData>): void;
@@ -9,7 +9,13 @@ export class GraphicTimeline extends Graphic {
9
9
  return {
10
10
  x: 0,
11
11
  y: 0,
12
- clipRange: 0
12
+ clipRange: 0,
13
+ activeSymbolStyle: {
14
+ size: 26
15
+ },
16
+ activeLineStyle: {
17
+ lineWidth: 1.5
18
+ }
13
19
  };
14
20
  }
15
21
  init() {
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/component/graphic/timeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAGxD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,OAAO,eAAgB,SAAQ,OAAO;IAG1C,oBAAoB;QAClB,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,SAAS,EAAE,CAAC;SACb,CAAC;IACJ,CAAC;IAED,IAAI;;QACF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAC1B,IAAI,CAAC,oBAAoB,iCACpB,IAAI,CAAC,oBAAoB,EAAE,GAC3B,CAAC,MAAA,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,0CAAE,OAAO,mCAAI,EAAE,CAAC,EAChD,CACH,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,YAAY,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;YACtD,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvD;IACH,CAAC;IAED,eAAe,CAAC,CAAuB;QACrC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CACzB,IAAI,CAAC,oBAAoB,CAAC;YACxB,CAAC;YACD,CAAC;YACD,KAAK;YACL,KAAK;YACL,MAAM;SACP,CAAC,CACH,CAAC;IACJ,CAAC;CACF","file":"timeline.js","sourcesContent":["import { Timeline } from '@visactor/vrender-components';\nimport { createText } from '@visactor/vrender';\nimport type { IPointLike } from '@visactor/vutils';\nimport { Graphic } from './graphic';\nimport type { IWidgetData } from '../../dsl-interface';\nimport { getLayoutFromWidget } from '../../../utils/layout';\n\nexport class GraphicTimeline extends Graphic {\n protected _graphic: Timeline;\n\n getInitialAttributes() {\n return {\n x: 0,\n y: 0,\n clipRange: 0\n };\n }\n\n init() {\n if (!this._graphic) {\n this._graphic = new Timeline(\n this._transformAttributes({\n ...this.getInitialAttributes(),\n ...(this._character.spec.options?.graphic ?? {})\n })\n );\n this._graphic.name = `timeline-${this._character.id}`;\n this._character.getGraphicParent().add(this._graphic);\n }\n }\n\n applyLayoutData(w: Partial<IWidgetData>) {\n const { x, y, width, height, angle } = getLayoutFromWidget(w);\n this._graphic.setAttributes(\n this._transformAttributes({\n x,\n y,\n angle,\n width,\n height\n })\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character/component/graphic/timeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAGxD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,OAAO,eAAgB,SAAQ,OAAO;IAG1C,oBAAoB;QAClB,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,SAAS,EAAE,CAAC;YACZ,iBAAiB,EAAE;gBACjB,IAAI,EAAE,EAAE;aACT;YACD,eAAe,EAAE;gBACf,SAAS,EAAE,GAAG;aACf;SACF,CAAC;IACJ,CAAC;IAED,IAAI;;QACF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAC1B,IAAI,CAAC,oBAAoB,iCACpB,IAAI,CAAC,oBAAoB,EAAE,GAC3B,CAAC,MAAA,MAAA,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,0CAAE,OAAO,mCAAI,EAAE,CAAC,EAChD,CACH,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,YAAY,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;YACtD,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACvD;IACH,CAAC;IAED,eAAe,CAAC,CAAuB;QACrC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,QAAQ,CAAC,aAAa,CACzB,IAAI,CAAC,oBAAoB,CAAC;YACxB,CAAC;YACD,CAAC;YACD,KAAK;YACL,KAAK;YACL,MAAM;SACP,CAAC,CACH,CAAC;IACJ,CAAC;CACF","file":"timeline.js","sourcesContent":["import { Timeline } from '@visactor/vrender-components';\nimport { createText } from '@visactor/vrender';\nimport type { IPointLike } from '@visactor/vutils';\nimport { Graphic } from './graphic';\nimport type { IWidgetData } from '../../dsl-interface';\nimport { getLayoutFromWidget } from '../../../utils/layout';\n\nexport class GraphicTimeline extends Graphic {\n protected _graphic: Timeline;\n\n getInitialAttributes() {\n return {\n x: 0,\n y: 0,\n clipRange: 0,\n activeSymbolStyle: {\n size: 26\n },\n activeLineStyle: {\n lineWidth: 1.5\n }\n };\n }\n\n init() {\n if (!this._graphic) {\n this._graphic = new Timeline(\n this._transformAttributes({\n ...this.getInitialAttributes(),\n ...(this._character.spec.options?.graphic ?? {})\n })\n );\n this._graphic.name = `timeline-${this._character.id}`;\n this._character.getGraphicParent().add(this._graphic);\n }\n }\n\n applyLayoutData(w: Partial<IWidgetData>) {\n const { x, y, width, height, angle } = getLayoutFromWidget(w);\n this._graphic.setAttributes(\n this._transformAttributes({\n x,\n y,\n angle,\n width,\n height\n })\n );\n }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import type { ITextGraphicAttribute } from '@visactor/vrender';
1
+ import type { IRichTextGraphicAttribute, ITextGraphicAttribute } from '@visactor/vrender';
2
2
  import type { DirectionType } from './chart/const';
3
3
  export type IPercent = `${number}%`;
4
4
  export type WidgetNumber = number;
@@ -21,7 +21,7 @@ export interface ICharacterSpecBase {
21
21
  export type IEditorTextGraphicAttribute = {
22
22
  graphicAlign?: 'left' | 'center' | 'right';
23
23
  graphicBaseline?: 'top' | 'middle' | 'bottom';
24
- } & ITextGraphicAttribute;
24
+ } & Partial<ITextGraphicAttribute & IRichTextGraphicAttribute>;
25
25
  export interface IComponentCharacterSpec extends ICharacterSpecBase {
26
26
  options: {
27
27
  graphic: any;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/dsl-interface.ts"],"names":[],"mappings":"","file":"dsl-interface.js","sourcesContent":["import type { ITextGraphicAttribute } from '@visactor/vrender';\nimport type { DirectionType } from './chart/const';\n\nexport type IPercent = `${number}%`;\nexport type WidgetNumber = number; // | IPercent;\n\nexport type IWidgetData = {\n left: WidgetNumber;\n top: WidgetNumber;\n} & (\n | {\n bottom: WidgetNumber;\n right: WidgetNumber;\n }\n | {\n width: WidgetNumber;\n height: WidgetNumber;\n }\n);\n\nexport interface ICharacterSpecBase {\n id: string;\n type: string; // 类型\n position: IWidgetData; // 定位描述\n zIndex: number;\n}\n\nexport type IEditorTextGraphicAttribute = {\n graphicAlign?: 'left' | 'center' | 'right';\n graphicBaseline?: 'top' | 'middle' | 'bottom';\n} & ITextGraphicAttribute;\n\nexport interface IComponentCharacterSpec extends ICharacterSpecBase {\n options: {\n graphic: any;\n text?: IEditorTextGraphicAttribute;\n isResized?: boolean;\n angle?: number;\n shapePoints?: any;\n };\n}\n\nexport interface IComponentMatch {\n usrId?: string;\n specIndex?: number | 'all'; // all 表示所有\n [key: string]: any;\n}\n\nexport interface IComponentSpec {\n specKey: string;\n matchInfo: IComponentMatch;\n spec: any;\n}\n\nexport interface IChartCharacterSpec extends ICharacterSpecBase {\n options: {\n // 图表spec\n spec?: any;\n panel?: any;\n // 各种图表配置属性\n theme?: any;\n // 数据源\n data?: any;\n // 内部模块布局信息\n padding?: any;\n // 标题\n title?: any;\n layout?: any;\n // 色板\n color?: string[];\n // 标注\n marker?: any;\n // mark单元素样式配置\n markStyle?: any[];\n // 组样式\n dataGroupSpec?: {\n [key: string]: any;\n };\n // 方向\n direction?: DirectionType;\n // 系列配置\n seriesSpec?: {\n matchInfo: IComponentMatch;\n spec: any;\n }[];\n // 模块 spec\n componentSpec?: IComponentSpec[];\n };\n}\n\nexport type ICharacterSpec = IChartCharacterSpec | IComponentCharacterSpec;\n"]}
1
+ {"version":3,"sources":["../src/story/character/dsl-interface.ts"],"names":[],"mappings":"","file":"dsl-interface.js","sourcesContent":["import type { IRichTextGraphicAttribute, ITextGraphicAttribute } from '@visactor/vrender';\nimport type { DirectionType } from './chart/const';\n\nexport type IPercent = `${number}%`;\nexport type WidgetNumber = number; // | IPercent;\n\nexport type IWidgetData = {\n left: WidgetNumber;\n top: WidgetNumber;\n} & (\n | {\n bottom: WidgetNumber;\n right: WidgetNumber;\n }\n | {\n width: WidgetNumber;\n height: WidgetNumber;\n }\n);\n\nexport interface ICharacterSpecBase {\n id: string;\n type: string; // 类型\n position: IWidgetData; // 定位描述\n zIndex: number;\n}\n\nexport type IEditorTextGraphicAttribute = {\n graphicAlign?: 'left' | 'center' | 'right';\n graphicBaseline?: 'top' | 'middle' | 'bottom';\n} & Partial<ITextGraphicAttribute & IRichTextGraphicAttribute>;\n\nexport interface IComponentCharacterSpec extends ICharacterSpecBase {\n options: {\n graphic: any;\n text?: IEditorTextGraphicAttribute;\n isResized?: boolean;\n angle?: number;\n shapePoints?: any;\n };\n}\n\nexport interface IComponentMatch {\n usrId?: string;\n specIndex?: number | 'all'; // all 表示所有\n [key: string]: any;\n}\n\nexport interface IComponentSpec {\n specKey: string;\n matchInfo: IComponentMatch;\n spec: any;\n}\n\nexport interface IChartCharacterSpec extends ICharacterSpecBase {\n options: {\n // 图表spec\n spec?: any;\n panel?: any;\n // 各种图表配置属性\n theme?: any;\n // 数据源\n data?: any;\n // 内部模块布局信息\n padding?: any;\n // 标题\n title?: any;\n layout?: any;\n // 色板\n color?: string[];\n // 标注\n marker?: any;\n // mark单元素样式配置\n markStyle?: any[];\n // 组样式\n dataGroupSpec?: {\n [key: string]: any;\n };\n // 方向\n direction?: DirectionType;\n // 系列配置\n seriesSpec?: {\n matchInfo: IComponentMatch;\n spec: any;\n }[];\n // 模块 spec\n componentSpec?: IComponentSpec[];\n };\n}\n\nexport type ICharacterSpec = IChartCharacterSpec | IComponentCharacterSpec;\n"]}
@@ -20,6 +20,7 @@ export interface ICharacter {
20
20
  checkEvent: (event: StoryEvent) => false | (ICharacterPickInfo & any);
21
21
  updateSpec: (spec: Omit<Partial<ICharacterSpec>, 'id' | 'type'>) => void;
22
22
  setAttributes: (attr: Record<string, any>) => void;
23
+ release: () => void;
23
24
  }
24
25
  export interface ICharacterInitOption {
25
26
  story: IStory;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/runtime-interface.ts"],"names":[],"mappings":"","file":"runtime-interface.js","sourcesContent":["import type { IGroup } from '@visactor/vrender';\nimport type { IPointLike } from '@visactor/vutils';\nimport type { StoryCanvas } from '../canvas/canvas';\nimport type { IStory, IStoryCanvas, StoryEvent } from '../interface/runtime-interface';\nimport type { ICharacterSpec } from './dsl-interface';\nimport type { Graphic } from './component/graphic/graphic';\n\nexport interface ICharacterPickInfo {\n part: string;\n graphicType: string;\n}\nexport interface ICharacter {\n id: string;\n spec: ICharacterSpec;\n\n init: () => void;\n reset: () => void;\n show: () => void;\n hide: () => void;\n getGraphicParent: () => IGroup;\n graphic: Graphic | IGroup;\n tickTo: (t: number) => void;\n\n checkEvent: (event: StoryEvent) => false | (ICharacterPickInfo & any);\n\n updateSpec: (spec: Omit<Partial<ICharacterSpec>, 'id' | 'type'>) => void;\n\n setAttributes: (attr: Record<string, any>) => void;\n}\n\nexport interface ICharacterInitOption {\n story: IStory;\n canvas: IStoryCanvas;\n graphicParent: IGroup;\n}\n\nexport interface ICharacterConstructor {\n new (spec: ICharacterSpec, option: ICharacterInitOption): ICharacter;\n}\n\nexport interface ILayoutAttribute {\n x: number;\n y: number;\n width: number;\n height: number;\n angle: number;\n anchor?: [number | string, number | string];\n dx?: number;\n dy?: number;\n shapePoints?: IPointLike[];\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character/runtime-interface.ts"],"names":[],"mappings":"","file":"runtime-interface.js","sourcesContent":["import type { IGroup } from '@visactor/vrender';\nimport type { IPointLike } from '@visactor/vutils';\nimport type { StoryCanvas } from '../canvas/canvas';\nimport type { IStory, IStoryCanvas, StoryEvent } from '../interface/runtime-interface';\nimport type { ICharacterSpec } from './dsl-interface';\nimport type { Graphic } from './component/graphic/graphic';\n\nexport interface ICharacterPickInfo {\n part: string;\n graphicType: string;\n}\nexport interface ICharacter {\n id: string;\n spec: ICharacterSpec;\n\n init: () => void;\n reset: () => void;\n show: () => void;\n hide: () => void;\n getGraphicParent: () => IGroup;\n graphic: Graphic | IGroup;\n tickTo: (t: number) => void;\n\n checkEvent: (event: StoryEvent) => false | (ICharacterPickInfo & any);\n\n updateSpec: (spec: Omit<Partial<ICharacterSpec>, 'id' | 'type'>) => void;\n\n setAttributes: (attr: Record<string, any>) => void;\n release: () => void;\n}\n\nexport interface ICharacterInitOption {\n story: IStory;\n canvas: IStoryCanvas;\n graphicParent: IGroup;\n}\n\nexport interface ICharacterConstructor {\n new (spec: ICharacterSpec, option: ICharacterInitOption): ICharacter;\n}\n\nexport interface ILayoutAttribute {\n x: number;\n y: number;\n width: number;\n height: number;\n angle: number;\n anchor?: [number | string, number | string];\n dx?: number;\n dy?: number;\n shapePoints?: IPointLike[];\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { ICharacterSpec } from 'src/story/character/dsl-interface';
2
2
  import { CharacterBase } from '../base/base';
3
- import type { ISpecProcess, ICharacterVisactor, IVisactorGraphic } from './interface';
3
+ import type { ISpecProcess, ICharacterVisactor } from './interface';
4
4
  import { ICharacterInitOption } from '../runtime-interface';
5
5
  import { IChartCharacterRuntime } from '../chart/runtime/interface';
6
6
  export declare abstract class CharacterVisactor extends CharacterBase implements ICharacterVisactor {
@@ -9,7 +9,6 @@ export declare abstract class CharacterVisactor extends CharacterBase implements
9
9
  get dataTempTransform(): import("./interface").IDataTempTransform;
10
10
  get chartType(): string;
11
11
  get tempType(): string;
12
- protected _graphic: IVisactorGraphic;
13
12
  protected _runtime: IChartCharacterRuntime[];
14
13
  constructor(spec: ICharacterSpec, option: ICharacterInitOption);
15
14
  protected _initRuntime(): void;
@@ -24,7 +23,7 @@ export declare abstract class CharacterVisactor extends CharacterBase implements
24
23
  protected abstract _updateVisactorSpec(): void;
25
24
  show(): void;
26
25
  hide(): void;
27
- getGraphicParent(): IVisactorGraphic;
26
+ getGraphicParent(): any;
28
27
  tickTo(t: number): void;
29
28
  release(): void;
30
29
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/visactor/character.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAK7C,MAAM,OAAgB,iBAAkB,SAAQ,aAAa;IAE3D,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC;IAC7C,CAAC;IAED,IAAI,SAAS;;QACX,OAAO,MAAA,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,0CAAE,YAAY,EAAE,CAAC;IACtE,CAAC;IAED,IAAI,QAAQ;;QACV,OAAO,MAAA,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,0CAAE,IAAI,CAAC;IAC5D,CAAC;IAMD,YAAY,IAAoB,EAAE,MAA4B;QAC5D,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAHZ,aAAQ,GAA6B,EAAE,CAAC;QAelD,gBAAW,GAAG,GAAG,EAAE;;YACjB,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,WAAW,iDAAI,CAAA,EAAA,CAAC,CAAC;YAC9C,MAAA,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,0CAAE,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACpH,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC;QAjBA,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAES,YAAY,KAAU,CAAC;IAEjC,WAAW,CAAC,GAAqD;IAEjE,CAAC;IAgBD,IAAI;QACF,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;IACjD,CAAC;IACD,IAAI;QACF,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAClD,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,CAAS;QACd,OAAO;IACT,CAAC;IAED,OAAO;;QACL,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,MAAM,0CAAE,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC3C,CAAC;CACF","file":"character.js","sourcesContent":["/* eslint-disable no-console */\nimport { ICharacterSpec } from 'src/story/character/dsl-interface';\nimport { CharacterBase } from '../base/base';\nimport type { ISpecProcess, ICharacterVisactor, IVisactorGraphic } from './interface';\nimport { ICharacterInitOption } from '../runtime-interface';\nimport { IChartCharacterRuntime } from '../chart/runtime/interface';\n\nexport abstract class CharacterVisactor extends CharacterBase implements ICharacterVisactor {\n protected declare _specProcess: ISpecProcess;\n get specProcess() {\n return this._specProcess;\n }\n get dataTempTransform() {\n return this._specProcess.dataTempTransform;\n }\n\n get chartType() {\n return this._specProcess.dataTempTransform.specTemp?.getChartType();\n }\n\n get tempType() {\n return this._specProcess.dataTempTransform.specTemp?.type;\n }\n\n protected declare _graphic: IVisactorGraphic;\n\n protected _runtime: IChartCharacterRuntime[] = [];\n\n constructor(spec: ICharacterSpec, option: ICharacterInitOption) {\n super(spec, option);\n this._initSpecProcess();\n }\n\n protected _initRuntime(): void {}\n\n clearConfig(opt: { clearCurrent: false | { [key: string]: any } }) {\n // do nothing\n }\n\n protected abstract _initSpecProcess(): void;\n\n onSpecReady = () => {\n console.log('onSpecReady !');\n this._runtime.forEach(r => r.onSpecReady?.());\n this._specProcess.dataTempTransform.specTemp?.standardizedSpec(this._specProcess.getVisSpec(), { character: this });\n this._updateVisactorSpec();\n this._afterRender();\n };\n\n protected abstract _afterRender(): void;\n\n protected abstract _updateVisactorSpec(): void;\n\n show(): void {\n this._graphic.setAttribute('visibleAll', true);\n }\n hide(): void {\n this._graphic.setAttribute('visibleAll', false);\n }\n\n getGraphicParent() {\n return this._graphic;\n }\n\n tickTo(t: number): void {\n return;\n }\n\n release() {\n this._specProcess.release();\n this._graphic?.parent?.removeChild(this._graphic);\n this._specProcess = this._graphic = null;\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character/visactor/character.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAK7C,MAAM,OAAgB,iBAAkB,SAAQ,aAAa;IAE3D,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC;IAC7C,CAAC;IAED,IAAI,SAAS;;QACX,OAAO,MAAA,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,0CAAE,YAAY,EAAE,CAAC;IACtE,CAAC;IAED,IAAI,QAAQ;;QACV,OAAO,MAAA,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,0CAAE,IAAI,CAAC;IAC5D,CAAC;IAID,YAAY,IAAoB,EAAE,MAA4B;QAC5D,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAHZ,aAAQ,GAA6B,EAAE,CAAC;QAelD,gBAAW,GAAG,GAAG,EAAE;;YACjB,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,WAAC,OAAA,MAAA,CAAC,CAAC,WAAW,iDAAI,CAAA,EAAA,CAAC,CAAC;YAC9C,MAAA,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,0CAAE,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACpH,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC;QAjBA,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAES,YAAY,KAAU,CAAC;IAEjC,WAAW,CAAC,GAAqD;IAEjE,CAAC;IAgBD,IAAI;QACF,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;IACjD,CAAC;IACD,IAAI;QACF,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAClD,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,CAAS;QACd,OAAO;IACT,CAAC;IAED,OAAO;;QACL,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,MAAM,0CAAE,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC3C,CAAC;CACF","file":"character.js","sourcesContent":["/* eslint-disable no-console */\nimport { ICharacterSpec } from 'src/story/character/dsl-interface';\nimport { CharacterBase } from '../base/base';\nimport type { ISpecProcess, ICharacterVisactor, IVisactorGraphic } from './interface';\nimport { ICharacterInitOption } from '../runtime-interface';\nimport { IChartCharacterRuntime } from '../chart/runtime/interface';\n\nexport abstract class CharacterVisactor extends CharacterBase implements ICharacterVisactor {\n protected declare _specProcess: ISpecProcess;\n get specProcess() {\n return this._specProcess;\n }\n get dataTempTransform() {\n return this._specProcess.dataTempTransform;\n }\n\n get chartType() {\n return this._specProcess.dataTempTransform.specTemp?.getChartType();\n }\n\n get tempType() {\n return this._specProcess.dataTempTransform.specTemp?.type;\n }\n\n protected _runtime: IChartCharacterRuntime[] = [];\n\n constructor(spec: ICharacterSpec, option: ICharacterInitOption) {\n super(spec, option);\n this._initSpecProcess();\n }\n\n protected _initRuntime(): void {}\n\n clearConfig(opt: { clearCurrent: false | { [key: string]: any } }) {\n // do nothing\n }\n\n protected abstract _initSpecProcess(): void;\n\n onSpecReady = () => {\n console.log('onSpecReady !');\n this._runtime.forEach(r => r.onSpecReady?.());\n this._specProcess.dataTempTransform.specTemp?.standardizedSpec(this._specProcess.getVisSpec(), { character: this });\n this._updateVisactorSpec();\n this._afterRender();\n };\n\n protected abstract _afterRender(): void;\n\n protected abstract _updateVisactorSpec(): void;\n\n show(): void {\n this._graphic.setAttribute('visibleAll', true);\n }\n hide(): void {\n this._graphic.setAttribute('visibleAll', false);\n }\n\n getGraphicParent() {\n return this._graphic;\n }\n\n tickTo(t: number): void {\n return;\n }\n\n release() {\n this._specProcess.release();\n this._graphic?.parent?.removeChild(this._graphic);\n this._specProcess = this._graphic = null;\n }\n}\n"]}
@@ -84,6 +84,7 @@ export interface IVisactorTempConstructor {
84
84
  export interface IVisactorGraphic extends IGroup {
85
85
  readonly vProduct: IVChart;
86
86
  updateSpec: (spec: any) => void;
87
+ release: () => void;
87
88
  }
88
89
  export interface ICharacterVisactor extends ICharacter {
89
90
  clearConfig: (opt: {
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character/visactor/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["import type { IChartCharacterSpec } from '../dsl-interface';\nimport type { EventEmitter } from '@visactor/vutils';\nimport type { ICharacter } from '../runtime-interface';\nimport type { ISpec, IVChart } from '@visactor/vchart';\nimport type { IGroup } from '@visactor/vrender';\n\nexport type StandardData = IDataValue | IDataValue[];\nexport type IParserValue = any;\nexport type DataUpdateCall = (data: StandardData) => void;\nexport type DataErrorCall = (msg: { type: string; info: string }, opt?: any) => void;\n\n// visactor 元素的内部结构\n// 数据部分 start\n// DataParser:数据处理。负责解析数据,得到模版可用数据,处理数据上的特性内容。\n// VisactorTemp:模版处理。负责结合数据,生成对应类型的基础 spec。不同类型图表的特殊逻辑,在 temp 中处理\n// DataTempTransform:数据与模版更新管理,当数据/模版更新时,通过这个模块判定更新是否成功,成功后抛出更新成功消息。包含 VisactorTemp 与 DataParser\n// SpecProcess:编辑配置管理器,编辑属性更新的处理,对外输出合并了编辑信息的 spec 。包含一个 dataTempTransform\n// 数据部分 end\n\n// graphic 部分 start\n// IVisactorGraphic:包含一个 vchart|vtbale 。visactor 的自定义图元封装。处理图元是否重绘,viewBox的图元属性逻辑\n// IVisactorGraphic-render:实际的 draw 入口,处理绘图过程,主要是处理变换矩阵。\n// graphic 部分 end\n\n// Visactor-role:编辑元素,包含一个 specProcess、IVisactorGraphic\n\nexport interface IDataTempTransform {\n readonly specTemp: IVisactorTemp;\n\n readonly nextTemp: IVisactorTemp;\n emitter: EventEmitter;\n\n updateChartTemp: (temp?: string) => void;\n\n // 得到没有经过编辑器配置加工过的基础spec\n getBaseSpec: () => any;\n\n // 释放\n release: () => void;\n\n dataParser?: IDataParser;\n}\n\nexport interface IDataTempTransformConstructor {\n new ({ specProcess, character }: { character: ICharacterVisactor; specProcess: ISpecProcess }): IDataTempTransform;\n}\n\nexport interface ISpecProcess {\n dataTempTransform: IDataTempTransform;\n emitter: EventEmitter;\n\n // 得到visactor元素的spec\n getVisSpec: () => ISpec;\n // 得到角色的spec\n getCharacterSpec: () => IChartCharacterSpec;\n\n // temp\n getCharacterType: () => string;\n\n release: () => void;\n}\n\nexport type IDataType = any;\n\nexport interface IDataValue {\n id: string;\n sourceKey: string;\n values: IDataType[];\n}\n\nexport type DataInfo = {\n [key: string]: {\n type: 'ordinal' | 'linear';\n };\n};\n\nexport type DataSave = {\n type: string;\n value: any;\n};\n\nexport interface IDataParser {\n type: string;\n getData: () => StandardData;\n getDataValue: () => IParserValue;\n getDataInfo?: () => DataInfo;\n getSpecOption?: () => any;\n getSave: () => DataSave;\n updateValue: (value: IParserValue) => void;\n setDataUpdateHandler: (call: DataUpdateCall) => void;\n setDataErrorHandler: (call: DataErrorCall) => void;\n clear: () => void;\n}\n\nexport interface IDataParserConstructor {\n type: string;\n new (\n value: any,\n option: {\n updateCall: DataUpdateCall;\n errorCall: DataErrorCall;\n currentData?: IDataParser;\n emitter: EventEmitter;\n }\n ): IDataParser;\n}\n\n// chart & table 都是用这个模版接口\nexport interface IVisactorTemp {\n type: string;\n getSpec: (data: StandardData, ctx: any, opt?: any) => ISpec | null;\n standardizedSpec: (spec: any, ctx: any, opt?: any) => void;\n getChartType: () => string;\n checkDataEnable: (data: StandardData, opt?: any) => boolean;\n getTempInfo?: () => any;\n clear: () => void;\n}\n\nexport interface IVisactorTempConstructor {\n new (): IVisactorTemp;\n}\n\n// 绘图元素\nexport interface IVisactorGraphic extends IGroup {\n readonly vProduct: IVChart;\n\n updateSpec: (spec: any) => void;\n}\n\n// 编辑元素\nexport interface ICharacterVisactor extends ICharacter {\n // 清除编辑数据\n clearConfig: (opt: { clearCurrent: false | { [key: string]: any } }) => void;\n getGraphicParent: () => IVisactorGraphic;\n}\n\nexport interface IUpdateAttributeOption {\n triggerHistory?: boolean;\n saveData?: boolean;\n actionType?: 'data-add' | 'data-change' | 'data-replace' | string;\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character/visactor/interface.ts"],"names":[],"mappings":"","file":"interface.js","sourcesContent":["import type { IChartCharacterSpec } from '../dsl-interface';\nimport type { EventEmitter } from '@visactor/vutils';\nimport type { ICharacter } from '../runtime-interface';\nimport type { ISpec, IVChart } from '@visactor/vchart';\nimport type { IGroup } from '@visactor/vrender';\n\nexport type StandardData = IDataValue | IDataValue[];\nexport type IParserValue = any;\nexport type DataUpdateCall = (data: StandardData) => void;\nexport type DataErrorCall = (msg: { type: string; info: string }, opt?: any) => void;\n\n// visactor 元素的内部结构\n// 数据部分 start\n// DataParser:数据处理。负责解析数据,得到模版可用数据,处理数据上的特性内容。\n// VisactorTemp:模版处理。负责结合数据,生成对应类型的基础 spec。不同类型图表的特殊逻辑,在 temp 中处理\n// DataTempTransform:数据与模版更新管理,当数据/模版更新时,通过这个模块判定更新是否成功,成功后抛出更新成功消息。包含 VisactorTemp 与 DataParser\n// SpecProcess:编辑配置管理器,编辑属性更新的处理,对外输出合并了编辑信息的 spec 。包含一个 dataTempTransform\n// 数据部分 end\n\n// graphic 部分 start\n// IVisactorGraphic:包含一个 vchart|vtbale 。visactor 的自定义图元封装。处理图元是否重绘,viewBox的图元属性逻辑\n// IVisactorGraphic-render:实际的 draw 入口,处理绘图过程,主要是处理变换矩阵。\n// graphic 部分 end\n\n// Visactor-role:编辑元素,包含一个 specProcess、IVisactorGraphic\n\nexport interface IDataTempTransform {\n readonly specTemp: IVisactorTemp;\n\n readonly nextTemp: IVisactorTemp;\n emitter: EventEmitter;\n\n updateChartTemp: (temp?: string) => void;\n\n // 得到没有经过编辑器配置加工过的基础spec\n getBaseSpec: () => any;\n\n // 释放\n release: () => void;\n\n dataParser?: IDataParser;\n}\n\nexport interface IDataTempTransformConstructor {\n new ({ specProcess, character }: { character: ICharacterVisactor; specProcess: ISpecProcess }): IDataTempTransform;\n}\n\nexport interface ISpecProcess {\n dataTempTransform: IDataTempTransform;\n emitter: EventEmitter;\n\n // 得到visactor元素的spec\n getVisSpec: () => ISpec;\n // 得到角色的spec\n getCharacterSpec: () => IChartCharacterSpec;\n\n // temp\n getCharacterType: () => string;\n\n release: () => void;\n}\n\nexport type IDataType = any;\n\nexport interface IDataValue {\n id: string;\n sourceKey: string;\n values: IDataType[];\n}\n\nexport type DataInfo = {\n [key: string]: {\n type: 'ordinal' | 'linear';\n };\n};\n\nexport type DataSave = {\n type: string;\n value: any;\n};\n\nexport interface IDataParser {\n type: string;\n getData: () => StandardData;\n getDataValue: () => IParserValue;\n getDataInfo?: () => DataInfo;\n getSpecOption?: () => any;\n getSave: () => DataSave;\n updateValue: (value: IParserValue) => void;\n setDataUpdateHandler: (call: DataUpdateCall) => void;\n setDataErrorHandler: (call: DataErrorCall) => void;\n clear: () => void;\n}\n\nexport interface IDataParserConstructor {\n type: string;\n new (\n value: any,\n option: {\n updateCall: DataUpdateCall;\n errorCall: DataErrorCall;\n currentData?: IDataParser;\n emitter: EventEmitter;\n }\n ): IDataParser;\n}\n\n// chart & table 都是用这个模版接口\nexport interface IVisactorTemp {\n type: string;\n getSpec: (data: StandardData, ctx: any, opt?: any) => ISpec | null;\n standardizedSpec: (spec: any, ctx: any, opt?: any) => void;\n getChartType: () => string;\n checkDataEnable: (data: StandardData, opt?: any) => boolean;\n getTempInfo?: () => any;\n clear: () => void;\n}\n\nexport interface IVisactorTempConstructor {\n new (): IVisactorTemp;\n}\n\n// 绘图元素\nexport interface IVisactorGraphic extends IGroup {\n readonly vProduct: IVChart;\n\n updateSpec: (spec: any) => void;\n release: () => void;\n}\n\n// 编辑元素\nexport interface ICharacterVisactor extends ICharacter {\n // 清除编辑数据\n clearConfig: (opt: { clearCurrent: false | { [key: string]: any } }) => void;\n getGraphicParent: () => IVisactorGraphic;\n}\n\nexport interface IUpdateAttributeOption {\n triggerHistory?: boolean;\n saveData?: boolean;\n actionType?: 'data-add' | 'data-change' | 'data-replace' | string;\n}\n"]}
@@ -12,4 +12,5 @@ export declare class CharacterTree implements ICharacterTree {
12
12
  getCharactersById(key: string): ICharacter;
13
13
  addCharacter(spec: ICharacterSpec): ICharacter;
14
14
  initCharacters(specs: ICharacterSpec[]): void;
15
+ releaseOldCharacters(): void;
15
16
  }
@@ -20,6 +20,7 @@ export class CharacterTree {
20
20
  this._characters[spec.id]) : null;
21
21
  }
22
22
  initCharacters(specs) {
23
+ this.releaseOldCharacters(), this._characters = {};
23
24
  const option = {
24
25
  story: this._story,
25
26
  canvas: this._story.canvas,
@@ -29,5 +30,10 @@ export class CharacterTree {
29
30
  spec.id && (this._characters[spec.id] || (this._characters[spec.id] = StoryFactory.createCharacter(spec, option)));
30
31
  }));
31
32
  }
33
+ releaseOldCharacters() {
34
+ Object.keys(this._characters).forEach((k => {
35
+ this._characters[k].release();
36
+ }));
37
+ }
32
38
  }
33
39
  //# sourceMappingURL=character-tree.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/character-tree/character-tree.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAGlD,MAAM,OAAO,aAAa;IAIxB,YAAY,KAAa;QAHf,gBAAW,GAAkC,EAAE,CAAC;QAIxD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,iBAAiB,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,IAAoB;QAC/B,MAAM,MAAM,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;YAC1B,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,YAAY;SAC1D,CAAC;QACF,IAAqB,IAAK,CAAC,EAAE,EAAE;YAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,EAAE;gBAChD,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,eAAe,CAAiB,IAAI,EAAE,MAAM,CAAC,CAAC;aAC1G;YACD,OAAO,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,CAAC;SACpD;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,cAAc,CAAC,KAAuB;QACpC,MAAM,MAAM,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;YAC1B,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,YAAY;SAC1D,CAAC;QAEF,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,IAAqB,IAAK,CAAC,EAAE,EAAE;gBAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,EAAE;oBAChD,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,eAAe,CAAiB,IAAI,EAAE,MAAM,CAAC,CAAC;iBAC1G;aAEF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;CACF","file":"character-tree.js","sourcesContent":["import type { ICharacter, ICharacterSpec } from '../character';\nimport { StoryFactory } from '../factory/factory';\nimport type { ICharacterTree, IStory } from '../interface';\n\nexport class CharacterTree implements ICharacterTree {\n protected _characters: { [key: string]: ICharacter } = {};\n protected _story: IStory;\n\n constructor(story: IStory) {\n this._story = story;\n }\n\n getCharacters(): { [key: string]: ICharacter } {\n return this._characters;\n }\n\n getCharactersById(key: string) {\n return this._characters[key] || null;\n }\n\n addCharacter(spec: ICharacterSpec) {\n const option = {\n story: this._story,\n canvas: this._story.canvas,\n graphicParent: this._story.canvas.getStage().defaultLayer\n };\n if ((<ICharacterSpec>spec).id) {\n if (!this._characters[(<ICharacterSpec>spec).id]) {\n this._characters[(<ICharacterSpec>spec).id] = StoryFactory.createCharacter(<ICharacterSpec>spec, option);\n }\n return this._characters[(<ICharacterSpec>spec).id];\n }\n return null;\n }\n\n initCharacters(specs: ICharacterSpec[]): void {\n const option = {\n story: this._story,\n canvas: this._story.canvas,\n graphicParent: this._story.canvas.getStage().defaultLayer\n };\n\n specs.forEach(spec => {\n if ((<ICharacterSpec>spec).id) {\n if (!this._characters[(<ICharacterSpec>spec).id]) {\n this._characters[(<ICharacterSpec>spec).id] = StoryFactory.createCharacter(<ICharacterSpec>spec, option);\n }\n // return this._characters[(<ICharacterSpec>spec).id];\n }\n });\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/story/character-tree/character-tree.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAGlD,MAAM,OAAO,aAAa;IAIxB,YAAY,KAAa;QAHf,gBAAW,GAAkC,EAAE,CAAC;QAIxD,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,iBAAiB,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,IAAoB;QAC/B,MAAM,MAAM,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;YAC1B,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,YAAY;SAC1D,CAAC;QACF,IAAqB,IAAK,CAAC,EAAE,EAAE;YAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,EAAE;gBAChD,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,eAAe,CAAiB,IAAI,EAAE,MAAM,CAAC,CAAC;aAC1G;YACD,OAAO,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,CAAC;SACpD;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,cAAc,CAAC,KAAuB;QACpC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,MAAM,MAAM,GAAG;YACb,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;YAC1B,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,YAAY;SAC1D,CAAC;QAEF,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,IAAqB,IAAK,CAAC,EAAE,EAAE;gBAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,EAAE;oBAChD,IAAI,CAAC,WAAW,CAAkB,IAAK,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,eAAe,CAAiB,IAAI,EAAE,MAAM,CAAC,CAAC;iBAC1G;aAEF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB;QAClB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACxC,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC,CAAC,OAAO,EAAE,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;CACF","file":"character-tree.js","sourcesContent":["import type { ICharacter, ICharacterSpec } from '../character';\nimport { StoryFactory } from '../factory/factory';\nimport type { ICharacterTree, IStory } from '../interface';\n\nexport class CharacterTree implements ICharacterTree {\n protected _characters: { [key: string]: ICharacter } = {};\n protected _story: IStory;\n\n constructor(story: IStory) {\n this._story = story;\n }\n\n getCharacters(): { [key: string]: ICharacter } {\n return this._characters;\n }\n\n getCharactersById(key: string) {\n return this._characters[key] || null;\n }\n\n addCharacter(spec: ICharacterSpec) {\n const option = {\n story: this._story,\n canvas: this._story.canvas,\n graphicParent: this._story.canvas.getStage().defaultLayer\n };\n if ((<ICharacterSpec>spec).id) {\n if (!this._characters[(<ICharacterSpec>spec).id]) {\n this._characters[(<ICharacterSpec>spec).id] = StoryFactory.createCharacter(<ICharacterSpec>spec, option);\n }\n return this._characters[(<ICharacterSpec>spec).id];\n }\n return null;\n }\n\n initCharacters(specs: ICharacterSpec[]): void {\n this.releaseOldCharacters();\n this._characters = {};\n const option = {\n story: this._story,\n canvas: this._story.canvas,\n graphicParent: this._story.canvas.getStage().defaultLayer\n };\n\n specs.forEach(spec => {\n if ((<ICharacterSpec>spec).id) {\n if (!this._characters[(<ICharacterSpec>spec).id]) {\n this._characters[(<ICharacterSpec>spec).id] = StoryFactory.createCharacter(<ICharacterSpec>spec, option);\n }\n // return this._characters[(<ICharacterSpec>spec).id];\n }\n });\n }\n\n releaseOldCharacters() {\n Object.keys(this._characters).forEach(k => {\n const c = this._characters[k];\n c.release();\n });\n }\n}\n"]}
package/es/story/index.js CHANGED
@@ -12,8 +12,6 @@ import { ChartRender, VChartRender } from "./character/chart/graphic/vchart-grap
12
12
 
13
13
  import { CharacterComponentText } from "./character/component/characters/character-text";
14
14
 
15
- import { CharacterComponentRichText } from "./character/component/characters/character-richtext";
16
-
17
15
  import { VChartPicker } from "./character/chart/graphic/vchart-graphic-picker";
18
16
 
19
17
  import { StoryComponentType } from "../constants/character";
@@ -43,7 +41,6 @@ export function registerCharacter() {
43
41
  _register || (_register = !0, StoryFactory.registerCharacter(VChartCharacter.type, VChartCharacter),
44
42
  StoryFactory.registerCharacter(StoryComponentType.RECT, CharacterComponentRect),
45
43
  StoryFactory.registerCharacter(StoryComponentType.TEXT, CharacterComponentText),
46
- StoryFactory.registerCharacter(StoryComponentType.RICH_TEXT, CharacterComponentRichText),
47
44
  StoryFactory.registerCharacter(StoryComponentType.QIPAO, CharacterComponentQipao),
48
45
  StoryFactory.registerCharacter(StoryComponentType.LINE, CharacterComponentLine),
49
46
  StoryFactory.registerCharacter(StoryComponentType.IMAGE, CharacterComponentImage),
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAC;AAC5F,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AACjG,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AAC5G,OAAO,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AAEjG,MAAM,WAAW,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,EAAE;IAE7C,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAC/C,IAAI,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAC1C,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IAC3C,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,gBAAgB,EAAE,CAAC;IACvD,IAAI,CAAC,wBAAwB,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAGvD,IAAI,CAAC,oBAAoB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACvD,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;AACtD,CAAC,CAAC,CAAC;AAEH,IAAI,SAAS,GAAG,KAAK,CAAC;AACtB,MAAM,UAAU,iBAAiB;IAC/B,IAAI,SAAS,EAAE;QACb,OAAO;KACR;IACD,SAAS,GAAG,IAAI,CAAC;IACjB,YAAY,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;IAKtE,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAChF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAChF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,SAAS,EAAE,0BAA0B,CAAC,CAAC;IACzF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,CAAC,CAAC;IAClF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAChF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,CAAC,CAAC;IAClF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,CAAC,CAAC;IAClF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAC;IAExF,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;AAC9B,CAAC;AAED,iBAAiB,EAAE,CAAC;AAEpB,cAAc,SAAS,CAAC","file":"index.js","sourcesContent":["import { CharacterComponentQipao } from './character/component/characters/character-qipao';\nimport { CharacterComponentRect } from './character/component/characters/character-rect';\nimport { StoryFactory } from './factory/factory';\nimport { ContainerModule, GraphicRender, container } from '@visactor/vrender';\nimport { CanvasPickerContribution } from '@visactor/vrender';\nimport { ChartRender, VChartRender } from './character/chart/graphic/vchart-graphic-render';\nimport { CharacterComponentText } from './character/component/characters/character-text';\nimport { CharacterComponentRichText } from './character/component/characters/character-richtext';\nimport { VChartPicker } from './character/chart/graphic/vchart-graphic-picker';\nimport { StoryComponentType } from '../constants/character';\nimport { CharacterComponentLine } from './character/component/characters/character-line';\nimport { CharacterComponentImage } from './character/component/characters/character-image';\nimport { CharacterComponentShape } from './character/component/characters/character-shape';\nimport { VChartCharacter } from './character/chart/characters/vchart';\nimport { ComponentGroupRender } from './character/component/character-group/component-group-graphic-render';\nimport { CharacterComponentTimeline } from './character/component/characters/character-timeline';\n\nconst splitModule = new ContainerModule(bind => {\n // chart渲染器注入\n bind(VChartRender).toSelf().inSingletonScope();\n bind(ChartRender).toService(VChartRender);\n bind(GraphicRender).toService(ChartRender);\n bind(VChartPicker).to(VChartPicker).inSingletonScope();\n bind(CanvasPickerContribution).toService(VChartPicker);\n\n // component渲染器注入\n bind(ComponentGroupRender).toSelf().inSingletonScope();\n bind(GraphicRender).toService(ComponentGroupRender);\n});\n\nlet _register = false;\nexport function registerCharacter() {\n if (_register) {\n return;\n }\n _register = true;\n StoryFactory.registerCharacter(VChartCharacter.type, VChartCharacter);\n\n // StoryFactory.registerCharacter('BarChart', CharacterChart);\n // StoryFactory.registerCharacter('CharacterChart', CharacterChart);\n // StoryFactory.registerCharacter('LineChart', CharacterChart);\n StoryFactory.registerCharacter(StoryComponentType.RECT, CharacterComponentRect);\n StoryFactory.registerCharacter(StoryComponentType.TEXT, CharacterComponentText);\n StoryFactory.registerCharacter(StoryComponentType.RICH_TEXT, CharacterComponentRichText);\n StoryFactory.registerCharacter(StoryComponentType.QIPAO, CharacterComponentQipao);\n StoryFactory.registerCharacter(StoryComponentType.LINE, CharacterComponentLine);\n StoryFactory.registerCharacter(StoryComponentType.IMAGE, CharacterComponentImage);\n StoryFactory.registerCharacter(StoryComponentType.SHAPE, CharacterComponentShape);\n StoryFactory.registerCharacter(StoryComponentType.TIMELINE, CharacterComponentTimeline);\n\n container.load(splitModule);\n}\n\nregisterCharacter();\n\nexport * from './story';\n"]}
1
+ {"version":3,"sources":["../src/story/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAC;AAC5F,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AAEzF,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,iDAAiD,CAAC;AACzF,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,sEAAsE,CAAC;AAC5G,OAAO,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AAEjG,MAAM,WAAW,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,EAAE;IAE7C,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAC/C,IAAI,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAC1C,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IAC3C,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,gBAAgB,EAAE,CAAC;IACvD,IAAI,CAAC,wBAAwB,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAGvD,IAAI,CAAC,oBAAoB,CAAC,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAC;IACvD,IAAI,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;AACtD,CAAC,CAAC,CAAC;AAEH,IAAI,SAAS,GAAG,KAAK,CAAC;AACtB,MAAM,UAAU,iBAAiB;IAC/B,IAAI,SAAS,EAAE;QACb,OAAO;KACR;IACD,SAAS,GAAG,IAAI,CAAC;IACjB,YAAY,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;IAKtE,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAChF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAEhF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,CAAC,CAAC;IAClF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;IAChF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,CAAC,CAAC;IAClF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,CAAC,CAAC;IAClF,YAAY,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAC;IAExF,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;AAC9B,CAAC;AAED,iBAAiB,EAAE,CAAC;AAEpB,cAAc,SAAS,CAAC","file":"index.js","sourcesContent":["import { CharacterComponentQipao } from './character/component/characters/character-qipao';\nimport { CharacterComponentRect } from './character/component/characters/character-rect';\nimport { StoryFactory } from './factory/factory';\nimport { ContainerModule, GraphicRender, container } from '@visactor/vrender';\nimport { CanvasPickerContribution } from '@visactor/vrender';\nimport { ChartRender, VChartRender } from './character/chart/graphic/vchart-graphic-render';\nimport { CharacterComponentText } from './character/component/characters/character-text';\n// import { CharacterComponentRichText } from './character/component/characters/character-richtext';\nimport { VChartPicker } from './character/chart/graphic/vchart-graphic-picker';\nimport { StoryComponentType } from '../constants/character';\nimport { CharacterComponentLine } from './character/component/characters/character-line';\nimport { CharacterComponentImage } from './character/component/characters/character-image';\nimport { CharacterComponentShape } from './character/component/characters/character-shape';\nimport { VChartCharacter } from './character/chart/characters/vchart';\nimport { ComponentGroupRender } from './character/component/character-group/component-group-graphic-render';\nimport { CharacterComponentTimeline } from './character/component/characters/character-timeline';\n\nconst splitModule = new ContainerModule(bind => {\n // chart渲染器注入\n bind(VChartRender).toSelf().inSingletonScope();\n bind(ChartRender).toService(VChartRender);\n bind(GraphicRender).toService(ChartRender);\n bind(VChartPicker).to(VChartPicker).inSingletonScope();\n bind(CanvasPickerContribution).toService(VChartPicker);\n\n // component渲染器注入\n bind(ComponentGroupRender).toSelf().inSingletonScope();\n bind(GraphicRender).toService(ComponentGroupRender);\n});\n\nlet _register = false;\nexport function registerCharacter() {\n if (_register) {\n return;\n }\n _register = true;\n StoryFactory.registerCharacter(VChartCharacter.type, VChartCharacter);\n\n // StoryFactory.registerCharacter('BarChart', CharacterChart);\n // StoryFactory.registerCharacter('CharacterChart', CharacterChart);\n // StoryFactory.registerCharacter('LineChart', CharacterChart);\n StoryFactory.registerCharacter(StoryComponentType.RECT, CharacterComponentRect);\n StoryFactory.registerCharacter(StoryComponentType.TEXT, CharacterComponentText);\n // StoryFactory.registerCharacter(StoryComponentType.RICH_TEXT, CharacterComponentRichText);\n StoryFactory.registerCharacter(StoryComponentType.QIPAO, CharacterComponentQipao);\n StoryFactory.registerCharacter(StoryComponentType.LINE, CharacterComponentLine);\n StoryFactory.registerCharacter(StoryComponentType.IMAGE, CharacterComponentImage);\n StoryFactory.registerCharacter(StoryComponentType.SHAPE, CharacterComponentShape);\n StoryFactory.registerCharacter(StoryComponentType.TIMELINE, CharacterComponentTimeline);\n\n container.load(splitModule);\n}\n\nregisterCharacter();\n\nexport * from './story';\n"]}
@@ -1,18 +1,15 @@
1
- import type { Action } from '../../dsl/types';
1
+ import type { IChartAddAction, IChartUpdateAction } from '../../player/processor/chart/vchart';
2
+ import type { IChartVisibilityAction, IComponentVisibilityAction } from '../../player/processor/interface/appear-action';
3
+ import type { IComponentBounceAction, IComponentMoveToAction, IComponentScaleToAction, IComponentStyleAction } from '../../player/processor/interface/style-action';
2
4
  import type { ICharacterSpec } from '../character';
3
- export interface IAction {
4
- startTime?: number;
5
- action: string;
6
- duration?: number;
7
- payload?: Action['payload'];
8
- }
5
+ export type IActionSpec = IComponentStyleAction | IComponentVisibilityAction | IComponentMoveToAction | IComponentScaleToAction | IComponentBounceAction | IChartVisibilityAction | IChartUpdateAction | IChartAddAction;
9
6
  export interface IStorySpec {
10
7
  acts: IActSpec[];
11
8
  characters: ICharacterSpec[];
12
9
  }
13
10
  export interface IActionsLink {
14
11
  characterId: string;
15
- characterActions: IAction[];
12
+ characterActions: IActionSpec[];
16
13
  }
17
14
  export type ISceneSpec = {
18
15
  id: string;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/interface/dsl-interface.ts"],"names":[],"mappings":"","file":"dsl-interface.js","sourcesContent":["import type { Action } from '../../dsl/types';\nimport type { ICharacterSpec } from '../character';\n\nexport interface IAction {\n startTime?: number;\n action: string;\n duration?: number;\n payload?: Action['payload'];\n}\n\nexport interface IStorySpec {\n acts: IActSpec[]; // 作品的章节\n characters: ICharacterSpec[]; // 作品中的元素\n}\n\nexport interface IActionsLink {\n characterId: string;\n characterActions: IAction[];\n}\n\nexport type ISceneSpec = {\n id: string;\n delay?: number; // 入场延迟,可以是正数或者负数\n actions: IActionsLink[];\n};\n\nexport interface IActSpec {\n id: string;\n scenes: ISceneSpec[];\n}\n"]}
1
+ {"version":3,"sources":["../src/story/interface/dsl-interface.ts"],"names":[],"mappings":"","file":"dsl-interface.js","sourcesContent":["import type { IChartAddAction, IChartUpdateAction } from '../../player/processor/chart/vchart';\nimport type {\n IChartVisibilityAction,\n IComponentVisibilityAction\n // IChartAddAction\n} from '../../player/processor/interface/appear-action';\nimport type {\n IComponentBounceAction,\n IComponentMoveToAction,\n IComponentScaleToAction,\n IComponentStyleAction\n} from '../../player/processor/interface/style-action';\nimport type { ICharacterSpec } from '../character';\n\nexport type IActionSpec =\n | IComponentStyleAction\n | IComponentVisibilityAction\n | IComponentMoveToAction\n | IComponentScaleToAction\n | IComponentBounceAction\n | IChartVisibilityAction\n | IChartUpdateAction\n | IChartAddAction;\n\nexport interface IStorySpec {\n acts: IActSpec[]; // 作品的章节\n characters: ICharacterSpec[]; // 作品中的元素\n}\n\nexport interface IActionsLink {\n characterId: string;\n characterActions: IActionSpec[];\n}\n\nexport type ISceneSpec = {\n id: string;\n delay?: number; // 入场延迟,可以是正数或者负数\n actions: IActionsLink[];\n};\n\nexport interface IActSpec {\n id: string;\n scenes: ISceneSpec[];\n}\n"]}
@@ -1,13 +1 @@
1
- import type { ICharacter } from '../character';
2
- import type { IActSpec } from './dsl-interface';
3
- export interface IPlayer {
4
- tickTo: (t: number) => void;
5
- play: () => void;
6
- encodeToVideo: (millsecond: number, fps: number) => Promise<string>;
7
- pause: () => void;
8
- release: () => void;
9
- addAct: (c: IActSpec, characters: {
10
- [key: string]: ICharacter;
11
- }) => void;
12
- getCurrentAct: () => number | string;
13
- }
1
+
@@ -1,2 +1,3 @@
1
- export { };
1
+
2
+
2
3
  //# sourceMappingURL=player.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/interface/player.ts"],"names":[],"mappings":"","file":"player.js","sourcesContent":["import type { ICharacter } from '../character';\nimport type { IActSpec } from './dsl-interface';\n\nexport interface IPlayer {\n tickTo: (t: number) => void;\n play: () => void;\n encodeToVideo: (millsecond: number, fps: number) => Promise<string>;\n pause: () => void;\n release: () => void;\n addAct: (\n c: IActSpec,\n characters: {\n [key: string]: ICharacter;\n }\n ) => void;\n getCurrentAct: () => number | string;\n}\n"]}
1
+ {"version":3,"sources":["../src/story/interface/player.ts"],"names":[],"mappings":"","file":"player.js","sourcesContent":["// import type { ICharacter } from '../character';\n// import type { IActSpec } from './dsl-interface';\n\n// export interface IPlayer {\n// tickTo: (t: number) => void;\n// play: () => void;\n// encodeToVideo: (millsecond: number, fps: number) => Promise<string>;\n// pause: () => void;\n// release: () => void;\n// addAct: (\n// c: IActSpec,\n// characters: {\n// [key: string]: ICharacter;\n// }\n// ) => void;\n// getCurrentAct: () => number | string;\n// }\n"]}
@@ -1,5 +1,6 @@
1
1
  import type { IGraphic, IStage } from '@visactor/vrender';
2
2
  import type { ICharacter, ICharacterSpec } from '../character';
3
+ import type { IPlayer } from '../../player/interface/player';
3
4
  export interface IStoryInitOption {
4
5
  dom: string | HTMLDivElement;
5
6
  playerOption?: {
@@ -18,6 +19,7 @@ export interface IStoryCanvas {
18
19
  }
19
20
  export interface IStory {
20
21
  readonly id: string;
22
+ readonly player: IPlayer;
21
23
  canvas: IStoryCanvas;
22
24
  getCharacters: () => {
23
25
  [key: string]: ICharacter;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/interface/runtime-interface.ts"],"names":[],"mappings":"","file":"runtime-interface.js","sourcesContent":["import type { IGraphic, IStage } from '@visactor/vrender';\nimport type { ICharacter, ICharacterSpec } from '../character';\n\nexport interface IStoryInitOption {\n dom: string | HTMLDivElement; // dom id\n playerOption?: {\n scaleX?: number;\n scaleY?: number;\n };\n}\n\nexport interface IStoryCanvas {\n getStage: () => IStage;\n getCanvas: () => HTMLCanvasElement;\n getEventDetail: (event: StoryEvent) => {\n character: ICharacter;\n characterInfo: undefined;\n };\n release: () => void;\n}\n\nexport interface IStory {\n readonly id: string;\n canvas: IStoryCanvas;\n getCharacters: () => { [key: string]: ICharacter };\n getCharactersById: (key: string) => ICharacter | null;\n}\nexport interface ICharacterTree {\n getCharacters: () => { [key: string]: ICharacter };\n getCharactersById: (key: string) => ICharacter | null;\n addCharacter: (spec: ICharacterSpec) => ICharacter;\n initCharacters: (spec: ICharacterSpec[]) => void;\n}\n\nexport type StoryEvent = Event & {\n detailPath: IGraphic[];\n path: IGraphic[];\n};\n"]}
1
+ {"version":3,"sources":["../src/story/interface/runtime-interface.ts"],"names":[],"mappings":"","file":"runtime-interface.js","sourcesContent":["import type { IGraphic, IStage } from '@visactor/vrender';\nimport type { ICharacter, ICharacterSpec } from '../character';\nimport type { IPlayer } from '../../player/interface/player';\n\nexport interface IStoryInitOption {\n dom: string | HTMLDivElement; // dom id\n playerOption?: {\n scaleX?: number;\n scaleY?: number;\n };\n}\n\nexport interface IStoryCanvas {\n getStage: () => IStage;\n getCanvas: () => HTMLCanvasElement;\n getEventDetail: (event: StoryEvent) => {\n character: ICharacter;\n characterInfo: undefined;\n };\n release: () => void;\n}\n\nexport interface IStory {\n readonly id: string;\n readonly player: IPlayer;\n canvas: IStoryCanvas;\n getCharacters: () => { [key: string]: ICharacter };\n getCharactersById: (key: string) => ICharacter | null;\n}\nexport interface ICharacterTree {\n getCharacters: () => { [key: string]: ICharacter };\n getCharactersById: (key: string) => ICharacter | null;\n addCharacter: (spec: ICharacterSpec) => ICharacter;\n initCharacters: (spec: ICharacterSpec[]) => void;\n}\n\nexport type StoryEvent = Event & {\n detailPath: IGraphic[];\n path: IGraphic[];\n};\n"]}
@@ -8,7 +8,9 @@ export declare class Story implements IStory {
8
8
  readonly id: string;
9
9
  protected _canvas: IStoryCanvas;
10
10
  protected _characterTree: ICharacterTree;
11
+ protected _spec: IStorySpec;
11
12
  get canvas(): IStoryCanvas;
13
+ get player(): IPlayer;
12
14
  constructor(spec: IStorySpec, option: IStoryInitOption);
13
15
  load(spec: IStorySpec): void;
14
16
  getCharacters(): {
@@ -16,7 +18,6 @@ export declare class Story implements IStory {
16
18
  };
17
19
  getCharactersById(key: string): ICharacter;
18
20
  play(loop?: boolean): void;
19
- tickTo(t: number): void;
20
21
  pause(): void;
21
22
  encodeToVideo(actIndexOrId: number, millsecond: number, fps: number): Promise<string>;
22
23
  getPlayer(): IPlayer;
package/es/story/story.js CHANGED
@@ -40,10 +40,13 @@ export class Story {
40
40
  get canvas() {
41
41
  return this._canvas;
42
42
  }
43
+ get player() {
44
+ return this._player;
45
+ }
43
46
  constructor(spec, option) {
44
47
  this.id = "test-mvp_" + Story._id_++, this._canvas = new StoryCanvas(this, isString(option.dom) ? document.getElementById(option.dom) : option.dom),
45
48
  this._player = new Player(this, option.playerOption), this._characterTree = new CharacterTree(this),
46
- spec && this.load(spec);
49
+ this._spec = spec, this._spec && this.load(this._spec);
47
50
  }
48
51
  load(spec) {
49
52
  this._characterTree.initCharacters(spec.characters), this._player.initActs(spec.acts);
@@ -55,10 +58,9 @@ export class Story {
55
58
  return this._characterTree.getCharactersById(key);
56
59
  }
57
60
  play(loop = !0) {
58
- this._player.play(loop);
59
- }
60
- tickTo(t) {
61
- this._player.tickTo(t);
61
+ this._spec && this.load(this._spec), this._player.play(), loop && this._player.once("onstop", (() => {
62
+ this.play(loop);
63
+ }));
62
64
  }
63
65
  pause() {
64
66
  this._player.pause();
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/story/story.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAG5C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG9C,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,aAAa,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;AAE3C,MAAM,OAAO,KAAK;IAUhB,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,YAAY,IAAgB,EAAE,MAAwB;QACpD,IAAI,CAAC,EAAE,GAAG,WAAW,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,CAC5B,IAAI,EACJ,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAE,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,CAAoB,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAC5F,CAAC;QACF,IAAI,CAAC,OAAO,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;QAErD,IAAI,CAAC,cAAc,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC;QAC9C,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACjB;IACH,CAAC;IAED,IAAI,CAAC,IAAgB;QACnB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpD,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IAC7C,CAAC;IAED,iBAAiB,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;IACpD,CAAC;IAMD,IAAI,CAAC,OAAgB,IAAI;QAEvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,CAAS;QACd,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,OAAO;IACT,CAAC;IAEK,aAAa,CAAC,YAAoB,EAAE,UAAkB,EAAE,GAAW;;YACvE,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC;KAAA;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QACvB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IACzB,CAAC;;AArEM,UAAI,GAAG,CAAC,CAAC","file":"story.js","sourcesContent":["import type { ICharacterSpec } from './character/dsl-interface';\nimport { isString } from '@visactor/vutils';\nimport type { ICharacterTree, IStory, IStoryCanvas, IStoryInitOption } from './interface/runtime-interface';\nimport type { ICharacter } from './character/runtime-interface';\nimport { StoryCanvas } from './canvas/canvas';\nimport type { IStorySpec, IActSpec } from './interface';\nimport { StoryFactory } from './factory/factory';\nimport { defaultTicker, defaultTimeline } from '@visactor/vrender';\nimport { CharacterTree } from './character-tree/character-tree';\nimport type { IPlayer } from '../player/interface/player';\nimport { Player } from '../player/player';\n\ndefaultTicker.remTimeline(defaultTimeline);\n\nexport class Story implements IStory {\n static _id_ = 0;\n\n protected _player: IPlayer;\n\n readonly id: string;\n\n protected _canvas: IStoryCanvas;\n\n protected _characterTree: ICharacterTree;\n get canvas() {\n return this._canvas;\n }\n\n constructor(spec: IStorySpec, option: IStoryInitOption) {\n this.id = 'test-mvp_' + Story._id_++;\n this._canvas = new StoryCanvas(\n this,\n isString(option.dom) ? (document.getElementById(option.dom) as HTMLDivElement) : option.dom\n );\n this._player = new Player(this, option.playerOption);\n\n this._characterTree = new CharacterTree(this);\n if (spec) {\n this.load(spec);\n }\n }\n\n load(spec: IStorySpec) {\n this._characterTree.initCharacters(spec.characters);\n this._player.initActs(spec.acts);\n }\n\n getCharacters(): { [key: string]: ICharacter } {\n return this._characterTree.getCharacters();\n }\n\n getCharactersById(key: string) {\n return this._characterTree.getCharactersById(key);\n }\n\n // private _createAct(spec: IActSpec) {\n // this._player.addAct(spec, this._characters);\n // }\n\n play(loop: boolean = true) {\n // player 开始播放\n this._player.play(loop);\n }\n\n tickTo(t: number) {\n this._player.tickTo(t);\n }\n\n pause() {\n this._player.pause();\n return;\n }\n\n async encodeToVideo(actIndexOrId: number, millsecond: number, fps: number) {\n return this._player.encodeToVideo(millsecond, fps);\n }\n\n getPlayer() {\n return this._player;\n }\n\n release() {\n this._player.release();\n this._canvas.release();\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/story/story.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAG5C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG9C,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAG1C,aAAa,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;AAE3C,MAAM,OAAO,KAAK;IAahB,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,YAAY,IAAgB,EAAE,MAAwB;QACpD,IAAI,CAAC,EAAE,GAAG,WAAW,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,CAC5B,IAAI,EACJ,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAE,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,CAAoB,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAC5F,CAAC;QACF,IAAI,CAAC,OAAO,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;QAErD,IAAI,CAAC,cAAc,GAAG,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,IAAI,CAAC,IAAgB;QACnB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpD,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IAC7C,CAAC;IAED,iBAAiB,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;IACpD,CAAC;IAMD,IAAI,CAAC,OAAgB,IAAI;QAEvB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACpB,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;gBAC/B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,OAAO;IACT,CAAC;IAEK,aAAa,CAAC,YAAoB,EAAE,UAAkB,EAAE,GAAW;;YACvE,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC;KAAA;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QACvB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IACzB,CAAC;;AA7EM,UAAI,GAAG,CAAC,CAAC","file":"story.js","sourcesContent":["import type { ICharacterSpec } from './character/dsl-interface';\nimport { isString } from '@visactor/vutils';\nimport type { ICharacterTree, IStory, IStoryCanvas, IStoryInitOption } from './interface/runtime-interface';\nimport type { ICharacter } from './character/runtime-interface';\nimport { StoryCanvas } from './canvas/canvas';\nimport type { IStorySpec, IActSpec } from './interface';\nimport { StoryFactory } from './factory/factory';\nimport { defaultTicker, defaultTimeline } from '@visactor/vrender';\nimport { CharacterTree } from './character-tree/character-tree';\nimport type { IPlayer } from '../player/interface/player';\nimport { Player } from '../player/player';\nimport { logger } from '../util/output';\n\ndefaultTicker.remTimeline(defaultTimeline);\n\nexport class Story implements IStory {\n static _id_ = 0;\n\n protected _player: IPlayer;\n\n readonly id: string;\n\n protected _canvas: IStoryCanvas;\n\n protected _characterTree: ICharacterTree;\n\n protected _spec: IStorySpec;\n\n get canvas() {\n return this._canvas;\n }\n\n get player(): IPlayer {\n return this._player;\n }\n\n constructor(spec: IStorySpec, option: IStoryInitOption) {\n this.id = 'test-mvp_' + Story._id_++;\n this._canvas = new StoryCanvas(\n this,\n isString(option.dom) ? (document.getElementById(option.dom) as HTMLDivElement) : option.dom\n );\n this._player = new Player(this, option.playerOption);\n\n this._characterTree = new CharacterTree(this);\n this._spec = spec;\n this._spec && this.load(this._spec);\n }\n\n load(spec: IStorySpec) {\n this._characterTree.initCharacters(spec.characters);\n this._player.initActs(spec.acts);\n }\n\n getCharacters(): { [key: string]: ICharacter } {\n return this._characterTree.getCharacters();\n }\n\n getCharactersById(key: string) {\n return this._characterTree.getCharactersById(key);\n }\n\n // private _createAct(spec: IActSpec) {\n // this._player.addAct(spec, this._characters);\n // }\n\n play(loop: boolean = true) {\n // player 开始播放\n this._spec && this.load(this._spec);\n this._player.play();\n if (loop) {\n this._player.once('onstop', () => {\n this.play(loop);\n });\n }\n }\n\n pause() {\n this._player.pause();\n return;\n }\n\n async encodeToVideo(actIndexOrId: number, millsecond: number, fps: number) {\n return this._player.encodeToVideo(millsecond, fps);\n }\n\n getPlayer() {\n return this._player;\n }\n\n release() {\n this._player.release();\n this._canvas.release();\n }\n}\n"]}
package/es/util/space.js CHANGED
@@ -93,5 +93,4 @@ export function getItemBoundsRectWithSpace(item, transformPos, space = 0) {
93
93
  width: bounds.width() + 2 * space,
94
94
  height: bounds.height() + 2 * space
95
95
  };
96
- }
97
- //# sourceMappingURL=space.js.map
96
+ }
@@ -3,4 +3,5 @@ export function forEachGraphicItem(group, cb) {
3
3
  const stopped = cb(node);
4
4
  node.isContainer && !stopped && forEachGraphicItem(node, cb);
5
5
  }));
6
- }
6
+ }
7
+ //# sourceMappingURL=vrender-api.js.map