1 line
45 KiB
JSON
1 line
45 KiB
JSON
{"remainingRequest":"E:\\项目\\suyiScreen\\node_modules\\babel-loader\\lib\\index.js!E:\\项目\\suyiScreen\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\项目\\suyiScreen\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\项目\\suyiScreen\\node_modules\\@jiaminghi\\data-view\\lib\\components\\flylineChartEnhanced\\src\\main.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\项目\\suyiScreen\\node_modules\\@jiaminghi\\data-view\\lib\\components\\flylineChartEnhanced\\src\\main.vue","mtime":1670569849700},{"path":"E:\\项目\\suyiScreen\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1670569853083},{"path":"E:\\项目\\suyiScreen\\node_modules\\babel-loader\\lib\\index.js","mtime":1670569850970},{"path":"E:\\项目\\suyiScreen\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1670569853083},{"path":"E:\\项目\\suyiScreen\\node_modules\\vue-loader\\lib\\index.js","mtime":1670569867456}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import "core-js/modules/es.array.concat";
import "core-js/modules/es.array.find";
import "core-js/modules/es.array.map";
import "core-js/modules/es.function.name";
import "core-js/modules/es.number.to-fixed";
import "core-js/modules/es.object.to-string";
import "core-js/modules/es.regexp.to-string";
import _objectSpread from "E:\\\u9879\u76EE\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/objectSpread2";
import _toConsumableArray from "E:\\\u9879\u76EE\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/toConsumableArray";
import _slicedToArray from "E:\\\u9879\u76EE\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/slicedToArray";
import "regenerator-runtime/runtime";
import _asyncToGenerator from "E:\\\u9879\u76EE\\suyiScreen\\node_modules\\@babel\\runtime/helpers/esm/asyncToGenerator";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { deepMerge } from '@jiaminghi/charts/lib/util/index';
import { deepClone } from '@jiaminghi/c-render/lib/plugin/util';
import { randomExtend, getPointDistance } from '../../../util/index';
import autoResize from '../../../mixin/autoResize';
export default {
  name: 'DvFlylineChartEnhanced',
  mixins: [autoResize],
  props: {
    config: {
      type: Object,
      default: function _default() {
        return {};
      }
    },
    dev: {
      type: Boolean,
      default: false
    }
  },
  data: function data() {
    var timestamp = Date.now();
    return {
      ref: 'dv-flyline-chart-enhanced',
      unique: Math.random(),
      flylineGradientId: "flyline-gradient-id-".concat(timestamp),
      haloGradientId: "halo-gradient-id-".concat(timestamp),

      /**
       * @description Type Declaration
       * 
       * interface Halo {
       *    show?: boolean
       *    duration?: [number, number]
       *    color?: string
       *    radius?: number
       * }
       * 
       * interface Text {
       *    show?: boolean
       *    offset?: [number, number]
       *    color?: string
       *    fontSize?: number
       * }
       * 
       * interface Icon {
       *    show?: boolean
       *    src?: string
       *    width?: number
       *    height?: number
       * }
       * 
       * interface Point {
       *    name: string
       *    coordinate: [number, number]
       *    halo?: Halo
       *    text?: Text
       *    icon?: Icon
       * }
       * 
       * interface Line {
       *    width?: number
       *    color?: string
       *    orbitColor?: string
       *    duration?: [number, number]
       *    radius?: string
       * }
       * 
       * interface Flyline extends Line {
       *    source: string
       *    target: string
       * }
       * 
       * interface FlylineWithPath extends Flyline {
       *    d: string
       *    path: [[number, number], [number, number], [number, number]]
       *    key: string
       * }
       */
      defaultConfig: {
        /**
         * @description Flyline chart points
         * @type {Point[]}
         * @default points = []
         */
        points: [],

        /**
         * @description Lines
         * @type {Flyline[]}
         * @default lines = []
         */
        lines: [],

        /**
         * @description Global halo configuration
         * @type {Halo}
         */
        halo: {
          /**
           * @description Whether to show halo
           * @type {Boolean}
           * @default show = false
           */
          show: false,

          /**
           * @description Halo animation duration (1s = 10)
           * @type {[number, number]}
           */
          duration: [20, 30],

          /**
           * @description Halo color
           * @type {String}
           * @default color = '#fb7293'
           */
          color: '#fb7293',

          /**
           * @description Halo radius
           * @type {Number}
           * @default radius = 120
           */
          radius: 120
        },

        /**
         * @description Global text configuration
         * @type {Text}
         */
        text: {
          /**
           * @description Whether to show text
           * @type {Boolean}
           * @default show = false
           */
          show: false,

          /**
           * @description Text offset
           * @type {[number, number]}
           * @default offset = [0, 15]
           */
          offset: [0, 15],

          /**
           * @description Text color
           * @type {String}
           * @default color = '#ffdb5c'
           */
          color: '#ffdb5c',

          /**
           * @description Text font size
           * @type {Number}
           * @default fontSize = 12
           */
          fontSize: 12
        },

        /**
         * @description Global icon configuration
         * @type {Icon}
         */
        icon: {
          /**
           * @description Whether to show icon
           * @type {Boolean}
           * @default show = false
           */
          show: false,

          /**
           * @description Icon src
           * @type {String}
           * @default src = ''
           */
          src: '',

          /**
           * @description Icon width
           * @type {Number}
           * @default width = 15
           */
          width: 15,

          /**
           * @description Icon height
           * @type {Number}
           * @default width = 15
           */
          height: 15
        },

        /**
         * @description Global line configuration
         * @type {Line}
         */
        line: {
          /**
           * @description Line width
           * @type {Number}
           * @default width = 1
           */
          width: 1,

          /**
           * @description Flyline color
           * @type {String}
           * @default color = '#ffde93'
           */
          color: '#ffde93',

          /**
           * @description Orbit color
           * @type {String}
           * @default orbitColor = 'rgba(103, 224, 227, .2)'
           */
          orbitColor: 'rgba(103, 224, 227, .2)',

          /**
           * @description Flyline animation duration
           * @type {[number, number]}
           * @default duration = [20, 30]
           */
          duration: [20, 30],

          /**
           * @description Flyline radius
           * @type {Number}
           * @default radius = 100
           */
          radius: 100
        },

        /**
         * @description Back ground image url
         * @type {String}
         * @default bgImgSrc = ''
         */
        bgImgSrc: '',

        /**
         * @description K value
         * @type {Number}
         * @default k = -0.5
         * @example k = -1 ~ 1
         */
        k: -0.5,

        /**
         * @description Flyline curvature
         * @type {Number}
         * @default curvature = 5
         */
        curvature: 5,

        /**
         * @description Relative points position
         * @type {Boolean}
         * @default relative = true
         */
        relative: true
      },

      /**
       * @description Fly line data
       * @type {FlylineWithPath[]}
       * @default flylines = []
       */
      flylines: [],

      /**
       * @description Fly line lengths
       * @type {Number[]}
       * @default flylineLengths = []
       */
      flylineLengths: [],

      /**
       * @description Fly line points
       * @default flylinePoints = []
       */
      flylinePoints: [],
      mergedConfig: null
    };
  },
  watch: {
    config: function config() {
      var calcData = this.calcData;
      calcData();
    }
  },
  methods: {
    afterAutoResizeMixinInit: function afterAutoResizeMixinInit() {
      var calcData = this.calcData;
      calcData();
    },
    onResize: function onResize() {
      var calcData = this.calcData;
      calcData();
    },
    calcData: function calcData() {
      var _this = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var mergeConfig, calcflylinePoints, calcLinePaths, calcLineLengths;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                mergeConfig = _this.mergeConfig, calcflylinePoints = _this.calcflylinePoints, calcLinePaths = _this.calcLinePaths;
                mergeConfig();
                calcflylinePoints();
                calcLinePaths();
                calcLineLengths = _this.calcLineLengths;
                _context.next = 7;
                return calcLineLengths();

              case 7:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }))();
    },
    mergeConfig: function mergeConfig() {
      var config = this.config,
          defaultConfig = this.defaultConfig;
      var mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {});
      var points = mergedConfig.points,
          lines = mergedConfig.lines,
          halo = mergedConfig.halo,
          text = mergedConfig.text,
          icon = mergedConfig.icon,
          line = mergedConfig.line;
      mergedConfig.points = points.map(function (item) {
        item.halo = deepMerge(deepClone(halo, true), item.halo || {});
        item.text = deepMerge(deepClone(text, true), item.text || {});
        item.icon = deepMerge(deepClone(icon, true), item.icon || {});
        return item;
      });
      mergedConfig.lines = lines.map(function (item) {
        return deepMerge(deepClone(line, true), item);
      });
      this.mergedConfig = mergedConfig;
    },
    calcflylinePoints: function calcflylinePoints() {
      var mergedConfig = this.mergedConfig,
          width = this.width,
          height = this.height;
      var relative = mergedConfig.relative,
          points = mergedConfig.points;
      this.flylinePoints = points.map(function (item, i) {
        var _item$coordinate = _slicedToArray(item.coordinate, 2),
            x = _item$coordinate[0],
            y = _item$coordinate[1],
            halo = item.halo,
            icon = item.icon,
            text = item.text;

        if (relative) item.coordinate = [x * width, y * height];
        item.halo.time = randomExtend.apply(void 0, _toConsumableArray(halo.duration)) / 10;
        var iw = icon.width,
            ih = icon.height;
        item.icon.x = item.coordinate[0] - iw / 2;
        item.icon.y = item.coordinate[1] - ih / 2;

        var _text$offset = _slicedToArray(text.offset, 2),
            ox = _text$offset[0],
            oy = _text$offset[1];

        item.text.x = item.coordinate[0] + ox;
        item.text.y = item.coordinate[1] + oy;
        item.key = "".concat(item.coordinate.toString()).concat(i);
        return item;
      });
    },
    calcLinePaths: function calcLinePaths() {
      var getPath = this.getPath,
          mergedConfig = this.mergedConfig;
      var points = mergedConfig.points,
          lines = mergedConfig.lines;
      this.flylines = lines.map(function (item) {
        var source = item.source,
            target = item.target,
            duration = item.duration;
        var sourcePoint = points.find(function (_ref) {
          var name = _ref.name;
          return name === source;
        }).coordinate;
        var targetPoint = points.find(function (_ref2) {
          var name = _ref2.name;
          return name === target;
        }).coordinate;
        var path = getPath(sourcePoint, targetPoint).map(function (item) {
          return item.map(function (v) {
            return parseFloat(v.toFixed(10));
          });
        });
        var d = "M".concat(path[0].toString(), " Q").concat(path[1].toString(), " ").concat(path[2].toString());
        var key = "path".concat(path.toString());
        var time = randomExtend.apply(void 0, _toConsumableArray(duration)) / 10;
        return _objectSpread({}, item, {
          path: path,
          key: key,
          d: d,
          time: time
        });
      });
    },
    getPath: function getPath(start, end) {
      var getControlPoint = this.getControlPoint;
      var controlPoint = getControlPoint(start, end);
      return [start, controlPoint, end];
    },
    getControlPoint: function getControlPoint(_ref3, _ref4) {
      var _ref5 = _slicedToArray(_ref3, 2),
          sx = _ref5[0],
          sy = _ref5[1];

      var _ref6 = _slicedToArray(_ref4, 2),
          ex = _ref6[0],
          ey = _ref6[1];

      var getKLinePointByx = this.getKLinePointByx,
          mergedConfig = this.mergedConfig;
      var curvature = mergedConfig.curvature,
          k = mergedConfig.k;
      var mx = (sx + ex) / 2,
          my = (sy + ey) / 2;
      var distance = getPointDistance([sx, sy], [ex, ey]);
      var targetLength = distance / curvature;
      var disDived = targetLength / 2;
      var dx = mx,
          dy = my;

      do {
        dx += disDived;
        dy = getKLinePointByx(k, [mx, my], dx)[1];
      } while (getPointDistance([mx, my], [dx, dy]) < targetLength);

      return [dx, dy];
    },
    getKLinePointByx: function getKLinePointByx(k, _ref7, x) {
      var _ref8 = _slicedToArray(_ref7, 2),
          lx = _ref8[0],
          ly = _ref8[1];

      var y = ly - k * lx + k * x;
      return [x, y];
    },
    calcLineLengths: function calcLineLengths() {
      var _this2 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {
        var $nextTick, flylines, $refs;
        return regeneratorRuntime.wrap(function _callee2$(_context2) {
          while (1) {
            switch (_context2.prev = _context2.next) {
              case 0:
                $nextTick = _this2.$nextTick, flylines = _this2.flylines, $refs = _this2.$refs;
                _context2.next = 3;
                return $nextTick();

              case 3:
                _this2.flylineLengths = flylines.map(function (_ref9) {
                  var key = _ref9.key;
                  return $refs[key][0].getTotalLength();
                });

              case 4:
              case "end":
                return _context2.stop();
            }
          }
        }, _callee2);
      }))();
    },
    consoleClickPos: function consoleClickPos(_ref10) {
      var offsetX = _ref10.offsetX,
          offsetY = _ref10.offsetY;
      var width = this.width,
          height = this.height,
          dev = this.dev;
      if (!dev) return;
      var relativeX = (offsetX / width).toFixed(2);
      var relativeY = (offsetY / height).toFixed(2);
      console.warn("dv-flyline-chart-enhanced DEV: \n Click Position is [".concat(offsetX, ", ").concat(offsetY, "] \n Relative Position is [").concat(relativeX, ", ").concat(relativeY, "]"));
    }
  }
};"},{"version":3,"sources":["main.vue"],"names":[],"mappings":"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","sourcesContent":["<template>\r\n <div\r\n class=\"dv-flyline-chart-enhanced\"\r\n :style=\"`background-image: url(${mergedConfig ? mergedConfig.bgImgSrc : ''})`\"\r\n :ref=\"ref\"\r\n @click=\"consoleClickPos\"\r\n >\r\n <svg v-if=\"flylines.length\" :width=\"width\" :height=\"height\">\r\n <defs>\r\n <radialGradient\r\n :id=\"flylineGradientId\"\r\n cx=\"50%\" cy=\"50%\" r=\"50%\"\r\n >\r\n <stop\r\n offset=\"0%\" stop-color=\"#fff\"\r\n stop-opacity=\"1\"\r\n />\r\n <stop\r\n offset=\"100%\" stop-color=\"#fff\"\r\n stop-opacity=\"0\"\r\n />\r\n </radialGradient>\r\n\r\n <radialGradient\r\n :id=\"haloGradientId\"\r\n cx=\"50%\" cy=\"50%\" r=\"50%\"\r\n >\r\n <stop\r\n offset=\"0%\" stop-color=\"#fff\"\r\n stop-opacity=\"0\"\r\n />\r\n <stop\r\n offset=\"100%\" stop-color=\"#fff\"\r\n stop-opacity=\"1\"\r\n />\r\n </radialGradient>\r\n </defs>\r\n\r\n <!-- points -->\r\n <g v-for=\"point in flylinePoints\" :key=\"point.key + Math.random()\">\r\n <defs>\r\n <circle\r\n v-if=\"point.halo.show\"\r\n :id=\"`halo${unique}${point.key}`\"\r\n :cx=\"point.coordinate[0]\"\r\n :cy=\"point.coordinate[1]\"\r\n >\r\n <animate\r\n attributeName=\"r\"\r\n :values=\"`1;${point.halo.radius}`\"\r\n :dur=\"`${point.halo.time}s`\"\r\n repeatCount=\"indefinite\"\r\n />\r\n <animate\r\n attributeName=\"opacity\"\r\n values=\"1;0\"\r\n :dur=\"`${point.halo.time}s`\"\r\n repeatCount=\"indefinite\"\r\n />\r\n </circle>\r\n </defs>\r\n\r\n <!-- halo gradient mask -->\r\n <mask :id=\"`mask${unique}${point.key}`\">\r\n <use\r\n v-if=\"point.halo.show\"\r\n :xlink:href=\"`#halo${unique}${point.key}`\"\r\n :fill=\"`url(#${haloGradientId})`\"\r\n />\r\n </mask>\r\n\r\n <!-- point halo -->\r\n <use\r\n v-if=\"point.halo.show\"\r\n :xlink:href=\"`#halo${unique}${point.key}`\"\r\n :fill=\"point.halo.color\"\r\n :mask=\"`url(#mask${unique}${point.key})`\"\r\n />\r\n\r\n <!-- point icon -->\r\n <image\r\n v-if=\"point.icon.show\"\r\n :xlink:href=\"point.icon.src\"\r\n :width=\"point.icon.width\"\r\n :height=\"point.icon.height\"\r\n :x=\"point.icon.x\"\r\n :y=\"point.icon.y\"\r\n />\r\n\r\n <!-- point text -->\r\n <text\r\n v-if=\"point.text.show\"\r\n :style=\"`fontSize:${point.text.fontSize}px;color:${point.text.color}`\"\r\n :fill=\"point.text.color\"\r\n :x=\"point.text.x\"\r\n :y=\"point.text.y\"\r\n >\r\n {{ point.name }}\r\n </text>\r\n </g>\r\n\r\n <!-- flylines -->\r\n <g v-for=\"(line, i) in flylines\" :key=\"line.key + Math.random()\">\r\n <defs>\r\n <path\r\n :id=\"line.key\"\r\n :ref=\"line.key\"\r\n :d=\"line.d\"\r\n fill=\"transparent\"\r\n />\r\n </defs>\r\n\r\n <!-- orbit line -->\r\n <use\r\n :xlink:href=\"`#${line.key}`\"\r\n :stroke-width=\"line.width\"\r\n :stroke=\"line.orbitColor\"\r\n />\r\n\r\n <!-- fly line gradient mask -->\r\n <mask :id=\"`mask${unique}${line.key}`\">\r\n <circle cx=\"0\" cy=\"0\" :r=\"line.radius\" :fill=\"`url(#${flylineGradientId})`\">\r\n <animateMotion\r\n :dur=\"line.time\"\r\n :path=\"line.d\"\r\n rotate=\"auto\"\r\n repeatCount=\"indefinite\"\r\n />\r\n </circle>\r\n </mask>\r\n\r\n <!-- fly line -->\r\n <use\r\n v-if=\"flylineLengths[i]\"\r\n :xlink:href=\"`#${line.key}`\"\r\n :stroke-width=\"line.width\"\r\n :stroke=\"line.color\"\r\n :mask=\"`url(#mask${unique}${line.key})`\"\r\n >\r\n <animate\r\n attributeName=\"stroke-dasharray\"\r\n :from=\"`0, ${flylineLengths[i]}`\"\r\n :to=\"`${flylineLengths[i]}, 0`\"\r\n :dur=\"line.time\"\r\n repeatCount=\"indefinite\"\r\n />\r\n </use>\r\n </g>\r\n </svg>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport { deepMerge } from '@jiaminghi/charts/lib/util/index'\r\n\r\nimport { deepClone } from '@jiaminghi/c-render/lib/plugin/util'\r\n\r\nimport { randomExtend, getPointDistance } from '../../../util/index'\r\n\r\nimport autoResize from '../../../mixin/autoResize'\r\n\r\nexport default {\r\n name: 'DvFlylineChartEnhanced',\r\n mixins: [autoResize],\r\n props: {\r\n config: {\r\n type: Object,\r\n default: () => ({})\r\n },\r\n dev: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n data () {\r\n const timestamp = Date.now()\r\n return {\r\n ref: 'dv-flyline-chart-enhanced',\r\n unique: Math.random(),\r\n flylineGradientId: `flyline-gradient-id-${timestamp}`,\r\n haloGradientId: `halo-gradient-id-${timestamp}`,\r\n /**\r\n * @description Type Declaration\r\n * \r\n * interface Halo {\r\n * show?: boolean\r\n * duration?: [number, number]\r\n * color?: string\r\n * radius?: number\r\n * }\r\n * \r\n * interface Text {\r\n * show?: boolean\r\n * offset?: [number, number]\r\n * color?: string\r\n * fontSize?: number\r\n * }\r\n * \r\n * interface Icon {\r\n * show?: boolean\r\n * src?: string\r\n * width?: number\r\n * height?: number\r\n * }\r\n * \r\n * interface Point {\r\n * name: string\r\n * coordinate: [number, number]\r\n * halo?: Halo\r\n * text?: Text\r\n * icon?: Icon\r\n * }\r\n * \r\n * interface Line {\r\n * width?: number\r\n * color?: string\r\n * orbitColor?: string\r\n * duration?: [number, number]\r\n * radius?: string\r\n * }\r\n * \r\n * interface Flyline extends Line {\r\n * source: string\r\n * target: string\r\n * }\r\n * \r\n * interface FlylineWithPath extends Flyline {\r\n * d: string\r\n * path: [[number, number], [number, number], [number, number]]\r\n * key: string\r\n * }\r\n */\r\n defaultConfig: {\r\n /**\r\n * @description Flyline chart points\r\n * @type {Point[]}\r\n * @default points = []\r\n */\r\n points: [],\r\n /**\r\n * @description Lines\r\n * @type {Flyline[]}\r\n * @default lines = []\r\n */\r\n lines: [],\r\n /**\r\n * @description Global halo configuration\r\n * @type {Halo}\r\n */\r\n halo: {\r\n /**\r\n * @description Whether to show halo\r\n * @type {Boolean}\r\n * @default show = false\r\n */\r\n show: false,\r\n /**\r\n * @description Halo animation duration (1s = 10)\r\n * @type {[number, number]}\r\n */\r\n duration: [20, 30],\r\n /**\r\n * @description Halo color\r\n * @type {String}\r\n * @default color = '#fb7293'\r\n */\r\n color: '#fb7293',\r\n /**\r\n * @description Halo radius\r\n * @type {Number}\r\n * @default radius = 120\r\n */\r\n radius: 120\r\n },\r\n /**\r\n * @description Global text configuration\r\n * @type {Text}\r\n */\r\n text: {\r\n /**\r\n * @description Whether to show text\r\n * @type {Boolean}\r\n * @default show = false\r\n */\r\n show: false,\r\n /**\r\n * @description Text offset\r\n * @type {[number, number]}\r\n * @default offset = [0, 15]\r\n */\r\n offset: [0, 15],\r\n /**\r\n * @description Text color\r\n * @type {String}\r\n * @default color = '#ffdb5c'\r\n */\r\n color: '#ffdb5c',\r\n /**\r\n * @description Text font size\r\n * @type {Number}\r\n * @default fontSize = 12\r\n */\r\n fontSize: 12\r\n },\r\n /**\r\n * @description Global icon configuration\r\n * @type {Icon}\r\n */\r\n icon: {\r\n /**\r\n * @description Whether to show icon\r\n * @type {Boolean}\r\n * @default show = false\r\n */\r\n show: false,\r\n /**\r\n * @description Icon src\r\n * @type {String}\r\n * @default src = ''\r\n */\r\n src: '',\r\n /**\r\n * @description Icon width\r\n * @type {Number}\r\n * @default width = 15\r\n */\r\n width: 15,\r\n /**\r\n * @description Icon height\r\n * @type {Number}\r\n * @default width = 15\r\n */\r\n height: 15\r\n },\r\n /**\r\n * @description Global line configuration\r\n * @type {Line}\r\n */\r\n line: {\r\n /**\r\n * @description Line width\r\n * @type {Number}\r\n * @default width = 1\r\n */\r\n width: 1,\r\n /**\r\n * @description Flyline color\r\n * @type {String}\r\n * @default color = '#ffde93'\r\n */\r\n color: '#ffde93',\r\n /**\r\n * @description Orbit color\r\n * @type {String}\r\n * @default orbitColor = 'rgba(103, 224, 227, .2)'\r\n */\r\n orbitColor: 'rgba(103, 224, 227, .2)',\r\n /**\r\n * @description Flyline animation duration\r\n * @type {[number, number]}\r\n * @default duration = [20, 30]\r\n */\r\n duration: [20, 30],\r\n /**\r\n * @description Flyline radius\r\n * @type {Number}\r\n * @default radius = 100\r\n */\r\n radius: 100\r\n },\r\n /**\r\n * @description Back ground image url\r\n * @type {String}\r\n * @default bgImgSrc = ''\r\n */\r\n bgImgSrc: '',\r\n /**\r\n * @description K value\r\n * @type {Number}\r\n * @default k = -0.5\r\n * @example k = -1 ~ 1\r\n */\r\n k: -0.5,\r\n /**\r\n * @description Flyline curvature\r\n * @type {Number}\r\n * @default curvature = 5\r\n */\r\n curvature: 5,\r\n /**\r\n * @description Relative points position\r\n * @type {Boolean}\r\n * @default relative = true\r\n */\r\n relative: true\r\n },\r\n /**\r\n * @description Fly line data\r\n * @type {FlylineWithPath[]}\r\n * @default flylines = []\r\n */\r\n flylines: [],\r\n /**\r\n * @description Fly line lengths\r\n * @type {Number[]}\r\n * @default flylineLengths = []\r\n */\r\n flylineLengths: [],\r\n /**\r\n * @description Fly line points\r\n * @default flylinePoints = []\r\n */\r\n flylinePoints: [],\r\n\r\n mergedConfig: null\r\n }\r\n },\r\n watch: {\r\n config () {\r\n const { calcData } = this\r\n\r\n calcData()\r\n }\r\n },\r\n methods: {\r\n afterAutoResizeMixinInit () {\r\n const { calcData } = this\r\n\r\n calcData()\r\n },\r\n onResize () {\r\n const { calcData } = this\r\n\r\n calcData()\r\n },\r\n async calcData () {\r\n const { mergeConfig, calcflylinePoints, calcLinePaths } = this\r\n\r\n mergeConfig()\r\n\r\n calcflylinePoints()\r\n\r\n calcLinePaths()\r\n\r\n const { calcLineLengths } = this\r\n\r\n await calcLineLengths()\r\n },\r\n mergeConfig () {\r\n let { config, defaultConfig } = this\r\n\r\n const mergedConfig = deepMerge(deepClone(defaultConfig, true), config || {})\r\n\r\n const { points, lines, halo, text, icon, line } = mergedConfig\r\n\r\n mergedConfig.points = points.map(item => {\r\n item.halo = deepMerge(deepClone(halo, true), item.halo || {})\r\n item.text = deepMerge(deepClone(text, true), item.text || {})\r\n item.icon = deepMerge(deepClone(icon, true), item.icon || {})\r\n\r\n return item\r\n })\r\n\r\n mergedConfig.lines = lines.map(item => {\r\n return deepMerge(deepClone(line, true), item)\r\n })\r\n\r\n this.mergedConfig = mergedConfig\r\n },\r\n calcflylinePoints () {\r\n const { mergedConfig, width, height } = this\r\n\r\n const { relative, points } = mergedConfig\r\n\r\n this.flylinePoints = points.map((item, i) => {\r\n const { coordinate: [x, y], halo, icon, text } = item\r\n\r\n if (relative) item.coordinate = [x * width, y * height]\r\n\r\n item.halo.time = randomExtend(...halo.duration) / 10\r\n\r\n const { width: iw, height: ih } = icon\r\n item.icon.x = item.coordinate[0] - iw / 2\r\n item.icon.y = item.coordinate[1] - ih / 2\r\n\r\n const [ox, oy] = text.offset\r\n item.text.x = item.coordinate[0] + ox\r\n item.text.y = item.coordinate[1] + oy\r\n\r\n item.key = `${item.coordinate.toString()}${i}`\r\n\r\n return item\r\n })\r\n },\r\n calcLinePaths () {\r\n const { getPath, mergedConfig } = this\r\n\r\n const { points, lines } = mergedConfig\r\n\r\n this.flylines = lines.map(item => {\r\n const { source, target, duration } = item\r\n\r\n const sourcePoint = points.find(({ name }) => name === source).coordinate\r\n const targetPoint = points.find(({ name }) => name === target).coordinate\r\n\r\n const path = getPath(sourcePoint, targetPoint).map(item => item.map(v => parseFloat(v.toFixed(10))))\r\n const d = `M${path[0].toString()} Q${path[1].toString()} ${path[2].toString()}`\r\n const key = `path${path.toString()}`\r\n const time = randomExtend(...duration) / 10\r\n\r\n return { ...item, path, key, d, time }\r\n })\r\n },\r\n getPath (start, end) {\r\n const { getControlPoint } = this\r\n\r\n const controlPoint = getControlPoint(start, end)\r\n\r\n return [start, controlPoint, end]\r\n },\r\n getControlPoint ([sx, sy], [ex, ey]) {\r\n const { getKLinePointByx, mergedConfig } = this\r\n\r\n const { curvature, k } = mergedConfig\r\n\r\n const [mx, my] = [(sx + ex) / 2, (sy + ey) / 2]\r\n\r\n const distance = getPointDistance([sx, sy], [ex, ey])\r\n\r\n const targetLength = distance / curvature\r\n const disDived = targetLength / 2\r\n\r\n let [dx, dy] = [mx, my]\r\n\r\n do {\r\n dx += disDived\r\n dy = getKLinePointByx(k, [mx, my], dx)[1]\r\n } while (getPointDistance([mx, my], [dx, dy]) < targetLength)\r\n\r\n return [dx, dy]\r\n },\r\n getKLinePointByx (k, [lx, ly], x) {\r\n const y = ly - k * lx + k * x\r\n\r\n return [x, y]\r\n },\r\n async calcLineLengths () {\r\n const { $nextTick, flylines, $refs } = this\r\n\r\n await $nextTick()\r\n\r\n this.flylineLengths = flylines.map(({ key }) => $refs[key][0].getTotalLength())\r\n },\r\n consoleClickPos ({ offsetX, offsetY }) {\r\n const { width, height, dev } = this\r\n\r\n if (!dev) return\r\n\r\n const relativeX = (offsetX / width).toFixed(2)\r\n const relativeY = (offsetY / height).toFixed(2)\r\n\r\n console.warn(`dv-flyline-chart-enhanced DEV: \\n Click Position is [${offsetX}, ${offsetY}] \\n Relative Position is [${relativeX}, ${relativeY}]`)\r\n }\r\n }\r\n}\r\n</script>"],"sourceRoot":"node_modules/@jiaminghi/data-view/lib/components/flylineChartEnhanced/src"}]} |