Blame view

node_modules/echarts/src/coord/polar/prepareCustom.js 2.24 KB
aaac7fed   liuqimichale   add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
  /*
  * Licensed to the Apache Software Foundation (ASF) under one
  * or more contributor license agreements.  See the NOTICE file
  * distributed with this work for additional information
  * regarding copyright ownership.  The ASF licenses this file
  * to you under the Apache License, Version 2.0 (the
  * "License"); you may not use this file except in compliance
  * with the License.  You may obtain a copy of the License at
  *
  *   http://www.apache.org/licenses/LICENSE-2.0
  *
  * Unless required by applicable law or agreed to in writing,
  * software distributed under the License is distributed on an
  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  * KIND, either express or implied.  See the License for the
  * specific language governing permissions and limitations
  * under the License.
  */
  
  import * as zrUtil from 'zrender/src/core/util';
  
  function dataToCoordSize(dataSize, dataItem) {
      // dataItem is necessary in log axis.
      return zrUtil.map(['Radius', 'Angle'], function (dim, dimIdx) {
          var axis = this['get' + dim + 'Axis']();
          var val = dataItem[dimIdx];
          var halfSize = dataSize[dimIdx] / 2;
          var method = 'dataTo' + dim;
  
          var result = axis.type === 'category'
              ? axis.getBandWidth()
              : Math.abs(axis[method](val - halfSize) - axis[method](val + halfSize));
  
          if (dim === 'Angle') {
              result = result * Math.PI / 180;
          }
  
          return result;
  
      }, this);
  }
  
  export default function (coordSys) {
      var radiusAxis = coordSys.getRadiusAxis();
      var angleAxis = coordSys.getAngleAxis();
      var radius = radiusAxis.getExtent();
      radius[0] > radius[1] && radius.reverse();
  
      return {
          coordSys: {
              type: 'polar',
              cx: coordSys.cx,
              cy: coordSys.cy,
              r: radius[1],
              r0: radius[0]
          },
          api: {
              coord: zrUtil.bind(function (data) {
                  var radius = radiusAxis.dataToRadius(data[0]);
                  var angle = angleAxis.dataToAngle(data[1]);
                  var coord = coordSys.coordToPoint([radius, angle]);
                  coord.push(radius, angle * Math.PI / 180);
                  return coord;
              }),
              size: zrUtil.bind(dataToCoordSize, coordSys)
          }
      };
  }