findPointFromSeries.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing,
  13. * software distributed under the License is distributed on an
  14. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  15. * KIND, either express or implied. See the License for the
  16. * specific language governing permissions and limitations
  17. * under the License.
  18. */
  19. /**
  20. * AUTO-GENERATED FILE. DO NOT MODIFY.
  21. */
  22. /*
  23. * Licensed to the Apache Software Foundation (ASF) under one
  24. * or more contributor license agreements. See the NOTICE file
  25. * distributed with this work for additional information
  26. * regarding copyright ownership. The ASF licenses this file
  27. * to you under the Apache License, Version 2.0 (the
  28. * "License"); you may not use this file except in compliance
  29. * with the License. You may obtain a copy of the License at
  30. *
  31. * http://www.apache.org/licenses/LICENSE-2.0
  32. *
  33. * Unless required by applicable law or agreed to in writing,
  34. * software distributed under the License is distributed on an
  35. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  36. * KIND, either express or implied. See the License for the
  37. * specific language governing permissions and limitations
  38. * under the License.
  39. */
  40. import * as zrUtil from 'zrender/lib/core/util.js';
  41. import * as modelUtil from '../../util/model.js';
  42. /**
  43. * @param finder contains {seriesIndex, dataIndex, dataIndexInside}
  44. * @param ecModel
  45. * @return {point: [x, y], el: ...} point Will not be null.
  46. */
  47. export default function findPointFromSeries(finder, ecModel) {
  48. var point = [];
  49. var seriesIndex = finder.seriesIndex;
  50. var seriesModel;
  51. if (seriesIndex == null || !(seriesModel = ecModel.getSeriesByIndex(seriesIndex))) {
  52. return {
  53. point: []
  54. };
  55. }
  56. var data = seriesModel.getData();
  57. var dataIndex = modelUtil.queryDataIndex(data, finder);
  58. if (dataIndex == null || dataIndex < 0 || zrUtil.isArray(dataIndex)) {
  59. return {
  60. point: []
  61. };
  62. }
  63. var el = data.getItemGraphicEl(dataIndex);
  64. var coordSys = seriesModel.coordinateSystem;
  65. if (seriesModel.getTooltipPosition) {
  66. point = seriesModel.getTooltipPosition(dataIndex) || [];
  67. } else if (coordSys && coordSys.dataToPoint) {
  68. if (finder.isStacked) {
  69. var baseAxis = coordSys.getBaseAxis();
  70. var valueAxis = coordSys.getOtherAxis(baseAxis);
  71. var valueAxisDim = valueAxis.dim;
  72. var baseAxisDim = baseAxis.dim;
  73. var baseDataOffset = valueAxisDim === 'x' || valueAxisDim === 'radius' ? 1 : 0;
  74. var baseDim = data.mapDimension(baseAxisDim);
  75. var stackedData = [];
  76. stackedData[baseDataOffset] = data.get(baseDim, dataIndex);
  77. stackedData[1 - baseDataOffset] = data.get(data.getCalculationInfo('stackResultDimension'), dataIndex);
  78. point = coordSys.dataToPoint(stackedData) || [];
  79. } else {
  80. point = coordSys.dataToPoint(data.getValues(zrUtil.map(coordSys.dimensions, function (dim) {
  81. return data.mapDimension(dim);
  82. }), dataIndex)) || [];
  83. }
  84. } else if (el) {
  85. // Use graphic bounding rect
  86. var rect = el.getBoundingRect().clone();
  87. rect.applyTransform(el.transform);
  88. point = [rect.x + rect.width / 2, rect.y + rect.height / 2];
  89. }
  90. return {
  91. point: point,
  92. el: el
  93. };
  94. }