| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- /* *
- *
- * (c) 2010-2021 Torstein Honsi
- *
- * Scatter 3D series.
- *
- * 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 pointCameraDistance = Math3D.pointCameraDistance;
- import Scatter3DPoint from './Scatter3DPoint.js';
- import ScatterSeries from '../Scatter/ScatterSeries.js';
- import SeriesRegistry from '../../Core/Series/SeriesRegistry.js';
- import U from '../../Core/Utilities.js';
- var extend = U.extend, merge = U.merge;
- /* *
- *
- * Class
- *
- * */
- /**
- * @private
- * @class
- * @name Highcharts.seriesTypes.scatter3d
- *
- * @augments Highcharts.Series
- */
- var Scatter3DSeries = /** @class */ (function (_super) {
- __extends(Scatter3DSeries, _super);
- function Scatter3DSeries() {
- /* *
- *
- * Static Properties
- *
- * */
- var _this = _super !== null && _super.apply(this, arguments) || this;
- /* *
- *
- * Properties
- *
- * */
- _this.data = void 0;
- _this.options = void 0;
- _this.points = void 0;
- return _this;
- }
- /* *
- *
- * Functions
- *
- * */
- Scatter3DSeries.prototype.pointAttribs = function (point) {
- var attribs = _super.prototype.pointAttribs.apply(this, arguments);
- if (this.chart.is3d() && point) {
- attribs.zIndex =
- pointCameraDistance(point, this.chart);
- }
- return attribs;
- };
- /**
- * A 3D scatter plot uses x, y and z coordinates to display values for three
- * variables for a set of data.
- *
- * @sample {highcharts} highcharts/3d/scatter/
- * Simple 3D scatter
- * @sample {highcharts} highcharts/demo/3d-scatter-draggable
- * Draggable 3d scatter
- *
- * @extends plotOptions.scatter
- * @excluding dragDrop, cluster, boostThreshold, boostBlending
- * @product highcharts
- * @requires highcharts-3d
- * @optionparent plotOptions.scatter3d
- */
- Scatter3DSeries.defaultOptions = merge(ScatterSeries.defaultOptions, {
- tooltip: {
- pointFormat: 'x: <b>{point.x}</b><br/>y: <b>{point.y}</b><br/>z: <b>{point.z}</b><br/>'
- }
- });
- return Scatter3DSeries;
- }(ScatterSeries));
- extend(Scatter3DSeries.prototype, {
- axisTypes: ['xAxis', 'yAxis', 'zAxis'],
- // Require direct touch rather than using the k-d-tree, because the
- // k-d-tree currently doesn't take the xyz coordinate system into
- // account (#4552)
- directTouch: true,
- parallelArrays: ['x', 'y', 'z'],
- pointArrayMap: ['x', 'y', 'z'],
- pointClass: Scatter3DPoint
- });
- SeriesRegistry.registerSeriesType('scatter3d', Scatter3DSeries);
- /* *
- *
- * Default Export
- *
- * */
- export default Scatter3DSeries;
- /* *
- *
- * API Options
- *
- * */
- /**
- * A `scatter3d` series. If the [type](#series.scatter3d.type) option is
- * not specified, it is inherited from [chart.type](#chart.type).
- *
- * scatter3d](#plotOptions.scatter3d).
- *
- * @extends series,plotOptions.scatter3d
- * @excluding boostThreshold, boostBlending
- * @product highcharts
- * @requires highcharts-3d
- * @apioption series.scatter3d
- */
- /**
- * An array of data points for the series. For the `scatter3d` series
- * type, points can be given in the following ways:
- *
- * 1. An array of arrays with 3 values. In this case, the values correspond
- * to `x,y,z`. If the first value is a string, it is applied as the name
- * of the point, and the `x` value is inferred.
- *
- * ```js
- * data: [
- * [0, 0, 1],
- * [1, 8, 7],
- * [2, 9, 2]
- * ]
- * ```
- *
- * 3. An array of objects with named values. The following snippet shows only a
- * few settings, see the complete options set below. If the total number of data
- * points exceeds the series'
- * [turboThreshold](#series.scatter3d.turboThreshold), this option is not
- * available.
- *
- * ```js
- * data: [{
- * x: 1,
- * y: 2,
- * z: 24,
- * name: "Point2",
- * color: "#00FF00"
- * }, {
- * x: 1,
- * y: 4,
- * z: 12,
- * name: "Point1",
- * color: "#FF00FF"
- * }]
- * ```
- *
- * @sample {highcharts} highcharts/chart/reflow-true/
- * Numerical values
- * @sample {highcharts} highcharts/series/data-array-of-arrays/
- * Arrays of numeric x and y
- * @sample {highcharts} highcharts/series/data-array-of-arrays-datetime/
- * Arrays of datetime x and y
- * @sample {highcharts} highcharts/series/data-array-of-name-value/
- * Arrays of point.name and y
- * @sample {highcharts} highcharts/series/data-array-of-objects/
- * Config objects
- *
- * @type {Array<Array<number>|*>}
- * @extends series.scatter.data
- * @product highcharts
- * @apioption series.scatter3d.data
- */
- /**
- * The z value for each data point.
- *
- * @type {number}
- * @product highcharts
- * @apioption series.scatter3d.data.z
- */
- ''; // adds doclets above to transpiled file
|