@visactor/vrender-components 0.0.38-brush.2-alpha.0

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 (736) hide show
  1. package/README.md +9 -0
  2. package/cjs/axis/animate/group-fade.d.ts +17 -0
  3. package/cjs/axis/animate/group-fade.js +72 -0
  4. package/cjs/axis/animate/group-fade.js.map +1 -0
  5. package/cjs/axis/animate/group-transition.d.ts +10 -0
  6. package/cjs/axis/animate/group-transition.js +76 -0
  7. package/cjs/axis/animate/group-transition.js.map +1 -0
  8. package/cjs/axis/animate/index.d.ts +2 -0
  9. package/cjs/axis/animate/index.js +21 -0
  10. package/cjs/axis/animate/index.js.map +1 -0
  11. package/cjs/axis/base.d.ts +53 -0
  12. package/cjs/axis/base.js +305 -0
  13. package/cjs/axis/base.js.map +1 -0
  14. package/cjs/axis/circle.d.ts +88 -0
  15. package/cjs/axis/circle.js +182 -0
  16. package/cjs/axis/circle.js.map +1 -0
  17. package/cjs/axis/config.d.ts +71 -0
  18. package/cjs/axis/config.js +76 -0
  19. package/cjs/axis/config.js.map +1 -0
  20. package/cjs/axis/constant.d.ts +27 -0
  21. package/cjs/axis/constant.js +26 -0
  22. package/cjs/axis/constant.js.map +1 -0
  23. package/cjs/axis/grid.d.ts +9 -0
  24. package/cjs/axis/grid.js +106 -0
  25. package/cjs/axis/grid.js.map +1 -0
  26. package/cjs/axis/index.d.ts +6 -0
  27. package/cjs/axis/index.js +23 -0
  28. package/cjs/axis/index.js.map +1 -0
  29. package/cjs/axis/line.d.ts +89 -0
  30. package/cjs/axis/line.js +199 -0
  31. package/cjs/axis/line.js.map +1 -0
  32. package/cjs/axis/type.d.ts +177 -0
  33. package/cjs/axis/type.js +6 -0
  34. package/cjs/axis/type.js.map +1 -0
  35. package/cjs/brush/brush.d.ts +65 -0
  36. package/cjs/brush/brush.js +169 -0
  37. package/cjs/brush/brush.js.map +1 -0
  38. package/cjs/brush/config.d.ts +21 -0
  39. package/cjs/brush/config.js +26 -0
  40. package/cjs/brush/config.js.map +1 -0
  41. package/cjs/brush/index.d.ts +2 -0
  42. package/cjs/brush/index.js +21 -0
  43. package/cjs/brush/index.js.map +1 -0
  44. package/cjs/brush/type.d.ts +21 -0
  45. package/cjs/brush/type.js +6 -0
  46. package/cjs/brush/type.js.map +1 -0
  47. package/cjs/constant.d.ts +16 -0
  48. package/cjs/constant.js +18 -0
  49. package/cjs/constant.js.map +1 -0
  50. package/cjs/core/base.d.ts +12 -0
  51. package/cjs/core/base.js +44 -0
  52. package/cjs/core/base.js.map +1 -0
  53. package/cjs/core/type.d.ts +28 -0
  54. package/cjs/core/type.js +5 -0
  55. package/cjs/core/type.js.map +1 -0
  56. package/cjs/crosshair/base.d.ts +10 -0
  57. package/cjs/crosshair/base.js +19 -0
  58. package/cjs/crosshair/base.js.map +1 -0
  59. package/cjs/crosshair/circle.d.ts +17 -0
  60. package/cjs/crosshair/circle.js +33 -0
  61. package/cjs/crosshair/circle.js.map +1 -0
  62. package/cjs/crosshair/index.d.ts +6 -0
  63. package/cjs/crosshair/index.js +23 -0
  64. package/cjs/crosshair/index.js.map +1 -0
  65. package/cjs/crosshair/line.d.ts +17 -0
  66. package/cjs/crosshair/line.js +36 -0
  67. package/cjs/crosshair/line.js.map +1 -0
  68. package/cjs/crosshair/polygon.d.ts +17 -0
  69. package/cjs/crosshair/polygon.js +39 -0
  70. package/cjs/crosshair/polygon.js.map +1 -0
  71. package/cjs/crosshair/rect.d.ts +20 -0
  72. package/cjs/crosshair/rect.js +37 -0
  73. package/cjs/crosshair/rect.js.map +1 -0
  74. package/cjs/crosshair/sector.d.ts +15 -0
  75. package/cjs/crosshair/sector.js +38 -0
  76. package/cjs/crosshair/sector.js.map +1 -0
  77. package/cjs/crosshair/type.d.ts +37 -0
  78. package/cjs/crosshair/type.js +6 -0
  79. package/cjs/crosshair/type.js.map +1 -0
  80. package/cjs/data-zoom/config.d.ts +104 -0
  81. package/cjs/data-zoom/config.js +109 -0
  82. package/cjs/data-zoom/config.js.map +1 -0
  83. package/cjs/data-zoom/data-zoom.d.ts +193 -0
  84. package/cjs/data-zoom/data-zoom.js +447 -0
  85. package/cjs/data-zoom/data-zoom.js.map +1 -0
  86. package/cjs/data-zoom/index.d.ts +2 -0
  87. package/cjs/data-zoom/index.js +21 -0
  88. package/cjs/data-zoom/index.js.map +1 -0
  89. package/cjs/data-zoom/type.d.ts +59 -0
  90. package/cjs/data-zoom/type.js +6 -0
  91. package/cjs/data-zoom/type.js.map +1 -0
  92. package/cjs/index.d.ts +20 -0
  93. package/cjs/index.js +30 -0
  94. package/cjs/index.js.map +1 -0
  95. package/cjs/indicator/config.d.ts +2 -0
  96. package/cjs/indicator/config.js +31 -0
  97. package/cjs/indicator/config.js.map +1 -0
  98. package/cjs/indicator/index.d.ts +2 -0
  99. package/cjs/indicator/index.js +21 -0
  100. package/cjs/indicator/index.js.map +1 -0
  101. package/cjs/indicator/indicator.d.ts +9 -0
  102. package/cjs/indicator/indicator.js +73 -0
  103. package/cjs/indicator/indicator.js.map +1 -0
  104. package/cjs/indicator/type.d.ts +21 -0
  105. package/cjs/indicator/type.js +5 -0
  106. package/cjs/indicator/type.js.map +1 -0
  107. package/cjs/interface.d.ts +6 -0
  108. package/cjs/interface.js +6 -0
  109. package/cjs/interface.js.map +1 -0
  110. package/cjs/label/animate/animate.d.ts +7 -0
  111. package/cjs/label/animate/animate.js +53 -0
  112. package/cjs/label/animate/animate.js.map +1 -0
  113. package/cjs/label/animate/index.d.ts +1 -0
  114. package/cjs/label/animate/index.js +3 -0
  115. package/cjs/label/animate/index.js.map +1 -0
  116. package/cjs/label/base.d.ts +43 -0
  117. package/cjs/label/base.js +263 -0
  118. package/cjs/label/base.js.map +1 -0
  119. package/cjs/label/dataLabel.d.ts +13 -0
  120. package/cjs/label/dataLabel.js +56 -0
  121. package/cjs/label/dataLabel.js.map +1 -0
  122. package/cjs/label/index.d.ts +6 -0
  123. package/cjs/label/index.js +23 -0
  124. package/cjs/label/index.js.map +1 -0
  125. package/cjs/label/line.d.ts +15 -0
  126. package/cjs/label/line.js +47 -0
  127. package/cjs/label/line.js.map +1 -0
  128. package/cjs/label/overlap/bitmap.d.ts +13 -0
  129. package/cjs/label/overlap/bitmap.js +73 -0
  130. package/cjs/label/overlap/bitmap.js.map +1 -0
  131. package/cjs/label/overlap/index.d.ts +3 -0
  132. package/cjs/label/overlap/index.js +22 -0
  133. package/cjs/label/overlap/index.js.map +1 -0
  134. package/cjs/label/overlap/place.d.ts +14 -0
  135. package/cjs/label/overlap/place.js +61 -0
  136. package/cjs/label/overlap/place.js.map +1 -0
  137. package/cjs/label/overlap/scaler.d.ts +27 -0
  138. package/cjs/label/overlap/scaler.js +26 -0
  139. package/cjs/label/overlap/scaler.js.map +1 -0
  140. package/cjs/label/rect.d.ts +10 -0
  141. package/cjs/label/rect.js +59 -0
  142. package/cjs/label/rect.js.map +1 -0
  143. package/cjs/label/symbol.d.ts +10 -0
  144. package/cjs/label/symbol.js +69 -0
  145. package/cjs/label/symbol.js.map +1 -0
  146. package/cjs/label/type.d.ts +90 -0
  147. package/cjs/label/type.js +6 -0
  148. package/cjs/label/type.js.map +1 -0
  149. package/cjs/legend/base.d.ts +14 -0
  150. package/cjs/legend/base.js +58 -0
  151. package/cjs/legend/base.js.map +1 -0
  152. package/cjs/legend/color/color.d.ts +37 -0
  153. package/cjs/legend/color/color.js +128 -0
  154. package/cjs/legend/color/color.js.map +1 -0
  155. package/cjs/legend/color/index.d.ts +2 -0
  156. package/cjs/legend/color/index.js +21 -0
  157. package/cjs/legend/color/index.js.map +1 -0
  158. package/cjs/legend/color/type.d.ts +5 -0
  159. package/cjs/legend/color/type.js +6 -0
  160. package/cjs/legend/color/type.js.map +1 -0
  161. package/cjs/legend/constant.d.ts +29 -0
  162. package/cjs/legend/constant.js +24 -0
  163. package/cjs/legend/constant.js.map +1 -0
  164. package/cjs/legend/discrete/discrete.d.ts +26 -0
  165. package/cjs/legend/discrete/discrete.js +413 -0
  166. package/cjs/legend/discrete/discrete.js.map +1 -0
  167. package/cjs/legend/discrete/index.d.ts +2 -0
  168. package/cjs/legend/discrete/index.js +21 -0
  169. package/cjs/legend/discrete/index.js.map +1 -0
  170. package/cjs/legend/discrete/type.d.ts +65 -0
  171. package/cjs/legend/discrete/type.js +6 -0
  172. package/cjs/legend/discrete/type.js.map +1 -0
  173. package/cjs/legend/index.d.ts +8 -0
  174. package/cjs/legend/index.js +24 -0
  175. package/cjs/legend/index.js.map +1 -0
  176. package/cjs/legend/size/index.d.ts +1 -0
  177. package/cjs/legend/size/index.js +3 -0
  178. package/cjs/legend/size/index.js.map +1 -0
  179. package/cjs/legend/size/size.d.ts +34 -0
  180. package/cjs/legend/size/size.js +106 -0
  181. package/cjs/legend/size/size.js.map +1 -0
  182. package/cjs/legend/size/type.d.ts +6 -0
  183. package/cjs/legend/size/type.js +6 -0
  184. package/cjs/legend/size/type.js.map +1 -0
  185. package/cjs/legend/type.d.ts +27 -0
  186. package/cjs/legend/type.js +6 -0
  187. package/cjs/legend/type.js.map +1 -0
  188. package/cjs/link-path/index.d.ts +2 -0
  189. package/cjs/link-path/index.js +21 -0
  190. package/cjs/link-path/index.js.map +1 -0
  191. package/cjs/link-path/link-path.d.ts +15 -0
  192. package/cjs/link-path/link-path.js +65 -0
  193. package/cjs/link-path/link-path.js.map +1 -0
  194. package/cjs/link-path/type.d.ts +17 -0
  195. package/cjs/link-path/type.js +6 -0
  196. package/cjs/link-path/type.js.map +1 -0
  197. package/cjs/marker/area.d.ts +56 -0
  198. package/cjs/marker/area.js +64 -0
  199. package/cjs/marker/area.js.map +1 -0
  200. package/cjs/marker/base.d.ts +11 -0
  201. package/cjs/marker/base.js +22 -0
  202. package/cjs/marker/base.js.map +1 -0
  203. package/cjs/marker/config.d.ts +154 -0
  204. package/cjs/marker/config.js +240 -0
  205. package/cjs/marker/config.js.map +1 -0
  206. package/cjs/marker/index.d.ts +4 -0
  207. package/cjs/marker/index.js +22 -0
  208. package/cjs/marker/index.js.map +1 -0
  209. package/cjs/marker/line.d.ts +10 -0
  210. package/cjs/marker/line.js +45 -0
  211. package/cjs/marker/line.js.map +1 -0
  212. package/cjs/marker/point.d.ts +80 -0
  213. package/cjs/marker/point.js +102 -0
  214. package/cjs/marker/point.js.map +1 -0
  215. package/cjs/marker/type.d.ts +93 -0
  216. package/cjs/marker/type.js +26 -0
  217. package/cjs/marker/type.js.map +1 -0
  218. package/cjs/pager/index.d.ts +2 -0
  219. package/cjs/pager/index.js +21 -0
  220. package/cjs/pager/index.js.map +1 -0
  221. package/cjs/pager/pager.d.ts +20 -0
  222. package/cjs/pager/pager.js +132 -0
  223. package/cjs/pager/pager.js.map +1 -0
  224. package/cjs/pager/type.d.ts +19 -0
  225. package/cjs/pager/type.js +6 -0
  226. package/cjs/pager/type.js.map +1 -0
  227. package/cjs/player/base-player.d.ts +103 -0
  228. package/cjs/player/base-player.js +199 -0
  229. package/cjs/player/base-player.js.map +1 -0
  230. package/cjs/player/constant.d.ts +12 -0
  231. package/cjs/player/constant.js +16 -0
  232. package/cjs/player/constant.js.map +1 -0
  233. package/cjs/player/continuous-player.d.ts +34 -0
  234. package/cjs/player/continuous-player.js +107 -0
  235. package/cjs/player/continuous-player.js.map +1 -0
  236. package/cjs/player/controller/assets/index.d.ts +6 -0
  237. package/cjs/player/controller/assets/index.js +12 -0
  238. package/cjs/player/controller/assets/index.js.map +1 -0
  239. package/cjs/player/controller/constant.d.ts +12 -0
  240. package/cjs/player/controller/constant.js +15 -0
  241. package/cjs/player/controller/constant.js.map +1 -0
  242. package/cjs/player/controller/controller.d.ts +32 -0
  243. package/cjs/player/controller/controller.js +93 -0
  244. package/cjs/player/controller/controller.js.map +1 -0
  245. package/cjs/player/controller/icon/icon.d.ts +4 -0
  246. package/cjs/player/controller/icon/icon.js +16 -0
  247. package/cjs/player/controller/icon/icon.js.map +1 -0
  248. package/cjs/player/controller/icon/index.d.ts +1 -0
  249. package/cjs/player/controller/icon/index.js +21 -0
  250. package/cjs/player/controller/icon/index.js.map +1 -0
  251. package/cjs/player/controller/icon/type.d.ts +1 -0
  252. package/cjs/player/controller/icon/type.js +3 -0
  253. package/cjs/player/controller/icon/type.js.map +1 -0
  254. package/cjs/player/controller/index.d.ts +2 -0
  255. package/cjs/player/controller/index.js +21 -0
  256. package/cjs/player/controller/index.js.map +1 -0
  257. package/cjs/player/controller/type.d.ts +11 -0
  258. package/cjs/player/controller/type.js +6 -0
  259. package/cjs/player/controller/type.js.map +1 -0
  260. package/cjs/player/discrete-player.d.ts +32 -0
  261. package/cjs/player/discrete-player.js +85 -0
  262. package/cjs/player/discrete-player.js.map +1 -0
  263. package/cjs/player/index.d.ts +4 -0
  264. package/cjs/player/index.js +22 -0
  265. package/cjs/player/index.js.map +1 -0
  266. package/cjs/player/type/base.d.ts +7 -0
  267. package/cjs/player/type/base.js +6 -0
  268. package/cjs/player/type/base.js.map +1 -0
  269. package/cjs/player/type/continuous-player.d.ts +7 -0
  270. package/cjs/player/type/continuous-player.js +6 -0
  271. package/cjs/player/type/continuous-player.js.map +1 -0
  272. package/cjs/player/type/direction.d.ts +5 -0
  273. package/cjs/player/type/direction.js +10 -0
  274. package/cjs/player/type/direction.js.map +1 -0
  275. package/cjs/player/type/discrete-player.d.ts +9 -0
  276. package/cjs/player/type/discrete-player.js +6 -0
  277. package/cjs/player/type/discrete-player.js.map +1 -0
  278. package/cjs/player/type/event.d.ts +8 -0
  279. package/cjs/player/type/event.js +12 -0
  280. package/cjs/player/type/event.js.map +1 -0
  281. package/cjs/player/type/index.d.ts +9 -0
  282. package/cjs/player/type/index.js +23 -0
  283. package/cjs/player/type/index.js.map +1 -0
  284. package/cjs/player/type/layout.d.ts +35 -0
  285. package/cjs/player/type/layout.js +6 -0
  286. package/cjs/player/type/layout.js.map +1 -0
  287. package/cjs/player/utils.d.ts +20 -0
  288. package/cjs/player/utils.js +74 -0
  289. package/cjs/player/utils.js.map +1 -0
  290. package/cjs/scrollbar/index.d.ts +2 -0
  291. package/cjs/scrollbar/index.js +21 -0
  292. package/cjs/scrollbar/index.js.map +1 -0
  293. package/cjs/scrollbar/scrollbar.d.ts +43 -0
  294. package/cjs/scrollbar/scrollbar.js +161 -0
  295. package/cjs/scrollbar/scrollbar.js.map +1 -0
  296. package/cjs/scrollbar/type.d.ts +16 -0
  297. package/cjs/scrollbar/type.js +6 -0
  298. package/cjs/scrollbar/type.js.map +1 -0
  299. package/cjs/segment/index.d.ts +2 -0
  300. package/cjs/segment/index.js +21 -0
  301. package/cjs/segment/index.js.map +1 -0
  302. package/cjs/segment/segment.d.ts +18 -0
  303. package/cjs/segment/segment.js +105 -0
  304. package/cjs/segment/segment.js.map +1 -0
  305. package/cjs/segment/type.d.ts +22 -0
  306. package/cjs/segment/type.js +6 -0
  307. package/cjs/segment/type.js.map +1 -0
  308. package/cjs/slider/constant.d.ts +13 -0
  309. package/cjs/slider/constant.js +15 -0
  310. package/cjs/slider/constant.js.map +1 -0
  311. package/cjs/slider/index.d.ts +3 -0
  312. package/cjs/slider/index.js +22 -0
  313. package/cjs/slider/index.js.map +1 -0
  314. package/cjs/slider/slider.d.ts +96 -0
  315. package/cjs/slider/slider.js +405 -0
  316. package/cjs/slider/slider.js.map +1 -0
  317. package/cjs/slider/type.d.ts +44 -0
  318. package/cjs/slider/type.js +6 -0
  319. package/cjs/slider/type.js.map +1 -0
  320. package/cjs/tag/index.d.ts +2 -0
  321. package/cjs/tag/index.js +21 -0
  322. package/cjs/tag/index.js.map +1 -0
  323. package/cjs/tag/tag.d.ts +8 -0
  324. package/cjs/tag/tag.js +103 -0
  325. package/cjs/tag/tag.js.map +1 -0
  326. package/cjs/tag/type.d.ts +24 -0
  327. package/cjs/tag/type.js +6 -0
  328. package/cjs/tag/type.js.map +1 -0
  329. package/cjs/title/index.d.ts +2 -0
  330. package/cjs/title/index.js +21 -0
  331. package/cjs/title/index.js.map +1 -0
  332. package/cjs/title/title.d.ts +10 -0
  333. package/cjs/title/title.js +133 -0
  334. package/cjs/title/title.js.map +1 -0
  335. package/cjs/title/type.d.ts +41 -0
  336. package/cjs/title/type.js +6 -0
  337. package/cjs/title/type.js.map +1 -0
  338. package/cjs/tooltip/config.d.ts +3 -0
  339. package/cjs/tooltip/config.js +78 -0
  340. package/cjs/tooltip/config.js.map +1 -0
  341. package/cjs/tooltip/index.d.ts +2 -0
  342. package/cjs/tooltip/index.js +21 -0
  343. package/cjs/tooltip/index.js.map +1 -0
  344. package/cjs/tooltip/tooltip.d.ts +18 -0
  345. package/cjs/tooltip/tooltip.js +160 -0
  346. package/cjs/tooltip/tooltip.js.map +1 -0
  347. package/cjs/tooltip/type.d.ts +60 -0
  348. package/cjs/tooltip/type.js +6 -0
  349. package/cjs/tooltip/type.js.map +1 -0
  350. package/cjs/tooltip/util.d.ts +2 -0
  351. package/cjs/tooltip/util.js +17 -0
  352. package/cjs/tooltip/util.js.map +1 -0
  353. package/cjs/util/common.d.ts +3 -0
  354. package/cjs/util/common.js +21 -0
  355. package/cjs/util/common.js.map +1 -0
  356. package/cjs/util/index.d.ts +4 -0
  357. package/cjs/util/index.js +22 -0
  358. package/cjs/util/index.js.map +1 -0
  359. package/cjs/util/labelSmartInvert.d.ts +2 -0
  360. package/cjs/util/labelSmartInvert.js +45 -0
  361. package/cjs/util/labelSmartInvert.js.map +1 -0
  362. package/cjs/util/matrix.d.ts +4 -0
  363. package/cjs/util/matrix.js +24 -0
  364. package/cjs/util/matrix.js.map +1 -0
  365. package/cjs/util/text.d.ts +7 -0
  366. package/cjs/util/text.js +40 -0
  367. package/cjs/util/text.js.map +1 -0
  368. package/dist/vrender-components.js.js +1 -0
  369. package/dist/vrender-components.js.min.js +1 -0
  370. package/es/axis/animate/group-fade.d.ts +17 -0
  371. package/es/axis/animate/group-fade.js +62 -0
  372. package/es/axis/animate/group-fade.js.map +1 -0
  373. package/es/axis/animate/group-transition.d.ts +10 -0
  374. package/es/axis/animate/group-transition.js +72 -0
  375. package/es/axis/animate/group-transition.js.map +1 -0
  376. package/es/axis/animate/index.d.ts +2 -0
  377. package/es/axis/animate/index.js +4 -0
  378. package/es/axis/animate/index.js.map +1 -0
  379. package/es/axis/base.d.ts +53 -0
  380. package/es/axis/base.js +306 -0
  381. package/es/axis/base.js.map +1 -0
  382. package/es/axis/circle.d.ts +88 -0
  383. package/es/axis/circle.js +186 -0
  384. package/es/axis/circle.js.map +1 -0
  385. package/es/axis/config.d.ts +71 -0
  386. package/es/axis/config.js +72 -0
  387. package/es/axis/config.js.map +1 -0
  388. package/es/axis/constant.d.ts +27 -0
  389. package/es/axis/constant.js +26 -0
  390. package/es/axis/constant.js.map +1 -0
  391. package/es/axis/grid.d.ts +9 -0
  392. package/es/axis/grid.js +102 -0
  393. package/es/axis/grid.js.map +1 -0
  394. package/es/axis/index.d.ts +6 -0
  395. package/es/axis/index.js +12 -0
  396. package/es/axis/index.js.map +1 -0
  397. package/es/axis/line.d.ts +89 -0
  398. package/es/axis/line.js +204 -0
  399. package/es/axis/line.js.map +1 -0
  400. package/es/axis/type.d.ts +177 -0
  401. package/es/axis/type.js +2 -0
  402. package/es/axis/type.js.map +1 -0
  403. package/es/brush/brush.d.ts +65 -0
  404. package/es/brush/brush.js +171 -0
  405. package/es/brush/brush.js.map +1 -0
  406. package/es/brush/config.d.ts +21 -0
  407. package/es/brush/config.js +22 -0
  408. package/es/brush/config.js.map +1 -0
  409. package/es/brush/index.d.ts +2 -0
  410. package/es/brush/index.js +4 -0
  411. package/es/brush/index.js.map +1 -0
  412. package/es/brush/type.d.ts +21 -0
  413. package/es/brush/type.js +2 -0
  414. package/es/brush/type.js.map +1 -0
  415. package/es/constant.d.ts +16 -0
  416. package/es/constant.js +21 -0
  417. package/es/constant.js.map +1 -0
  418. package/es/core/base.d.ts +12 -0
  419. package/es/core/base.js +40 -0
  420. package/es/core/base.js.map +1 -0
  421. package/es/core/type.d.ts +28 -0
  422. package/es/core/type.js +1 -0
  423. package/es/core/type.js.map +1 -0
  424. package/es/crosshair/base.d.ts +10 -0
  425. package/es/crosshair/base.js +11 -0
  426. package/es/crosshair/base.js.map +1 -0
  427. package/es/crosshair/circle.d.ts +17 -0
  428. package/es/crosshair/circle.js +29 -0
  429. package/es/crosshair/circle.js.map +1 -0
  430. package/es/crosshair/index.d.ts +6 -0
  431. package/es/crosshair/index.js +12 -0
  432. package/es/crosshair/index.js.map +1 -0
  433. package/es/crosshair/line.d.ts +17 -0
  434. package/es/crosshair/line.js +32 -0
  435. package/es/crosshair/line.js.map +1 -0
  436. package/es/crosshair/polygon.d.ts +17 -0
  437. package/es/crosshair/polygon.js +35 -0
  438. package/es/crosshair/polygon.js.map +1 -0
  439. package/es/crosshair/rect.d.ts +20 -0
  440. package/es/crosshair/rect.js +33 -0
  441. package/es/crosshair/rect.js.map +1 -0
  442. package/es/crosshair/sector.d.ts +15 -0
  443. package/es/crosshair/sector.js +35 -0
  444. package/es/crosshair/sector.js.map +1 -0
  445. package/es/crosshair/type.d.ts +37 -0
  446. package/es/crosshair/type.js +2 -0
  447. package/es/crosshair/type.js.map +1 -0
  448. package/es/data-zoom/config.d.ts +104 -0
  449. package/es/data-zoom/config.js +106 -0
  450. package/es/data-zoom/config.js.map +1 -0
  451. package/es/data-zoom/data-zoom.d.ts +193 -0
  452. package/es/data-zoom/data-zoom.js +444 -0
  453. package/es/data-zoom/data-zoom.js.map +1 -0
  454. package/es/data-zoom/index.d.ts +2 -0
  455. package/es/data-zoom/index.js +4 -0
  456. package/es/data-zoom/index.js.map +1 -0
  457. package/es/data-zoom/type.d.ts +59 -0
  458. package/es/data-zoom/type.js +2 -0
  459. package/es/data-zoom/type.js.map +1 -0
  460. package/es/index.d.ts +20 -0
  461. package/es/index.js +40 -0
  462. package/es/index.js.map +1 -0
  463. package/es/indicator/config.d.ts +2 -0
  464. package/es/indicator/config.js +27 -0
  465. package/es/indicator/config.js.map +1 -0
  466. package/es/indicator/index.d.ts +2 -0
  467. package/es/indicator/index.js +4 -0
  468. package/es/indicator/index.js.map +1 -0
  469. package/es/indicator/indicator.d.ts +9 -0
  470. package/es/indicator/indicator.js +69 -0
  471. package/es/indicator/indicator.js.map +1 -0
  472. package/es/indicator/type.d.ts +21 -0
  473. package/es/indicator/type.js +1 -0
  474. package/es/indicator/type.js.map +1 -0
  475. package/es/interface.d.ts +6 -0
  476. package/es/interface.js +2 -0
  477. package/es/interface.js.map +1 -0
  478. package/es/label/animate/animate.d.ts +7 -0
  479. package/es/label/animate/animate.js +47 -0
  480. package/es/label/animate/animate.js.map +1 -0
  481. package/es/label/animate/index.d.ts +1 -0
  482. package/es/label/animate/index.js +3 -0
  483. package/es/label/animate/index.js.map +1 -0
  484. package/es/label/base.d.ts +43 -0
  485. package/es/label/base.js +263 -0
  486. package/es/label/base.js.map +1 -0
  487. package/es/label/dataLabel.d.ts +13 -0
  488. package/es/label/dataLabel.js +60 -0
  489. package/es/label/dataLabel.js.map +1 -0
  490. package/es/label/index.d.ts +6 -0
  491. package/es/label/index.js +12 -0
  492. package/es/label/index.js.map +1 -0
  493. package/es/label/line.d.ts +15 -0
  494. package/es/label/line.js +43 -0
  495. package/es/label/line.js.map +1 -0
  496. package/es/label/overlap/bitmap.d.ts +13 -0
  497. package/es/label/overlap/bitmap.js +65 -0
  498. package/es/label/overlap/bitmap.js.map +1 -0
  499. package/es/label/overlap/index.d.ts +3 -0
  500. package/es/label/overlap/index.js +6 -0
  501. package/es/label/overlap/index.js.map +1 -0
  502. package/es/label/overlap/place.d.ts +14 -0
  503. package/es/label/overlap/place.js +57 -0
  504. package/es/label/overlap/place.js.map +1 -0
  505. package/es/label/overlap/scaler.d.ts +27 -0
  506. package/es/label/overlap/scaler.js +18 -0
  507. package/es/label/overlap/scaler.js.map +1 -0
  508. package/es/label/rect.d.ts +10 -0
  509. package/es/label/rect.js +55 -0
  510. package/es/label/rect.js.map +1 -0
  511. package/es/label/symbol.d.ts +10 -0
  512. package/es/label/symbol.js +65 -0
  513. package/es/label/symbol.js.map +1 -0
  514. package/es/label/type.d.ts +90 -0
  515. package/es/label/type.js +2 -0
  516. package/es/label/type.js.map +1 -0
  517. package/es/legend/base.d.ts +14 -0
  518. package/es/legend/base.js +56 -0
  519. package/es/legend/base.js.map +1 -0
  520. package/es/legend/color/color.d.ts +37 -0
  521. package/es/legend/color/color.js +128 -0
  522. package/es/legend/color/color.js.map +1 -0
  523. package/es/legend/color/index.d.ts +2 -0
  524. package/es/legend/color/index.js +4 -0
  525. package/es/legend/color/index.js.map +1 -0
  526. package/es/legend/color/type.d.ts +5 -0
  527. package/es/legend/color/type.js +2 -0
  528. package/es/legend/color/type.js.map +1 -0
  529. package/es/legend/constant.d.ts +29 -0
  530. package/es/legend/constant.js +40 -0
  531. package/es/legend/constant.js.map +1 -0
  532. package/es/legend/discrete/discrete.d.ts +26 -0
  533. package/es/legend/discrete/discrete.js +409 -0
  534. package/es/legend/discrete/discrete.js.map +1 -0
  535. package/es/legend/discrete/index.d.ts +2 -0
  536. package/es/legend/discrete/index.js +4 -0
  537. package/es/legend/discrete/index.js.map +1 -0
  538. package/es/legend/discrete/type.d.ts +65 -0
  539. package/es/legend/discrete/type.js +2 -0
  540. package/es/legend/discrete/type.js.map +1 -0
  541. package/es/legend/index.d.ts +8 -0
  542. package/es/legend/index.js +16 -0
  543. package/es/legend/index.js.map +1 -0
  544. package/es/legend/size/index.d.ts +1 -0
  545. package/es/legend/size/index.js +3 -0
  546. package/es/legend/size/index.js.map +1 -0
  547. package/es/legend/size/size.d.ts +34 -0
  548. package/es/legend/size/size.js +105 -0
  549. package/es/legend/size/size.js.map +1 -0
  550. package/es/legend/size/type.d.ts +6 -0
  551. package/es/legend/size/type.js +2 -0
  552. package/es/legend/size/type.js.map +1 -0
  553. package/es/legend/type.d.ts +27 -0
  554. package/es/legend/type.js +2 -0
  555. package/es/legend/type.js.map +1 -0
  556. package/es/link-path/index.d.ts +2 -0
  557. package/es/link-path/index.js +4 -0
  558. package/es/link-path/index.js.map +1 -0
  559. package/es/link-path/link-path.d.ts +15 -0
  560. package/es/link-path/link-path.js +59 -0
  561. package/es/link-path/link-path.js.map +1 -0
  562. package/es/link-path/type.d.ts +17 -0
  563. package/es/link-path/type.js +2 -0
  564. package/es/link-path/type.js.map +1 -0
  565. package/es/marker/area.d.ts +56 -0
  566. package/es/marker/area.js +65 -0
  567. package/es/marker/area.js.map +1 -0
  568. package/es/marker/base.d.ts +11 -0
  569. package/es/marker/base.js +15 -0
  570. package/es/marker/base.js.map +1 -0
  571. package/es/marker/config.d.ts +154 -0
  572. package/es/marker/config.js +244 -0
  573. package/es/marker/config.js.map +1 -0
  574. package/es/marker/index.d.ts +4 -0
  575. package/es/marker/index.js +8 -0
  576. package/es/marker/index.js.map +1 -0
  577. package/es/marker/line.d.ts +10 -0
  578. package/es/marker/line.js +47 -0
  579. package/es/marker/line.js.map +1 -0
  580. package/es/marker/point.d.ts +80 -0
  581. package/es/marker/point.js +106 -0
  582. package/es/marker/point.js.map +1 -0
  583. package/es/marker/type.d.ts +93 -0
  584. package/es/marker/type.js +27 -0
  585. package/es/marker/type.js.map +1 -0
  586. package/es/pager/index.d.ts +2 -0
  587. package/es/pager/index.js +4 -0
  588. package/es/pager/index.js.map +1 -0
  589. package/es/pager/pager.d.ts +20 -0
  590. package/es/pager/pager.js +132 -0
  591. package/es/pager/pager.js.map +1 -0
  592. package/es/pager/type.d.ts +19 -0
  593. package/es/pager/type.js +2 -0
  594. package/es/pager/type.js.map +1 -0
  595. package/es/player/base-player.d.ts +103 -0
  596. package/es/player/base-player.js +200 -0
  597. package/es/player/base-player.js.map +1 -0
  598. package/es/player/constant.d.ts +12 -0
  599. package/es/player/constant.js +14 -0
  600. package/es/player/constant.js.map +1 -0
  601. package/es/player/continuous-player.d.ts +34 -0
  602. package/es/player/continuous-player.js +104 -0
  603. package/es/player/continuous-player.js.map +1 -0
  604. package/es/player/controller/assets/index.d.ts +6 -0
  605. package/es/player/controller/assets/index.js +12 -0
  606. package/es/player/controller/assets/index.js.map +1 -0
  607. package/es/player/controller/constant.d.ts +12 -0
  608. package/es/player/controller/constant.js +14 -0
  609. package/es/player/controller/constant.js.map +1 -0
  610. package/es/player/controller/controller.d.ts +32 -0
  611. package/es/player/controller/controller.js +97 -0
  612. package/es/player/controller/controller.js.map +1 -0
  613. package/es/player/controller/icon/icon.d.ts +4 -0
  614. package/es/player/controller/icon/icon.js +8 -0
  615. package/es/player/controller/icon/icon.js.map +1 -0
  616. package/es/player/controller/icon/index.d.ts +1 -0
  617. package/es/player/controller/icon/index.js +2 -0
  618. package/es/player/controller/icon/index.js.map +1 -0
  619. package/es/player/controller/icon/type.d.ts +1 -0
  620. package/es/player/controller/icon/type.js +3 -0
  621. package/es/player/controller/icon/type.js.map +1 -0
  622. package/es/player/controller/index.d.ts +2 -0
  623. package/es/player/controller/index.js +4 -0
  624. package/es/player/controller/index.js.map +1 -0
  625. package/es/player/controller/type.d.ts +11 -0
  626. package/es/player/controller/type.js +2 -0
  627. package/es/player/controller/type.js.map +1 -0
  628. package/es/player/discrete-player.d.ts +32 -0
  629. package/es/player/discrete-player.js +86 -0
  630. package/es/player/discrete-player.js.map +1 -0
  631. package/es/player/index.d.ts +4 -0
  632. package/es/player/index.js +8 -0
  633. package/es/player/index.js.map +1 -0
  634. package/es/player/type/base.d.ts +7 -0
  635. package/es/player/type/base.js +2 -0
  636. package/es/player/type/base.js.map +1 -0
  637. package/es/player/type/continuous-player.d.ts +7 -0
  638. package/es/player/type/continuous-player.js +2 -0
  639. package/es/player/type/continuous-player.js.map +1 -0
  640. package/es/player/type/direction.d.ts +5 -0
  641. package/es/player/type/direction.js +6 -0
  642. package/es/player/type/direction.js.map +1 -0
  643. package/es/player/type/discrete-player.d.ts +9 -0
  644. package/es/player/type/discrete-player.js +2 -0
  645. package/es/player/type/discrete-player.js.map +1 -0
  646. package/es/player/type/event.d.ts +8 -0
  647. package/es/player/type/event.js +8 -0
  648. package/es/player/type/event.js.map +1 -0
  649. package/es/player/type/index.d.ts +9 -0
  650. package/es/player/type/index.js +12 -0
  651. package/es/player/type/index.js.map +1 -0
  652. package/es/player/type/layout.d.ts +35 -0
  653. package/es/player/type/layout.js +2 -0
  654. package/es/player/type/layout.js.map +1 -0
  655. package/es/player/utils.d.ts +20 -0
  656. package/es/player/utils.js +45 -0
  657. package/es/player/utils.js.map +1 -0
  658. package/es/scrollbar/index.d.ts +2 -0
  659. package/es/scrollbar/index.js +4 -0
  660. package/es/scrollbar/index.js.map +1 -0
  661. package/es/scrollbar/scrollbar.d.ts +43 -0
  662. package/es/scrollbar/scrollbar.js +154 -0
  663. package/es/scrollbar/scrollbar.js.map +1 -0
  664. package/es/scrollbar/type.d.ts +16 -0
  665. package/es/scrollbar/type.js +2 -0
  666. package/es/scrollbar/type.js.map +1 -0
  667. package/es/segment/index.d.ts +2 -0
  668. package/es/segment/index.js +4 -0
  669. package/es/segment/index.js.map +1 -0
  670. package/es/segment/segment.d.ts +18 -0
  671. package/es/segment/segment.js +103 -0
  672. package/es/segment/segment.js.map +1 -0
  673. package/es/segment/type.d.ts +22 -0
  674. package/es/segment/type.js +2 -0
  675. package/es/segment/type.js.map +1 -0
  676. package/es/slider/constant.d.ts +13 -0
  677. package/es/slider/constant.js +11 -0
  678. package/es/slider/constant.js.map +1 -0
  679. package/es/slider/index.d.ts +3 -0
  680. package/es/slider/index.js +6 -0
  681. package/es/slider/index.js.map +1 -0
  682. package/es/slider/slider.d.ts +96 -0
  683. package/es/slider/slider.js +399 -0
  684. package/es/slider/slider.js.map +1 -0
  685. package/es/slider/type.d.ts +44 -0
  686. package/es/slider/type.js +2 -0
  687. package/es/slider/type.js.map +1 -0
  688. package/es/tag/index.d.ts +2 -0
  689. package/es/tag/index.js +4 -0
  690. package/es/tag/index.js.map +1 -0
  691. package/es/tag/tag.d.ts +8 -0
  692. package/es/tag/tag.js +97 -0
  693. package/es/tag/tag.js.map +1 -0
  694. package/es/tag/type.d.ts +24 -0
  695. package/es/tag/type.js +2 -0
  696. package/es/tag/type.js.map +1 -0
  697. package/es/title/index.d.ts +2 -0
  698. package/es/title/index.js +4 -0
  699. package/es/title/index.js.map +1 -0
  700. package/es/title/title.d.ts +10 -0
  701. package/es/title/title.js +125 -0
  702. package/es/title/title.js.map +1 -0
  703. package/es/title/type.d.ts +41 -0
  704. package/es/title/type.js +2 -0
  705. package/es/title/type.js.map +1 -0
  706. package/es/tooltip/config.d.ts +3 -0
  707. package/es/tooltip/config.js +76 -0
  708. package/es/tooltip/config.js.map +1 -0
  709. package/es/tooltip/index.d.ts +2 -0
  710. package/es/tooltip/index.js +4 -0
  711. package/es/tooltip/index.js.map +1 -0
  712. package/es/tooltip/tooltip.d.ts +18 -0
  713. package/es/tooltip/tooltip.js +161 -0
  714. package/es/tooltip/tooltip.js.map +1 -0
  715. package/es/tooltip/type.d.ts +60 -0
  716. package/es/tooltip/type.js +2 -0
  717. package/es/tooltip/type.js.map +1 -0
  718. package/es/tooltip/util.d.ts +2 -0
  719. package/es/tooltip/util.js +11 -0
  720. package/es/tooltip/util.js.map +1 -0
  721. package/es/util/common.d.ts +3 -0
  722. package/es/util/common.js +11 -0
  723. package/es/util/common.js.map +1 -0
  724. package/es/util/index.d.ts +4 -0
  725. package/es/util/index.js +8 -0
  726. package/es/util/index.js.map +1 -0
  727. package/es/util/labelSmartInvert.d.ts +2 -0
  728. package/es/util/labelSmartInvert.js +39 -0
  729. package/es/util/labelSmartInvert.js.map +1 -0
  730. package/es/util/matrix.d.ts +4 -0
  731. package/es/util/matrix.js +13 -0
  732. package/es/util/matrix.js.map +1 -0
  733. package/es/util/text.d.ts +7 -0
  734. package/es/util/text.js +38 -0
  735. package/es/util/text.js.map +1 -0
  736. package/package.json +49 -0
