UNPKG

highcharts

Version:
127 lines (126 loc) 4.1 kB
/* * * * (c) 2010-2021 Torstein Honsi * * Extension to the Series object in 3D charts. * * License: www.highcharts.com/license * * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!! * * */ 'use strict'; var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); import Math3D from '../../Extensions/Math3D.js'; var perspective = Math3D.perspective; import Series from '../Series/Series.js'; import U from '../Utilities.js'; var addEvent = U.addEvent, extend = U.extend, merge = U.merge, pick = U.pick, isNumber = U.isNumber; /* * * * Class * * */ var Series3D = /** @class */ (function (_super) { __extends(Series3D, _super); function Series3D() { return _super !== null && _super.apply(this, arguments) || this; } /* * * * Functions * * */ /* eslint-disable valid-jsdoc */ Series3D.prototype.translate = function () { _super.prototype.translate.apply(this, arguments); if (this.chart.is3d()) { this.translate3dPoints(); } }; /** * Translate the plotX, plotY properties and add plotZ. * @private */ Series3D.prototype.translate3dPoints = function () { var series = this, seriesOptions = series.options, chart = series.chart, zAxis = pick(series.zAxis, chart.options.zAxis[0]), rawPoints = [], rawPoint, projectedPoints, projectedPoint, zValue, i, rawPointsX = [], stack = seriesOptions.stacking ? (isNumber(seriesOptions.stack) ? seriesOptions.stack : 0) : series.index || 0; series.zPadding = stack * (seriesOptions.depth || 0 + (seriesOptions.groupZPadding || 1)); for (i = 0; i < series.data.length; i++) { rawPoint = series.data[i]; if (zAxis && zAxis.translate) { zValue = zAxis.logarithmic && zAxis.val2lin ? zAxis.val2lin(rawPoint.z) : rawPoint.z; // #4562 rawPoint.plotZ = zAxis.translate(zValue); rawPoint.isInside = rawPoint.isInside ? (zValue >= zAxis.min && zValue <= zAxis.max) : false; } else { rawPoint.plotZ = series.zPadding; } rawPoint.axisXpos = rawPoint.plotX; rawPoint.axisYpos = rawPoint.plotY; rawPoint.axisZpos = rawPoint.plotZ; rawPoints.push({ x: rawPoint.plotX, y: rawPoint.plotY, z: rawPoint.plotZ }); rawPointsX.push(rawPoint.plotX || 0); } series.rawPointsX = rawPointsX; projectedPoints = perspective(rawPoints, chart, true); for (i = 0; i < series.data.length; i++) { rawPoint = series.data[i]; projectedPoint = projectedPoints[i]; rawPoint.plotX = projectedPoint.x; rawPoint.plotY = projectedPoint.y; rawPoint.plotZ = projectedPoint.z; } }; /* * * * Static Properties * * */ Series3D.defaultOptions = merge(Series.defaultOptions); return Series3D; }(Series)); /* * * * Compatibility * * */ /* eslint-disable no-invalid-this */ addEvent(Series, 'afterTranslate', function () { if (this.chart.is3d()) { this.translate3dPoints(); } }); /* eslint-enable no-invalid-this */ extend(Series.prototype, { translate3dPoints: Series3D.prototype.translate3dPoints }); /* * * * Default Export * * */ export default Series3D;