path.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. import { __read, __spreadArray } from "tslib";
  2. import { clone, isEqual, clamp } from '@antv/util';
  3. import { catmullRom2Bezier } from '../../util';
  4. /**
  5. * 根据数据获得每条线各点x,y值
  6. */
  7. export function dataToLines(data, scales) {
  8. var _a;
  9. var x = scales.x, y = scales.y;
  10. var _b = __read((y.getOptions().range || [0, 0]), 2), max = _b[0], min = _b[1];
  11. if (min > max)
  12. _a = __read([max, min], 2), min = _a[0], max = _a[1];
  13. return data.map(function (points) {
  14. var lines = points.map(function (val, idx) {
  15. return [x.map(idx), clamp(y.map(val), min, max)];
  16. });
  17. return lines;
  18. });
  19. }
  20. /**
  21. * 根据线的点数据生成折线path
  22. */
  23. export function lineToLinePath(line, reverse) {
  24. if (reverse === void 0) { reverse = false; }
  25. var M = reverse ? line.length - 1 : 0;
  26. var linePath = line.map(function (point, idx) { return __spreadArray([idx === M ? 'M' : 'L'], __read(point), false); });
  27. return reverse ? linePath.reverse() : linePath;
  28. }
  29. /**
  30. * 根据点数据生成曲线path
  31. * @param points 点数据
  32. * @param reverse 是否倒序生成
  33. */
  34. export function lineToCurvePath(line, reverse) {
  35. if (reverse === void 0) { reverse = false; }
  36. if (line.length <= 2) {
  37. return lineToLinePath(line);
  38. }
  39. var data = [];
  40. var len = line.length;
  41. for (var idx = 0; idx < len; idx += 1) {
  42. var point = reverse ? line[len - idx - 1] : line[idx];
  43. if (!isEqual(point, data.slice(-2))) {
  44. data.push.apply(data, __spreadArray([], __read(point), false));
  45. }
  46. }
  47. var path = catmullRom2Bezier(data, false);
  48. if (reverse) {
  49. path.unshift(__spreadArray(['M'], __read(line[len - 1]), false));
  50. }
  51. else {
  52. path.unshift(__spreadArray(['M'], __read(line[0]), false));
  53. }
  54. return path;
  55. }
  56. /**
  57. * 根据baseline将path闭合
  58. */
  59. export function closePathByBaseLine(path, width, baseline) {
  60. var closedPath = clone(path);
  61. closedPath.push(['L', width, baseline], ['L', 0, baseline], ['Z']);
  62. return closedPath;
  63. }
  64. /**
  65. * 将多条线的点数据生成区域path
  66. * 可以是折线或曲线
  67. */
  68. export function linesToAreaPaths(lines, smooth, width, baseline) {
  69. return lines.map(function (line) {
  70. return closePathByBaseLine(smooth ? lineToCurvePath(line) : lineToLinePath(line), width, baseline);
  71. });
  72. }
  73. /**
  74. * 生成折线堆叠区域封闭图形路径
  75. */
  76. export function linesToStackAreaPaths(lines, width, baseline) {
  77. var paths = [];
  78. for (var idx = lines.length - 1; idx >= 0; idx -= 1) {
  79. var currLine = lines[idx];
  80. var currCurvePath = lineToLinePath(currLine);
  81. var path = void 0;
  82. if (idx === 0) {
  83. // 最底部的线直接与y=0连接成闭合区域
  84. path = closePathByBaseLine(currCurvePath, width, baseline);
  85. }
  86. else {
  87. // 计算下一根曲线的反向路径
  88. var belowLine = lines[idx - 1];
  89. var belowCurvePath = lineToLinePath(belowLine, true);
  90. belowCurvePath[0][0] = 'L';
  91. // 连接路径
  92. path = __spreadArray(__spreadArray(__spreadArray([], __read(currCurvePath), false), __read(belowCurvePath), false), [['Z']], false);
  93. }
  94. paths.push(path);
  95. }
  96. return paths;
  97. }
  98. /**
  99. * 生成曲线堆叠区域封闭图形路径
  100. */
  101. export function linesToStackCurveAreaPaths(lines, width, baseline) {
  102. var paths = [];
  103. for (var idx = lines.length - 1; idx >= 0; idx -= 1) {
  104. var currLine = lines[idx];
  105. var currCurvePath = lineToCurvePath(currLine);
  106. var path = void 0;
  107. if (idx === 0) {
  108. // 最底部的线直接与y=0连接成闭合区域
  109. path = closePathByBaseLine(currCurvePath, width, baseline);
  110. }
  111. else {
  112. // 计算下一根曲线的反向路径
  113. var belowLine = lines[idx - 1];
  114. var belowCurvePath = lineToCurvePath(belowLine, true);
  115. /**
  116. * 将线条连接成闭合路径
  117. * M C C C C C
  118. * A ~ -> ~ B
  119. * ⬆ ⬇
  120. * D ~ <- ~ C
  121. * C C C C C M
  122. *
  123. */
  124. var A = currLine[0];
  125. // const B = currLine[currLine.length - 1];
  126. // const C = belowLine[belowLine.length - 1];
  127. // const D = belowLine[0];
  128. // 将反向曲线开头 M X Y 改为 L X Y
  129. belowCurvePath[0][0] = 'L';
  130. // 连接路径
  131. path = __spreadArray(__spreadArray(__spreadArray([], __read(currCurvePath), false), __read(belowCurvePath), false), [__spreadArray(['M'], __read(A), false), ['Z']], false);
  132. }
  133. paths.push(path);
  134. }
  135. return paths;
  136. }
  137. //# sourceMappingURL=path.js.map