path.js 5.4 KB

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