pinch.js 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. exports.__esModule = true;
  4. exports["default"] = void 0;
  5. var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
  6. var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
  7. var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
  8. var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose"));
  9. var _base = _interopRequireDefault(require("./base"));
  10. var _common = require("../../util/common");
  11. function _createSuper(Derived) { return function () { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (_isNativeReflectConstruct()) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
  12. function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
  13. var Pinch = /*#__PURE__*/function (_Base) {
  14. (0, _inheritsLoose2["default"])(Pinch, _Base);
  15. var _super = _createSuper(Pinch);
  16. var _proto = Pinch.prototype;
  17. _proto.getDefaultCfg = function getDefaultCfg() {
  18. return {
  19. type: 'pinch',
  20. startEvent: 'pinchstart',
  21. processEvent: 'pinch',
  22. endEvent: 'pinchend'
  23. };
  24. };
  25. function Pinch(cfg, chart) {
  26. var _this;
  27. _this = _Base.call(this, cfg, chart) || this;
  28. var _assertThisInitialize = (0, _assertThisInitialized2["default"])(_this),
  29. context = _assertThisInitialize.context;
  30. (0, _common.mix)(context, cfg);
  31. return _this;
  32. }
  33. _proto.start = function start() {
  34. var context = this.context;
  35. context.start();
  36. };
  37. _proto.process = function process(e) {
  38. e.preventDefault && e.preventDefault();
  39. var zoom = e.zoom,
  40. center = e.center;
  41. var context = this.context;
  42. var chart = context.chart;
  43. var coord = chart.get('coord');
  44. var start = coord.start,
  45. end = coord.end;
  46. var coordWidth = end.x - start.x;
  47. var leftLen = Math.abs(center.x - start.x);
  48. var rightLen = Math.abs(end.x - center.x); // 计算左右缩放的比例
  49. var leftScale = leftLen / coordWidth;
  50. var rightScale = rightLen / coordWidth;
  51. context.doZoom(leftScale, rightScale, zoom);
  52. };
  53. _proto.end = function end() {
  54. // 缩放完成后再更新ticks
  55. var context = this.context;
  56. context.updateTicks();
  57. };
  58. return Pinch;
  59. }(_base["default"]);
  60. var _default = Pinch;
  61. exports["default"] = _default;