@@ -0,0 +1,186 @@
1
+ var __rest = this && this.__rest || function(s, e) {
2
+ var t = {};
3
+ for (var p in s) Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0 && (t[p] = s[p]);
4
+ if (null != s && "function" == typeof Object.getOwnPropertySymbols) {
5
+ var i = 0;
6
+ for (p = Object.getOwnPropertySymbols(s); i < p.length; i++) e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]) && (t[p[i]] = s[p[i]]);
7
+ }
8
+ return t;
9
+ };
10
+
11
+ import { createCircle } from "@visactor/vrender";
12
+
13
+ import { isNil, get, merge, polarToCartesian, isNumberClose, isEmpty } from "@visactor/vutils";
14
+
15
+ import { vec2 } from "../util/matrix";
16
+
17
+ import { POLAR_END_ANGLE, POLAR_START_ANGLE } from "../constant";
18
+
19
+ import { AxisBase } from "./base";
20
+
21
+ import { DEFAULT_AXIS_THEME } from "./config";
22
+
23
+ import { AXIS_ELEMENT_NAME, DEFAULT_STATES } from "./constant";
24
+
25
+ export class CircleAxis extends AxisBase {
26
+ constructor(attributes) {
27
+ super(merge({}, CircleAxis.defaultAttributes, attributes));
28
+ }
29
+ renderLine(container) {
30
+ const {startAngle: startAngle = POLAR_START_ANGLE, endAngle: endAngle = POLAR_END_ANGLE, radius: radius, center: center, innerRadius: innerRadius = 0, line: line, inside: inside = !1} = this.attribute;
31
+ let arcRadius = radius, arcInnerRadius = innerRadius;
32
+ inside && innerRadius > 0 && (arcRadius = innerRadius, arcInnerRadius = 0);
33
+ const arcAttrs = Object.assign(Object.assign(Object.assign({}, center), {
34
+ startAngle: startAngle,
35
+ endAngle: endAngle,
36
+ radius: arcRadius,
37
+ innerRadius: arcInnerRadius
38
+ }), null == line ? void 0 : line.style), axisLine = createCircle(arcAttrs);
39
+ axisLine.name = AXIS_ELEMENT_NAME.line, axisLine.id = this._getNodeId("line"), isEmpty(null == line ? void 0 : line.state) || (axisLine.states = merge({}, DEFAULT_STATES, line.state)),
40
+ container.add(axisLine);
41
+ }
42
+ isInValidValue(value) {
43
+ const {startAngle: startAngle = POLAR_START_ANGLE, endAngle: endAngle = POLAR_END_ANGLE} = this.attribute;
44
+ return Math.abs(endAngle - startAngle) % (2 * Math.PI) == 0 ? value > 1 : value < 0 || value > 1;
45
+ }
46
+ getTickCoord(tickValue) {
47
+ const {startAngle: startAngle = POLAR_START_ANGLE, endAngle: endAngle = POLAR_END_ANGLE, center: center, radius: radius, inside: inside = !1, innerRadius: innerRadius = 0} = this.attribute;
48
+ return polarToCartesian(center, inside && innerRadius > 0 ? innerRadius : radius, startAngle + (endAngle - startAngle) * tickValue);
49
+ }
50
+ getVerticalVector(offset, inside = !1, point) {
51
+ const {inside: axisInside = !1} = this.attribute, {center: center} = this.attribute, vector = [ point.x - center.x, point.y - center.y ];
52
+ return vec2.scale(vector, vector, (inside ? -1 : 1) * (axisInside ? -1 : 1) * offset / vec2.length(vector)),
53
+ vector;
54
+ }
55
+ getRelativeVector(point) {
56
+ const {center: center} = this.attribute;
57
+ return [ point.y - center.y, -1 * (point.x - center.x) ];
58
+ }
59
+ getTitleAttribute() {
60
+ var _a, _b, _c, _d, _e, _f, _g, _h;
61
+ const {center: center, radius: radius, innerRadius: innerRadius = 0} = this.attribute, _j = this.attribute.title, {space: space = 4, textStyle: textStyle = {}, shape: shape, background: background, state: state} = _j, restAttrs = __rest(_j, [ "space", "textStyle", "shape", "background", "state" ]);
62
+ let titlePoint = center, labelHeight = 0;
63
+ (null === (_a = this.attribute.label) || void 0 === _a ? void 0 : _a.visible) && !1 === (null === (_b = this.attribute.label) || void 0 === _b ? void 0 : _b.inside) && (labelHeight = get(this.attribute.label, "style.fontSize", 12) + get(this.attribute.label, "space", 4));
64
+ let tickLength = 0;
65
+ (null === (_c = this.attribute.tick) || void 0 === _c ? void 0 : _c.visible) && !1 === (null === (_d = this.attribute.tick) || void 0 === _d ? void 0 : _d.inside) && (tickLength = (null === (_e = this.attribute.tick) || void 0 === _e ? void 0 : _e.length) || 4),
66
+ (null === (_f = this.attribute.subTick) || void 0 === _f ? void 0 : _f.visible) && !1 === (null === (_g = this.attribute.subTick) || void 0 === _g ? void 0 : _g.inside) && (tickLength = Math.max(tickLength, (null === (_h = this.attribute.subTick) || void 0 === _h ? void 0 : _h.length) || 2));
67
+ const offset = radius + tickLength + labelHeight + space;
68
+ let textBaseline = "middle", {position: position} = this.attribute.title;
69
+ isNil(position) && (position = 0 === innerRadius ? "end" : "middle"), "start" === position ? (textBaseline = "bottom",
70
+ titlePoint = {
71
+ x: center.x,
72
+ y: center.y - offset
73
+ }) : "end" === position && (textBaseline = "top", titlePoint = {
74
+ x: center.x,
75
+ y: center.y + offset
76
+ });
77
+ const attrs = Object.assign(Object.assign(Object.assign({}, titlePoint), restAttrs), {
78
+ textStyle: Object.assign({
79
+ textBaseline: textBaseline,
80
+ textAlign: "center"
81
+ }, textStyle),
82
+ state: isEmpty(state) ? null : {
83
+ text: state.text,
84
+ shape: state.shape,
85
+ panel: state.background
86
+ }
87
+ }), {angle: angle} = restAttrs;
88
+ return attrs.angle = angle, shape && shape.visible && (attrs.shape = Object.assign({
89
+ visible: !0
90
+ }, shape.style), shape.space && (attrs.space = shape.space)), background && background.visible && (attrs.panel = Object.assign({
91
+ visible: !0
92
+ }, background.style)), attrs;
93
+ }
94
+ getSubTickLineItems() {
95
+ var _a, _b;
96
+ const {subTick: subTick} = this.attribute, subTickLineItems = [], {count: subCount = 4, inside: inside = !1, length: length = 2} = subTick, tickLineItems = this.tickLineItems, tickLineCount = tickLineItems.length;
97
+ if (tickLineCount >= 2) {
98
+ const tickSegment = this.data[1].value - this.data[0].value, isAlignWithLable = null === (_b = null === (_a = this.attribute) || void 0 === _a ? void 0 : _a.tick) || void 0 === _b ? void 0 : _b.alignWithLabel;
99
+ for (let i = 0; i < tickLineCount; i++) {
100
+ const pre = tickLineItems[i], next = tickLineItems[i + 1];
101
+ for (let j = 0; j < subCount; j++) {
102
+ const percent = (j + 1) / (subCount + 1), value = (1 - percent) * pre.value + percent * (next ? next.value : isAlignWithLable ? 1 : pre.value + tickSegment), point = this.getTickCoord(value), endPoint = this.getVerticalCoord(point, length, inside);
103
+ subTickLineItems.push({
104
+ start: point,
105
+ end: endPoint,
106
+ value: value
107
+ });
108
+ }
109
+ }
110
+ }
111
+ return subTickLineItems;
112
+ }
113
+ getGridAttribute(type) {
114
+ let gridAttribute, items = [];
115
+ const {radius: radius, innerRadius: innerRadius = 0, startAngle: startAngle = POLAR_START_ANGLE, endAngle: endAngle = POLAR_END_ANGLE, center: center, grid: grid} = this.attribute, {alignWithLabel: alignWithLabel = !0} = grid || {}, length = radius - innerRadius;
116
+ let tickSegment = 1;
117
+ if (this.data.length >= 2 && (tickSegment = this.data[1].value - this.data[0].value),
118
+ "grid" === type) {
119
+ gridAttribute = this.attribute.grid;
120
+ const gridItems = [];
121
+ let data;
122
+ data = Math.abs(endAngle - startAngle) % (2 * Math.PI) == 0 ? [ ...this.data ].concat(this.data[0]) : this.data,
123
+ data.forEach((item => {
124
+ let {point: point} = item;
125
+ if (!alignWithLabel) {
126
+ const value = item.value - tickSegment / 2;
127
+ if (this.isInValidValue(value)) return;
128
+ point = this.getTickCoord(value);
129
+ }
130
+ const endPoint = this.getVerticalCoord(point, length, !0);
131
+ gridItems.push({
132
+ id: item.id,
133
+ points: [ point, endPoint ],
134
+ datum: item
135
+ });
136
+ })), items = gridItems;
137
+ } else {
138
+ gridAttribute = merge({}, this.attribute.grid, this.attribute.subGrid);
139
+ const subGridItems = [], {count: subCount = 4} = this.attribute.subTick || {}, tickLineCount = this.data.length;
140
+ if (tickLineCount >= 2) {
141
+ const points = [];
142
+ this.data.forEach((item => {
143
+ let tickValue = item.value;
144
+ if (!alignWithLabel) {
145
+ const value = item.value - tickSegment / 2;
146
+ if (this.isInValidValue(value)) return;
147
+ tickValue = value;
148
+ }
149
+ points.push({
150
+ value: tickValue
151
+ });
152
+ }));
153
+ for (let i = 0; i < tickLineCount; i++) {
154
+ const pre = points[i], next = points[i + 1];
155
+ subGridItems.push({
156
+ id: `sub-${i}-0`,
157
+ points: [ this.getTickCoord(pre.value), this.getVerticalCoord(this.getTickCoord(pre.value), length, !0) ],
158
+ datum: {}
159
+ });
160
+ for (let j = 0; j < subCount; j++) {
161
+ const percent = (j + 1) / (subCount + 1), value = (1 - percent) * pre.value + percent * (next ? next.value : alignWithLabel ? 1 : pre.value + tickSegment), point = this.getTickCoord(value), endPoint = this.getVerticalCoord(point, length, !0);
162
+ subGridItems.push({
163
+ id: `sub-${i}-${j + 1}`,
164
+ points: [ point, endPoint ],
165
+ datum: {}
166
+ });
167
+ }
168
+ }
169
+ Math.abs(endAngle - startAngle) % (2 * Math.PI) == 0 && subGridItems.push(subGridItems[0]),
170
+ items = subGridItems;
171
+ }
172
+ }
173
+ return Object.assign(Object.assign({}, gridAttribute), {
174
+ items: items,
175
+ center: center
176
+ });
177
+ }
178
+ getTextBaseline(vector) {
179
+ let base = "middle";
180
+ return isNumberClose(vector[1], 0) ? base = "middle" : vector[1] > 0 && vector[1] > Math.abs(vector[0]) ? base = "top" : vector[1] < 0 && Math.abs(vector[1]) > Math.abs(vector[0]) && (base = "bottom"),
181
+ base;
182
+ }
183
+ }
184
+
185
+ CircleAxis.defaultAttributes = DEFAULT_AXIS_THEME;
186
+ //# sourceMappingURL=circle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/axis/circle.ts"],"names":[],"mappings":"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","file":"circle.js","sourcesContent":["/**\n * @description 圆弧型坐标轴\n */\nimport { IGroup, TextBaselineType, createCircle } from '@visactor/vrender';\nimport { isNil, get, merge, polarToCartesian, isNumberClose, isEmpty } from '@visactor/vutils';\nimport { Point } from '../core/type';\nimport { vec2 } from '../util/matrix';\nimport { TagAttributes } from '../tag';\nimport { POLAR_END_ANGLE, POLAR_START_ANGLE } from '../constant';\nimport {\n CircleAxisGridAttributes,\n CircleAxisAttributes,\n TitleAttributes,\n GridItem,\n SubTickAttributes,\n TickLineItem,\n TransformedAxisItem\n} from './type';\nimport { AxisBase } from './base';\nimport { DEFAULT_AXIS_THEME } from './config';\nimport { AXIS_ELEMENT_NAME, DEFAULT_STATES } from './constant';\n\nexport class CircleAxis extends AxisBase<CircleAxisAttributes> {\n static defaultAttributes = DEFAULT_AXIS_THEME;\n\n constructor(attributes: CircleAxisAttributes) {\n super(merge({}, CircleAxis.defaultAttributes, attributes));\n }\n\n protected renderLine(container: IGroup): void {\n const {\n startAngle = POLAR_START_ANGLE,\n endAngle = POLAR_END_ANGLE,\n radius,\n center,\n innerRadius = 0,\n line,\n inside = false\n } = this.attribute as CircleAxisAttributes;\n\n let arcRadius = radius;\n let arcInnerRadius = innerRadius;\n if (inside && innerRadius > 0) {\n arcRadius = innerRadius;\n arcInnerRadius = 0;\n }\n\n const arcAttrs = {\n ...center,\n startAngle,\n endAngle,\n radius: arcRadius,\n innerRadius: arcInnerRadius,\n ...line?.style\n };\n const axisLine = createCircle(arcAttrs);\n axisLine.name = AXIS_ELEMENT_NAME.line;\n axisLine.id = this._getNodeId('line');\n\n if (!isEmpty(line?.state)) {\n axisLine.states = merge({}, DEFAULT_STATES, line.state);\n }\n container.add(axisLine);\n }\n\n protected isInValidValue(value: number) {\n const { startAngle = POLAR_START_ANGLE, endAngle = POLAR_END_ANGLE } = this.attribute as CircleAxisAttributes;\n if (Math.abs(endAngle - startAngle) % (Math.PI * 2) === 0) {\n return value > 1;\n }\n\n return value < 0 || value > 1;\n }\n\n protected getTickCoord(tickValue: number): Point {\n const {\n startAngle = POLAR_START_ANGLE,\n endAngle = POLAR_END_ANGLE,\n center,\n radius,\n inside = false,\n innerRadius = 0\n } = this.attribute as CircleAxisAttributes;\n const angle = startAngle + (endAngle - startAngle) * tickValue;\n return polarToCartesian(center, inside && innerRadius > 0 ? innerRadius : radius, angle);\n }\n\n protected getVerticalVector(offset: number, inside = false, point: Point) {\n const { inside: axisInside = false } = this.attribute;\n const { center } = this.attribute as CircleAxisAttributes;\n const vector: [number, number] = [point.x - center.x, point.y - center.y];\n vec2.scale(vector, vector, ((inside ? -1 : 1) * (axisInside ? -1 : 1) * offset) / vec2.length(vector));\n return vector;\n }\n\n protected getRelativeVector(point: Point): [number, number] {\n const { center } = this.attribute as CircleAxisAttributes;\n return [point.y - center.y, -1 * (point.x - center.x)];\n }\n\n protected getTitleAttribute() {\n const { center, radius, innerRadius = 0 } = this.attribute as CircleAxisAttributes;\n const {\n space = 4,\n textStyle = {},\n shape,\n background,\n state,\n ...restAttrs\n } = this.attribute.title as TitleAttributes;\n let titlePoint = center;\n let labelHeight = 0;\n if (this.attribute.label?.visible && this.attribute.label?.inside === false) {\n // 这里取 label 的最大长度\n labelHeight = get(this.attribute.label, 'style.fontSize', 12) + get(this.attribute.label, 'space', 4);\n }\n let tickLength = 0;\n if (this.attribute.tick?.visible && this.attribute.tick?.inside === false) {\n tickLength = this.attribute.tick?.length || 4;\n }\n if (this.attribute.subTick?.visible && this.attribute.subTick?.inside === false) {\n tickLength = Math.max(tickLength, this.attribute.subTick?.length || 2);\n }\n const offset = radius + tickLength + labelHeight + space;\n let textBaseline: TextBaselineType = 'middle';\n let { position } = this.attribute.title as TitleAttributes;\n if (isNil(position)) {\n position = innerRadius === 0 ? 'end' : 'middle';\n }\n if (position === 'start') {\n textBaseline = 'bottom';\n titlePoint = {\n x: center.x,\n y: center.y - offset\n };\n } else if (position === 'end') {\n textBaseline = 'top';\n titlePoint = {\n x: center.x,\n y: center.y + offset\n };\n }\n const attrs: TagAttributes = {\n ...titlePoint,\n ...restAttrs,\n textStyle: {\n textBaseline,\n textAlign: 'center',\n ...textStyle\n },\n state: isEmpty(state)\n ? null\n : {\n text: state.text,\n shape: state.shape,\n panel: state.background\n }\n };\n\n const { angle } = restAttrs; // 用户设置的是角度\n attrs.angle = angle;\n\n if (shape && shape.visible) {\n attrs.shape = {\n visible: true,\n ...shape.style\n };\n if (shape.space) {\n attrs.space = shape.space;\n }\n }\n\n if (background && background.visible) {\n attrs.panel = {\n visible: true,\n ...background.style\n };\n }\n\n return attrs;\n }\n\n protected getSubTickLineItems() {\n const { subTick } = this.attribute as CircleAxisAttributes;\n const subTickLineItems: TickLineItem[] = [];\n const { count: subCount = 4, inside = false, length = 2 } = subTick as SubTickAttributes;\n const tickLineItems = this.tickLineItems;\n const tickLineCount = tickLineItems.length;\n // 刻度线的数量大于 2 时,才绘制子刻度\n if (tickLineCount >= 2) {\n const tickSegment = this.data[1].value - this.data[0].value;\n const isAlignWithLable = this.attribute?.tick?.alignWithLabel;\n for (let i = 0; i < tickLineCount; i++) {\n const pre = tickLineItems[i];\n const next = tickLineItems[i + 1];\n for (let j = 0; j < subCount; j++) {\n const percent = (j + 1) / (subCount + 1);\n const value =\n (1 - percent) * pre.value + percent * (next ? next.value : isAlignWithLable ? 1 : pre.value + tickSegment);\n const point = this.getTickCoord(value);\n const endPoint = this.getVerticalCoord(point, length, inside);\n subTickLineItems.push({\n start: point,\n end: endPoint,\n value\n });\n }\n }\n }\n\n return subTickLineItems;\n }\n\n protected getGridAttribute(type: string) {\n let gridAttribute;\n let items: GridItem[] = [];\n const {\n radius,\n innerRadius = 0,\n startAngle = POLAR_START_ANGLE,\n endAngle = POLAR_END_ANGLE,\n center,\n grid\n } = this.attribute as CircleAxisAttributes;\n const { alignWithLabel = true } = grid || {};\n\n const length = radius - innerRadius;\n let tickSegment = 1;\n const count = this.data.length;\n if (count >= 2) {\n tickSegment = this.data[1].value - this.data[0].value;\n }\n if (type === 'grid') {\n gridAttribute = this.attribute.grid as CircleAxisGridAttributes;\n // 计算 grid Items\n const gridItems: GridItem[] = [];\n let data;\n if (Math.abs(endAngle - startAngle) % (Math.PI * 2) === 0) {\n data = [...this.data].concat(this.data[0]);\n } else {\n data = this.data;\n }\n\n data.forEach(item => {\n let { point } = item;\n if (!alignWithLabel) {\n // tickLine 不同 tick 对齐时需要调整 point\n const value = item.value - tickSegment / 2;\n if (this.isInValidValue(value)) {\n return;\n }\n point = this.getTickCoord(value);\n }\n const endPoint = this.getVerticalCoord(point, length as number, true);\n gridItems.push({\n id: item.id,\n points: [point, endPoint],\n datum: item\n });\n });\n items = gridItems;\n } else {\n // 渲染 subGrid\n gridAttribute = merge({}, this.attribute.grid, this.attribute.subGrid);\n // 计算 grid Items\n const subGridItems: GridItem[] = [];\n const { count: subCount = 4 } = this.attribute.subTick || {};\n const tickLineCount = this.data.length;\n // 刻度线的数量大于 2 时,才绘制子刻度\n if (tickLineCount >= 2) {\n const points: { value: number }[] = [];\n this.data.forEach((item: TransformedAxisItem) => {\n let tickValue = item.value;\n if (!alignWithLabel) {\n // tickLine 不同 tick 对齐时需要调整 point\n const value = item.value - tickSegment / 2;\n if (this.isInValidValue(value)) {\n return;\n }\n tickValue = value;\n }\n points.push({\n value: tickValue\n });\n });\n\n for (let i = 0; i < tickLineCount; i++) {\n const pre = points[i];\n const next = points[i + 1];\n subGridItems.push({\n id: `sub-${i}-${0}`,\n points: [this.getTickCoord(pre.value), this.getVerticalCoord(this.getTickCoord(pre.value), length, true)],\n datum: {}\n });\n for (let j = 0; j < subCount; j++) {\n const percent = (j + 1) / (subCount + 1);\n const value =\n (1 - percent) * pre.value + percent * (next ? next.value : alignWithLabel ? 1 : pre.value + tickSegment);\n const point = this.getTickCoord(value);\n const endPoint = this.getVerticalCoord(point, length, true);\n subGridItems.push({\n id: `sub-${i}-${j + 1}`,\n points: [point, endPoint],\n // TODO: 这里也需要,后续考虑如何加上\n datum: {}\n });\n }\n }\n\n if (Math.abs(endAngle - startAngle) % (Math.PI * 2) === 0) {\n subGridItems.push(subGridItems[0]);\n }\n\n items = subGridItems;\n }\n }\n\n return {\n ...gridAttribute,\n items,\n center\n };\n }\n protected getTextBaseline(vector: number[]): TextBaselineType {\n let base: TextBaselineType = 'middle';\n if (isNumberClose(vector[1], 0)) {\n base = 'middle';\n } else if (vector[1] > 0 && vector[1] > Math.abs(vector[0])) {\n base = 'top';\n } else if (vector[1] < 0 && Math.abs(vector[1]) > Math.abs(vector[0])) {\n base = 'bottom';\n }\n return base;\n }\n}\n"]}
@@ -0,0 +1,71 @@
1
+ export declare const DEFAULT_AXIS_THEME: {
2
+ title: {
3
+ space: number;
4
+ padding: number;
5
+ textStyle: {
6
+ fontSize: number;
7
+ fillColor: string;
8
+ fontWeight: string;
9
+ fillOpacity: number;
10
+ };
11
+ };
12
+ label: {
13
+ visible: boolean;
14
+ inside: boolean;
15
+ space: number;
16
+ padding: number;
17
+ style: {
18
+ fontSize: number;
19
+ fillColor: string;
20
+ fontWeight: string;
21
+ fillOpacity: number;
22
+ };
23
+ };
24
+ tick: {
25
+ visible: boolean;
26
+ inside: boolean;
27
+ alignWithLabel: boolean;
28
+ length: number;
29
+ style: {
30
+ lineWidth: number;
31
+ strokeColor: string;
32
+ strokeOpacity: number;
33
+ };
34
+ };
35
+ subTick: {
36
+ visible: boolean;
37
+ inside: boolean;
38
+ count: number;
39
+ length: number;
40
+ style: {
41
+ lineWidth: number;
42
+ strokeColor: string;
43
+ strokeOpacity: number;
44
+ };
45
+ };
46
+ line: {
47
+ visible: boolean;
48
+ style: {
49
+ lineWidth: number;
50
+ strokeColor: string;
51
+ strokeOpacity: number;
52
+ };
53
+ };
54
+ grid: {
55
+ style: {
56
+ lineWidth: number;
57
+ strokeColor: string;
58
+ strokeOpacity: number;
59
+ lineDash: number[];
60
+ };
61
+ };
62
+ subGrid: {
63
+ visible: boolean;
64
+ style: {
65
+ lineWidth: number;
66
+ strokeColor: string;
67
+ strokeOpacity: number;
68
+ lineDash: number[];
69
+ };
70
+ };
71
+ };
@@ -0,0 +1,72 @@
1
+ export const DEFAULT_AXIS_THEME = {
2
+ title: {
3
+ space: 4,
4
+ padding: 0,
5
+ textStyle: {
6
+ fontSize: 12,
7
+ fillColor: "#333333",
8
+ fontWeight: "normal",
9
+ fillOpacity: 1
10
+ }
11
+ },
12
+ label: {
13
+ visible: !0,
14
+ inside: !1,
15
+ space: 4,
16
+ padding: 0,
17
+ style: {
18
+ fontSize: 12,
19
+ fillColor: "#333",
20
+ fontWeight: "normal",
21
+ fillOpacity: 1
22
+ }
23
+ },
24
+ tick: {
25
+ visible: !0,
26
+ inside: !1,
27
+ alignWithLabel: !0,
28
+ length: 4,
29
+ style: {
30
+ lineWidth: 1,
31
+ strokeColor: "#000",
32
+ strokeOpacity: 1
33
+ }
34
+ },
35
+ subTick: {
36
+ visible: !1,
37
+ inside: !1,
38
+ count: 4,
39
+ length: 2,
40
+ style: {
41
+ lineWidth: 1,
42
+ strokeColor: "#999",
43
+ strokeOpacity: 1
44
+ }
45
+ },
46
+ line: {
47
+ visible: !0,
48
+ style: {
49
+ lineWidth: 1,
50
+ strokeColor: "#000",
51
+ strokeOpacity: 1
52
+ }
53
+ },
54
+ grid: {
55
+ style: {
56
+ lineWidth: 1,
57
+ strokeColor: "#999",
58
+ strokeOpacity: 1,
59
+ lineDash: [ 4, 4 ]
60
+ }
61
+ },
62
+ subGrid: {
63
+ visible: !1,
64
+ style: {
65
+ lineWidth: 1,
66
+ strokeColor: "#999",
67
+ strokeOpacity: 1,
68
+ lineDash: [ 4, 4 ]
69
+ }
70
+ }
71
+ };
72
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/axis/config.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,KAAK,EAAE;QACL,KAAK,EAAE,CAAC;QACR,OAAO,EAAE,CAAC;QACV,SAAS,EAAE;YACT,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,SAAS;YACpB,UAAU,EAAE,QAAQ;YACpB,WAAW,EAAE,CAAC;SACf;KACF;IACD,KAAK,EAAE;QACL,OAAO,EAAE,IAAI;QACb,MAAM,EAAE,KAAK;QACb,KAAK,EAAE,CAAC;QACR,OAAO,EAAE,CAAC;QACV,KAAK,EAAE;YACL,QAAQ,EAAE,EAAE;YACZ,SAAS,EAAE,MAAM;YACjB,UAAU,EAAE,QAAQ;YACpB,WAAW,EAAE,CAAC;SACf;KACF;IACD,IAAI,EAAE;QACJ,OAAO,EAAE,IAAI;QACb,MAAM,EAAE,KAAK;QACb,cAAc,EAAE,IAAI;QACpB,MAAM,EAAE,CAAC;QACT,KAAK,EAAE;YACL,SAAS,EAAE,CAAC;YACZ,WAAW,EAAE,MAAM;YACnB,aAAa,EAAE,CAAC;SACjB;KACF;IACD,OAAO,EAAE;QACP,OAAO,EAAE,KAAK;QACd,MAAM,EAAE,KAAK;QACb,KAAK,EAAE,CAAC;QACR,MAAM,EAAE,CAAC;QACT,KAAK,EAAE;YACL,SAAS,EAAE,CAAC;YACZ,WAAW,EAAE,MAAM;YACnB,aAAa,EAAE,CAAC;SACjB;KACF;IACD,IAAI,EAAE;QACJ,OAAO,EAAE,IAAI;QACb,KAAK,EAAE;YACL,SAAS,EAAE,CAAC;YACZ,WAAW,EAAE,MAAM;YACnB,aAAa,EAAE,CAAC;SACjB;KACF;IACD,IAAI,EAAE;QACJ,KAAK,EAAE;YACL,SAAS,EAAE,CAAC;YACZ,WAAW,EAAE,MAAM;YACnB,aAAa,EAAE,CAAC;YAChB,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;SACjB;KACF;IACD,OAAO,EAAE;QACP,OAAO,EAAE,KAAK;QACd,KAAK,EAAE;YACL,SAAS,EAAE,CAAC;YACZ,WAAW,EAAE,MAAM;YACnB,aAAa,EAAE,CAAC;YAChB,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;SACjB;KACF;CACF,CAAC","file":"config.js","sourcesContent":["export const DEFAULT_AXIS_THEME = {\n title: {\n space: 4,\n padding: 0,\n textStyle: {\n fontSize: 12,\n fillColor: '#333333',\n fontWeight: 'normal',\n fillOpacity: 1\n }\n },\n label: {\n visible: true,\n inside: false,\n space: 4,\n padding: 0,\n style: {\n fontSize: 12,\n fillColor: '#333',\n fontWeight: 'normal',\n fillOpacity: 1\n }\n },\n tick: {\n visible: true,\n inside: false,\n alignWithLabel: true,\n length: 4,\n style: {\n lineWidth: 1,\n strokeColor: '#000',\n strokeOpacity: 1\n }\n },\n subTick: {\n visible: false,\n inside: false,\n count: 4,\n length: 2,\n style: {\n lineWidth: 1,\n strokeColor: '#999',\n strokeOpacity: 1\n }\n },\n line: {\n visible: true,\n style: {\n lineWidth: 1,\n strokeColor: '#000',\n strokeOpacity: 1\n }\n },\n grid: {\n style: {\n lineWidth: 1,\n strokeColor: '#999',\n strokeOpacity: 1,\n lineDash: [4, 4]\n }\n },\n subGrid: {\n visible: false,\n style: {\n lineWidth: 1,\n strokeColor: '#999',\n strokeOpacity: 1,\n lineDash: [4, 4]\n }\n }\n};\n"]}
@@ -0,0 +1,27 @@
1
+ export declare enum AXIS_ELEMENT_NAME {
2
+ innerView = "inner-view",
3
+ axisContainer = "axis-container",
4
+ labelContainer = "axis-label-container",
5
+ tickContainer = "axis-tick-container",
6
+ tick = "axis-tick",
7
+ subTick = "axis-sub-tick",
8
+ label = "axis-label",
9
+ title = "axis-title",
10
+ gridContainer = "axis-grid-container",
11
+ grid = "axis-grid",
12
+ gridRegion = "axis-grid-region",
13
+ line = "axis-line",
14
+ background = "axis-background"
15
+ }
16
+ export declare enum AxisStateValue {
17
+ selected = "selected",
18
+ selectedReverse = "selected_reverse",
19
+ hover = "hover",
20
+ hoverReverse = "hover_reverse"
21
+ }
22
+ export declare const DEFAULT_STATES: {
23
+ selected_reverse: {};
24
+ selected: {};
25
+ hover: {};
26
+ hover_reverse: {};
27
+ };
@@ -0,0 +1,26 @@
1
+ export var AXIS_ELEMENT_NAME;
2
+
3
+ !function(AXIS_ELEMENT_NAME) {
4
+ AXIS_ELEMENT_NAME.innerView = "inner-view", AXIS_ELEMENT_NAME.axisContainer = "axis-container",
5
+ AXIS_ELEMENT_NAME.labelContainer = "axis-label-container", AXIS_ELEMENT_NAME.tickContainer = "axis-tick-container",
6
+ AXIS_ELEMENT_NAME.tick = "axis-tick", AXIS_ELEMENT_NAME.subTick = "axis-sub-tick",
7
+ AXIS_ELEMENT_NAME.label = "axis-label", AXIS_ELEMENT_NAME.title = "axis-title",
8
+ AXIS_ELEMENT_NAME.gridContainer = "axis-grid-container", AXIS_ELEMENT_NAME.grid = "axis-grid",
9
+ AXIS_ELEMENT_NAME.gridRegion = "axis-grid-region", AXIS_ELEMENT_NAME.line = "axis-line",
10
+ AXIS_ELEMENT_NAME.background = "axis-background";
11
+ }(AXIS_ELEMENT_NAME || (AXIS_ELEMENT_NAME = {}));
12
+
13
+ export var AxisStateValue;
14
+
15
+ !function(AxisStateValue) {
16
+ AxisStateValue.selected = "selected", AxisStateValue.selectedReverse = "selected_reverse",
17
+ AxisStateValue.hover = "hover", AxisStateValue.hoverReverse = "hover_reverse";
18
+ }(AxisStateValue || (AxisStateValue = {}));
19
+
20
+ export const DEFAULT_STATES = {
21
+ [AxisStateValue.selectedReverse]: {},
22
+ [AxisStateValue.selected]: {},
23
+ [AxisStateValue.hover]: {},
24
+ [AxisStateValue.hoverReverse]: {}
25
+ };
26
+ //# sourceMappingURL=constant.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/axis/constant.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,iBAcX;AAdD,WAAY,iBAAiB;IAC3B,6CAAwB,CAAA;IACxB,qDAAgC,CAAA;IAChC,4DAAuC,CAAA;IACvC,0DAAqC,CAAA;IACrC,uCAAkB,CAAA;IAClB,8CAAyB,CAAA;IACzB,yCAAoB,CAAA;IACpB,yCAAoB,CAAA;IACpB,0DAAqC,CAAA;IACrC,uCAAkB,CAAA;IAClB,oDAA+B,CAAA;IAC/B,uCAAkB,CAAA;IAClB,mDAA8B,CAAA;AAChC,CAAC,EAdW,iBAAiB,KAAjB,iBAAiB,QAc5B;AAED,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,uCAAqB,CAAA;IACrB,sDAAoC,CAAA;IACpC,iCAAe,CAAA;IACf,gDAA8B,CAAA;AAChC,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE,EAAE;IACpC,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,EAAE;IAC7B,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE,EAAE;IAC1B,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE,EAAE;CAClC,CAAC","file":"constant.js","sourcesContent":["export enum AXIS_ELEMENT_NAME {\n innerView = 'inner-view',\n axisContainer = 'axis-container',\n labelContainer = 'axis-label-container',\n tickContainer = 'axis-tick-container',\n tick = 'axis-tick',\n subTick = 'axis-sub-tick',\n label = 'axis-label',\n title = 'axis-title',\n gridContainer = 'axis-grid-container',\n grid = 'axis-grid',\n gridRegion = 'axis-grid-region',\n line = 'axis-line',\n background = 'axis-background'\n}\n\nexport enum AxisStateValue {\n selected = 'selected',\n selectedReverse = 'selected_reverse',\n hover = 'hover',\n hoverReverse = 'hover_reverse'\n}\n\nexport const DEFAULT_STATES = {\n [AxisStateValue.selectedReverse]: {},\n [AxisStateValue.selected]: {},\n [AxisStateValue.hover]: {},\n [AxisStateValue.hoverReverse]: {}\n};\n"]}
@@ -0,0 +1,9 @@
1
+ import { AbstractComponent } from '../core/base';
2
+ import { GridAttributes } from './type';
3
+ export declare class Grid extends AbstractComponent<Required<GridAttributes>> {
4
+ name: string;
5
+ static defaultAttributes: Partial<GridAttributes>;
6
+ constructor(attributes: GridAttributes);
7
+ protected render(): void;
8
+ protected _getNodeId(id: string): string;
9
+ }
@@ -0,0 +1,102 @@
1
+ import { isFunction, isArray, isEmpty, merge, PointService, abs, pi } from "@visactor/vutils";
2
+
3
+ import { createPath } from "@visactor/vrender";
4
+
5
+ import { AbstractComponent } from "../core/base";
6
+
7
+ function getLinePath(points, closed) {
8
+ let path = "";
9
+ return 0 === points.length || (points.forEach(((point, index) => {
10
+ 0 === index ? path = `M${point.x},${point.y}` : path += `L${point.x},${point.y}`;
11
+ })), closed && (path += "Z")), path;
12
+ }
13
+
14
+ function getArcPath(center, points, reverse, closed) {
15
+ let path = "";
16
+ if (!center || 0 === points.length) return path;
17
+ const firstPoint = points[0], radius = PointService.distancePP(center, firstPoint), sweepFlag = reverse ? 0 : 1;
18
+ return closed ? path += `M${center.x},${center.y - radius}A${radius},${radius},0,0,${sweepFlag},${center.x},${center.y + radius}A${radius},${radius},0,0,${sweepFlag},${center.x},${center.y - radius}Z` : points.forEach(((point, index) => {
19
+ 0 === index ? path = `M${point.x},${point.y}` : path += `A${radius},${radius},0,0,${sweepFlag},${point.x},${point.y}`;
20
+ })), path;
21
+ }
22
+
23
+ function getRegionPath(from, to, attribute) {
24
+ const {type: type, closed: closed} = attribute, reversePoints = to.slice(0).reverse();
25
+ let regionPath = "", nextPath = "";
26
+ if ("line" === type && attribute.smoothLink && attribute.center) {
27
+ const fromStart = from[0], toEnd = reversePoints[0], center = attribute.center;
28
+ regionPath = getLinePath(from, !!closed), nextPath = getLinePath(reversePoints, !!closed);
29
+ const toEndRadius = PointService.distancePP(toEnd, center), fromStartRadius = PointService.distancePP(fromStart, center);
30
+ regionPath += `A${toEndRadius},${toEndRadius},0,0,1,${toEnd.x},${toEnd.y}L${toEnd.x},${toEnd.y}`,
31
+ nextPath += `A${fromStartRadius},${fromStartRadius},0,0,0,${fromStart.x},${fromStart.y}`;
32
+ } else if ("circle" === type) {
33
+ const {center: center} = attribute;
34
+ regionPath = getArcPath(center, from, !1, !!closed), nextPath = getArcPath(center, reversePoints, !0, !!closed);
35
+ } else "line" !== type && "polygon" !== type || (regionPath = getLinePath(from, !!closed),
36
+ nextPath = getLinePath(reversePoints, !!closed));
37
+ return closed ? regionPath += nextPath : (nextPath = "L" + nextPath.substring(1),
38
+ regionPath += nextPath, regionPath += "Z"), regionPath;
39
+ }
40
+
41
+ export class Grid extends AbstractComponent {
42
+ constructor(attributes) {
43
+ super(merge({}, Grid.defaultAttributes, attributes)), this.name = "grid";
44
+ }
45
+ render() {
46
+ this.removeAllChild();
47
+ const {type: type, items: items, style: style, closed: closed, alternateColor: alternateColor, depth: depth = 0} = this.attribute;
48
+ if (!isEmpty(items) && (items.forEach(((item, index) => {
49
+ const {id: id, points: points} = item;
50
+ let path = "";
51
+ if ("line" === type || "polygon" === type) path = getLinePath(points, !!closed); else if ("circle" === type) {
52
+ const {center: center} = this.attribute;
53
+ path = getArcPath(center, points, !1, !!closed);
54
+ }
55
+ const shape = createPath(Object.assign({
56
+ path: path,
57
+ z: depth
58
+ }, isFunction(style) ? merge({}, Grid.defaultAttributes.style, style(item, index)) : style));
59
+ shape.name = `${this.name}-line`, shape.id = this._getNodeId(`path-${id}`), this.add(shape);
60
+ })), depth && "line" === type && items.forEach(((item, index) => {
61
+ const {id: id, points: points} = item, nextPoints = [];
62
+ nextPoints.push(points[0]);
63
+ const dir_x = points[1].x - points[0].x, dir_y = points[1].y - points[0].y, dirLen = Math.sqrt(dir_x * dir_x + dir_y * dir_y), ratio = depth / dirLen;
64
+ nextPoints.push({
65
+ x: points[0].x + dir_x * ratio,
66
+ y: points[0].y + dir_y * ratio
67
+ });
68
+ const path = getLinePath(nextPoints, !!closed), deltaX = abs(nextPoints[0].x - nextPoints[1].x), deltaY = abs(nextPoints[0].y - nextPoints[1].y), shape = createPath(Object.assign({
69
+ path: path,
70
+ z: 0,
71
+ alpha: deltaX > deltaY ? (points[1].x - points[0].x > 0 ? -1 : 1) * pi / 2 : 0,
72
+ beta: deltaX < deltaY ? -pi / 2 : 0,
73
+ anchor3d: deltaX > deltaY ? [ nextPoints[0].x, 0 ] : [ 0, nextPoints[0].y ]
74
+ }, isFunction(style) ? merge({}, Grid.defaultAttributes.style, style(item, index)) : style));
75
+ shape.name = `${this.name}-line`, shape.id = this._getNodeId(`path-${id}`), this.add(shape);
76
+ })), items.length > 1 && alternateColor)) {
77
+ const colors = isArray(alternateColor) ? alternateColor : [ alternateColor, "transparent" ], getColor = index => colors[index % colors.length];
78
+ for (let index = 0; index < items.length - 1; index++) {
79
+ const [prev, curr] = [ items[index].points, items[index + 1].points ], path = getRegionPath(prev, curr, this.attribute), shape = createPath({
80
+ path: path,
81
+ fill: !0,
82
+ fillColor: getColor(index)
83
+ });
84
+ shape.name = `${this.name}-region`, shape.id = this._getNodeId(`region-${index}`),
85
+ this.add(shape);
86
+ }
87
+ }
88
+ }
89
+ _getNodeId(id) {
90
+ return `${this.id}-${id}`;
91
+ }
92
+ }
93
+
94
+ Grid.defaultAttributes = {
95
+ style: {
96
+ lineWidth: 1,
97
+ stroke: !0,
98
+ strokeColor: "#416180"
99
+ },
100
+ zIndex: 0
101
+ };
102
+ //# sourceMappingURL=grid.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/axis/grid.ts"],"names":[],"mappings":"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","file":"grid.js","sourcesContent":["/**\n * @description 网格线\n */\nimport { isFunction, isArray, isEmpty, merge, PointService, abs, pi } from '@visactor/vutils';\nimport { createPath, Path } from '@visactor/vrender';\nimport { AbstractComponent } from '../core/base';\nimport { Point } from '../core/type';\nimport { LineGridAttributes, GridItem, GridAttributes, CircleGridAttributes } from './type';\n\nfunction getLinePath(points: Point[], closed: boolean) {\n let path = '';\n if (points.length === 0) {\n return path;\n }\n points.forEach((point, index) => {\n if (index === 0) {\n path = `M${point.x},${point.y}`;\n } else {\n path += `L${point.x},${point.y}`;\n }\n });\n if (closed) {\n path += 'Z';\n }\n\n return path;\n}\n\nfunction getArcPath(center: Point, points: Point[], reverse: boolean, closed: boolean) {\n let path = '';\n if (!center || points.length === 0) {\n return path;\n }\n const firstPoint = points[0];\n const radius = PointService.distancePP(center, firstPoint);\n const sweepFlag = reverse ? 0 : 1; // 顺时针还是逆时针\n if (closed) {\n // 封闭时,绘制整个圆\n path += `M${center.x},${center.y - radius}A${radius},${radius},0,0,${sweepFlag},${center.x},${\n center.y + radius\n }A${radius},${radius},0,0,${sweepFlag},${center.x},${center.y - radius}Z`;\n } else {\n points.forEach((point, index) => {\n if (index === 0) {\n path = `M${point.x},${point.y}`;\n } else {\n path += `A${radius},${radius},0,0,${sweepFlag},${point.x},${point.y}`;\n }\n });\n }\n\n return path;\n}\n\nfunction getRegionPath(from: Point[], to: Point[], attribute: GridAttributes) {\n const { type, closed } = attribute;\n const reversePoints = to.slice(0).reverse();\n\n let regionPath = '';\n let nextPath = '';\n\n if (type === 'line' && (attribute as LineGridAttributes).smoothLink && (attribute as LineGridAttributes).center) {\n const fromStart = from[0];\n const toEnd = reversePoints[0];\n const center = (attribute as LineGridAttributes).center as Point;\n\n regionPath = getLinePath(from, !!closed);\n nextPath = getLinePath(reversePoints, !!closed);\n const toEndRadius = PointService.distancePP(toEnd, center);\n const fromStartRadius = PointService.distancePP(fromStart, center);\n regionPath += `A${toEndRadius},${toEndRadius},0,0,1,${toEnd.x},${toEnd.y}L${toEnd.x},${toEnd.y}`;\n nextPath += `A${fromStartRadius},${fromStartRadius},0,0,0,${fromStart.x},${fromStart.y}`;\n } else if (type === 'circle') {\n const { center } = attribute as CircleGridAttributes;\n regionPath = getArcPath(center, from, false, !!closed);\n nextPath = getArcPath(center, reversePoints, true, !!closed);\n } else if (type === 'line' || type === 'polygon') {\n regionPath = getLinePath(from, !!closed);\n nextPath = getLinePath(reversePoints, !!closed);\n }\n\n if (closed) {\n regionPath += nextPath;\n } else {\n nextPath = 'L' + nextPath.substring(1); // 更新第一个节点\n regionPath += nextPath;\n regionPath += 'Z';\n }\n return regionPath;\n}\n\nexport class Grid extends AbstractComponent<Required<GridAttributes>> {\n name = 'grid';\n\n static defaultAttributes: Partial<GridAttributes> = {\n style: {\n lineWidth: 1,\n stroke: true,\n strokeColor: '#416180'\n },\n zIndex: 0\n };\n\n constructor(attributes: GridAttributes) {\n super(merge({}, Grid.defaultAttributes, attributes));\n }\n\n protected render(): void {\n this.removeAllChild();\n const {\n type,\n items,\n style,\n closed,\n alternateColor,\n // zIndex = 0,\n depth = 0\n } = this.attribute as GridAttributes & { depth?: number };\n\n if (isEmpty(items)) {\n return;\n }\n // 绘制网格线\n items.forEach((item: GridItem, index: number) => {\n const { id, points } = item;\n let path = '';\n if (type === 'line' || type === 'polygon') {\n path = getLinePath(points, !!closed);\n } else if (type === 'circle') {\n const { center } = this.attribute as CircleGridAttributes;\n path = getArcPath(center, points, false, !!closed);\n }\n const shape = createPath({\n path,\n z: depth,\n ...(isFunction(style) ? merge({}, Grid.defaultAttributes.style, style(item, index)) : style)\n }) as Path;\n shape.name = `${this.name}-line`;\n shape.id = this._getNodeId(`path-${id}`);\n this.add(shape);\n });\n\n // 添加额外的3d线段\n if (depth && type === 'line') {\n items.forEach((item: GridItem, index: number) => {\n const { id, points } = item;\n // 重新计算points,使其长度为depth\n const nextPoints = [];\n nextPoints.push(points[0]);\n const dir = { x: points[1].x - points[0].x, y: points[1].y - points[0].y };\n const dirLen = Math.sqrt(dir.x * dir.x + dir.y * dir.y);\n const ratio = depth / dirLen;\n nextPoints.push({ x: points[0].x + dir.x * ratio, y: points[0].y + dir.y * ratio });\n const path = getLinePath(nextPoints, !!closed);\n const deltaX = abs(nextPoints[0].x - nextPoints[1].x);\n const deltaY = abs(nextPoints[0].y - nextPoints[1].y);\n const shape = createPath({\n path,\n z: 0,\n alpha: deltaX > deltaY ? ((points[1].x - points[0].x > 0 ? -1 : 1) * pi) / 2 : 0,\n beta: deltaX < deltaY ? -pi / 2 : 0,\n anchor3d: deltaX > deltaY ? [nextPoints[0].x, 0] : [0, nextPoints[0].y],\n ...(isFunction(style) ? merge({}, Grid.defaultAttributes.style, style(item, index)) : style)\n }) as Path;\n shape.name = `${this.name}-line`;\n shape.id = this._getNodeId(`path-${id}`);\n this.add(shape);\n });\n }\n\n // 绘制填充区域\n if (items.length > 1 && alternateColor) {\n const colors: string[] = isArray(alternateColor)\n ? (alternateColor as string[])\n : [alternateColor as string, 'transparent'];\n const getColor = (index: number) => colors[index % colors.length];\n\n // const regions: any[] = [];\n for (let index = 0; index < items.length - 1; index++) {\n const [prev, curr] = [items[index].points, items[index + 1].points];\n const path = getRegionPath(prev, curr, this.attribute as GridAttributes);\n const shape = createPath({\n path,\n fill: true,\n fillColor: getColor(index)\n }) as Path;\n shape.name = `${this.name}-region`;\n shape.id = this._getNodeId(`region-${index}`);\n this.add(shape);\n }\n }\n }\n\n /**\n * @override 覆写\n * @param id\n * @returns\n */\n protected _getNodeId(id: string) {\n return `${this.id}-${id}`;\n }\n}\n"]}
@@ -0,0 +1,6 @@
1
+ export * from './grid';
2
+ export * from './line';
3
+ export * from './circle';
4
+ export * from './type';
5
+ export * from './animate';
6
+ export * from './constant';
@@ -0,0 +1,12 @@
1
+ export * from "./grid";
2
+
3
+ export * from "./line";
4
+
5
+ export * from "./circle";
6
+
7
+ export * from "./type";
8
+
9
+ export * from "./animate";
10
+
11
+ export * from "./constant";
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/axis/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC;AAEzB,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC","file":"index.js","sourcesContent":["export * from './grid';\nexport * from './line';\nexport * from './circle';\n\nexport * from './type';\nexport * from './animate';\nexport * from './constant';\n"]}