123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688 |
- /*
- * 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.
- */
- /**
- * AUTO-GENERATED FILE. DO NOT MODIFY.
- */
- /*
- * 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 { __extends } from "tslib";
- import * as zrUtil from 'zrender/lib/core/util.js';
- import LinearGradient from 'zrender/lib/graphic/LinearGradient.js';
- import * as eventTool from 'zrender/lib/core/event.js';
- import VisualMapView from './VisualMapView.js';
- import * as graphic from '../../util/graphic.js';
- import * as numberUtil from '../../util/number.js';
- import sliderMove from '../helper/sliderMove.js';
- import * as helper from './helper.js';
- import * as modelUtil from '../../util/model.js';
- import { parsePercent } from 'zrender/lib/contain/text.js';
- import { setAsHighDownDispatcher } from '../../util/states.js';
- import { createSymbol } from '../../util/symbol.js';
- import ZRImage from 'zrender/lib/graphic/Image.js';
- import { getECData } from '../../util/innerStore.js';
- import { createTextStyle } from '../../label/labelStyle.js';
- import { findEventDispatcher } from '../../util/event.js';
- var linearMap = numberUtil.linearMap;
- var each = zrUtil.each;
- var mathMin = Math.min;
- var mathMax = Math.max;
- // Arbitrary value
- var HOVER_LINK_SIZE = 12;
- var HOVER_LINK_OUT = 6;
- // Notice:
- // Any "interval" should be by the order of [low, high].
- // "handle0" (handleIndex === 0) maps to
- // low data value: this._dataInterval[0] and has low coord.
- // "handle1" (handleIndex === 1) maps to
- // high data value: this._dataInterval[1] and has high coord.
- // The logic of transform is implemented in this._createBarGroup.
- var ContinuousView = /** @class */function (_super) {
- __extends(ContinuousView, _super);
- function ContinuousView() {
- var _this = _super !== null && _super.apply(this, arguments) || this;
- _this.type = ContinuousView.type;
- _this._shapes = {};
- _this._dataInterval = [];
- _this._handleEnds = [];
- _this._hoverLinkDataIndices = [];
- return _this;
- }
- ContinuousView.prototype.init = function (ecModel, api) {
- _super.prototype.init.call(this, ecModel, api);
- this._hoverLinkFromSeriesMouseOver = zrUtil.bind(this._hoverLinkFromSeriesMouseOver, this);
- this._hideIndicator = zrUtil.bind(this._hideIndicator, this);
- };
- ContinuousView.prototype.doRender = function (visualMapModel, ecModel, api, payload) {
- if (!payload || payload.type !== 'selectDataRange' || payload.from !== this.uid) {
- this._buildView();
- }
- };
- ContinuousView.prototype._buildView = function () {
- this.group.removeAll();
- var visualMapModel = this.visualMapModel;
- var thisGroup = this.group;
- this._orient = visualMapModel.get('orient');
- this._useHandle = visualMapModel.get('calculable');
- this._resetInterval();
- this._renderBar(thisGroup);
- var dataRangeText = visualMapModel.get('text');
- this._renderEndsText(thisGroup, dataRangeText, 0);
- this._renderEndsText(thisGroup, dataRangeText, 1);
- // Do this for background size calculation.
- this._updateView(true);
- // After updating view, inner shapes is built completely,
- // and then background can be rendered.
- this.renderBackground(thisGroup);
- // Real update view
- this._updateView();
- this._enableHoverLinkToSeries();
- this._enableHoverLinkFromSeries();
- this.positionGroup(thisGroup);
- };
- ContinuousView.prototype._renderEndsText = function (group, dataRangeText, endsIndex) {
- if (!dataRangeText) {
- return;
- }
- // Compatible with ec2, text[0] map to high value, text[1] map low value.
- var text = dataRangeText[1 - endsIndex];
- text = text != null ? text + '' : '';
- var visualMapModel = this.visualMapModel;
- var textGap = visualMapModel.get('textGap');
- var itemSize = visualMapModel.itemSize;
- var barGroup = this._shapes.mainGroup;
- var position = this._applyTransform([itemSize[0] / 2, endsIndex === 0 ? -textGap : itemSize[1] + textGap], barGroup);
- var align = this._applyTransform(endsIndex === 0 ? 'bottom' : 'top', barGroup);
- var orient = this._orient;
- var textStyleModel = this.visualMapModel.textStyleModel;
- this.group.add(new graphic.Text({
- style: createTextStyle(textStyleModel, {
- x: position[0],
- y: position[1],
- verticalAlign: orient === 'horizontal' ? 'middle' : align,
- align: orient === 'horizontal' ? align : 'center',
- text: text
- })
- }));
- };
- ContinuousView.prototype._renderBar = function (targetGroup) {
- var visualMapModel = this.visualMapModel;
- var shapes = this._shapes;
- var itemSize = visualMapModel.itemSize;
- var orient = this._orient;
- var useHandle = this._useHandle;
- var itemAlign = helper.getItemAlign(visualMapModel, this.api, itemSize);
- var mainGroup = shapes.mainGroup = this._createBarGroup(itemAlign);
- var gradientBarGroup = new graphic.Group();
- mainGroup.add(gradientBarGroup);
- // Bar
- gradientBarGroup.add(shapes.outOfRange = createPolygon());
- gradientBarGroup.add(shapes.inRange = createPolygon(null, useHandle ? getCursor(this._orient) : null, zrUtil.bind(this._dragHandle, this, 'all', false), zrUtil.bind(this._dragHandle, this, 'all', true)));
- // A border radius clip.
- gradientBarGroup.setClipPath(new graphic.Rect({
- shape: {
- x: 0,
- y: 0,
- width: itemSize[0],
- height: itemSize[1],
- r: 3
- }
- }));
- var textRect = visualMapModel.textStyleModel.getTextRect('国');
- var textSize = mathMax(textRect.width, textRect.height);
- // Handle
- if (useHandle) {
- shapes.handleThumbs = [];
- shapes.handleLabels = [];
- shapes.handleLabelPoints = [];
- this._createHandle(visualMapModel, mainGroup, 0, itemSize, textSize, orient);
- this._createHandle(visualMapModel, mainGroup, 1, itemSize, textSize, orient);
- }
- this._createIndicator(visualMapModel, mainGroup, itemSize, textSize, orient);
- targetGroup.add(mainGroup);
- };
- ContinuousView.prototype._createHandle = function (visualMapModel, mainGroup, handleIndex, itemSize, textSize, orient) {
- var onDrift = zrUtil.bind(this._dragHandle, this, handleIndex, false);
- var onDragEnd = zrUtil.bind(this._dragHandle, this, handleIndex, true);
- var handleSize = parsePercent(visualMapModel.get('handleSize'), itemSize[0]);
- var handleThumb = createSymbol(visualMapModel.get('handleIcon'), -handleSize / 2, -handleSize / 2, handleSize, handleSize, null, true);
- var cursor = getCursor(this._orient);
- handleThumb.attr({
- cursor: cursor,
- draggable: true,
- drift: onDrift,
- ondragend: onDragEnd,
- onmousemove: function (e) {
- eventTool.stop(e.event);
- }
- });
- handleThumb.x = itemSize[0] / 2;
- handleThumb.useStyle(visualMapModel.getModel('handleStyle').getItemStyle());
- handleThumb.setStyle({
- strokeNoScale: true,
- strokeFirst: true
- });
- handleThumb.style.lineWidth *= 2;
- handleThumb.ensureState('emphasis').style = visualMapModel.getModel(['emphasis', 'handleStyle']).getItemStyle();
- setAsHighDownDispatcher(handleThumb, true);
- mainGroup.add(handleThumb);
- // Text is always horizontal layout but should not be effected by
- // transform (orient/inverse). So label is built separately but not
- // use zrender/graphic/helper/RectText, and is located based on view
- // group (according to handleLabelPoint) but not barGroup.
- var textStyleModel = this.visualMapModel.textStyleModel;
- var handleLabel = new graphic.Text({
- cursor: cursor,
- draggable: true,
- drift: onDrift,
- onmousemove: function (e) {
- // For mobile device, prevent screen slider on the button.
- eventTool.stop(e.event);
- },
- ondragend: onDragEnd,
- style: createTextStyle(textStyleModel, {
- x: 0,
- y: 0,
- text: ''
- })
- });
- handleLabel.ensureState('blur').style = {
- opacity: 0.1
- };
- handleLabel.stateTransition = {
- duration: 200
- };
- this.group.add(handleLabel);
- var handleLabelPoint = [handleSize, 0];
- var shapes = this._shapes;
- shapes.handleThumbs[handleIndex] = handleThumb;
- shapes.handleLabelPoints[handleIndex] = handleLabelPoint;
- shapes.handleLabels[handleIndex] = handleLabel;
- };
- ContinuousView.prototype._createIndicator = function (visualMapModel, mainGroup, itemSize, textSize, orient) {
- var scale = parsePercent(visualMapModel.get('indicatorSize'), itemSize[0]);
- var indicator = createSymbol(visualMapModel.get('indicatorIcon'), -scale / 2, -scale / 2, scale, scale, null, true);
- indicator.attr({
- cursor: 'move',
- invisible: true,
- silent: true,
- x: itemSize[0] / 2
- });
- var indicatorStyle = visualMapModel.getModel('indicatorStyle').getItemStyle();
- if (indicator instanceof ZRImage) {
- var pathStyle = indicator.style;
- indicator.useStyle(zrUtil.extend({
- // TODO other properties like x, y ?
- image: pathStyle.image,
- x: pathStyle.x,
- y: pathStyle.y,
- width: pathStyle.width,
- height: pathStyle.height
- }, indicatorStyle));
- } else {
- indicator.useStyle(indicatorStyle);
- }
- mainGroup.add(indicator);
- var textStyleModel = this.visualMapModel.textStyleModel;
- var indicatorLabel = new graphic.Text({
- silent: true,
- invisible: true,
- style: createTextStyle(textStyleModel, {
- x: 0,
- y: 0,
- text: ''
- })
- });
- this.group.add(indicatorLabel);
- var indicatorLabelPoint = [(orient === 'horizontal' ? textSize / 2 : HOVER_LINK_OUT) + itemSize[0] / 2, 0];
- var shapes = this._shapes;
- shapes.indicator = indicator;
- shapes.indicatorLabel = indicatorLabel;
- shapes.indicatorLabelPoint = indicatorLabelPoint;
- this._firstShowIndicator = true;
- };
- ContinuousView.prototype._dragHandle = function (handleIndex, isEnd,
- // dx is event from ondragend if isEnd is true. It's not used
- dx, dy) {
- if (!this._useHandle) {
- return;
- }
- this._dragging = !isEnd;
- if (!isEnd) {
- // Transform dx, dy to bar coordination.
- var vertex = this._applyTransform([dx, dy], this._shapes.mainGroup, true);
- this._updateInterval(handleIndex, vertex[1]);
- this._hideIndicator();
- // Considering realtime, update view should be executed
- // before dispatch action.
- this._updateView();
- }
- // dragEnd do not dispatch action when realtime.
- if (isEnd === !this.visualMapModel.get('realtime')) {
- // jshint ignore:line
- this.api.dispatchAction({
- type: 'selectDataRange',
- from: this.uid,
- visualMapId: this.visualMapModel.id,
- selected: this._dataInterval.slice()
- });
- }
- if (isEnd) {
- !this._hovering && this._clearHoverLinkToSeries();
- } else if (useHoverLinkOnHandle(this.visualMapModel)) {
- this._doHoverLinkToSeries(this._handleEnds[handleIndex], false);
- }
- };
- ContinuousView.prototype._resetInterval = function () {
- var visualMapModel = this.visualMapModel;
- var dataInterval = this._dataInterval = visualMapModel.getSelected();
- var dataExtent = visualMapModel.getExtent();
- var sizeExtent = [0, visualMapModel.itemSize[1]];
- this._handleEnds = [linearMap(dataInterval[0], dataExtent, sizeExtent, true), linearMap(dataInterval[1], dataExtent, sizeExtent, true)];
- };
- /**
- * @private
- * @param {(number|string)} handleIndex 0 or 1 or 'all'
- * @param {number} dx
- * @param {number} dy
- */
- ContinuousView.prototype._updateInterval = function (handleIndex, delta) {
- delta = delta || 0;
- var visualMapModel = this.visualMapModel;
- var handleEnds = this._handleEnds;
- var sizeExtent = [0, visualMapModel.itemSize[1]];
- sliderMove(delta, handleEnds, sizeExtent, handleIndex,
- // cross is forbidden
- 0);
- var dataExtent = visualMapModel.getExtent();
- // Update data interval.
- this._dataInterval = [linearMap(handleEnds[0], sizeExtent, dataExtent, true), linearMap(handleEnds[1], sizeExtent, dataExtent, true)];
- };
- ContinuousView.prototype._updateView = function (forSketch) {
- var visualMapModel = this.visualMapModel;
- var dataExtent = visualMapModel.getExtent();
- var shapes = this._shapes;
- var outOfRangeHandleEnds = [0, visualMapModel.itemSize[1]];
- var inRangeHandleEnds = forSketch ? outOfRangeHandleEnds : this._handleEnds;
- var visualInRange = this._createBarVisual(this._dataInterval, dataExtent, inRangeHandleEnds, 'inRange');
- var visualOutOfRange = this._createBarVisual(dataExtent, dataExtent, outOfRangeHandleEnds, 'outOfRange');
- shapes.inRange.setStyle({
- fill: visualInRange.barColor
- // opacity: visualInRange.opacity
- }).setShape('points', visualInRange.barPoints);
- shapes.outOfRange.setStyle({
- fill: visualOutOfRange.barColor
- // opacity: visualOutOfRange.opacity
- }).setShape('points', visualOutOfRange.barPoints);
- this._updateHandle(inRangeHandleEnds, visualInRange);
- };
- ContinuousView.prototype._createBarVisual = function (dataInterval, dataExtent, handleEnds, forceState) {
- var opts = {
- forceState: forceState,
- convertOpacityToAlpha: true
- };
- var colorStops = this._makeColorGradient(dataInterval, opts);
- var symbolSizes = [this.getControllerVisual(dataInterval[0], 'symbolSize', opts), this.getControllerVisual(dataInterval[1], 'symbolSize', opts)];
- var barPoints = this._createBarPoints(handleEnds, symbolSizes);
- return {
- barColor: new LinearGradient(0, 0, 0, 1, colorStops),
- barPoints: barPoints,
- handlesColor: [colorStops[0].color, colorStops[colorStops.length - 1].color]
- };
- };
- ContinuousView.prototype._makeColorGradient = function (dataInterval, opts) {
- // Considering colorHue, which is not linear, so we have to sample
- // to calculate gradient color stops, but not only calculate head
- // and tail.
- var sampleNumber = 100; // Arbitrary value.
- var colorStops = [];
- var step = (dataInterval[1] - dataInterval[0]) / sampleNumber;
- colorStops.push({
- color: this.getControllerVisual(dataInterval[0], 'color', opts),
- offset: 0
- });
- for (var i = 1; i < sampleNumber; i++) {
- var currValue = dataInterval[0] + step * i;
- if (currValue > dataInterval[1]) {
- break;
- }
- colorStops.push({
- color: this.getControllerVisual(currValue, 'color', opts),
- offset: i / sampleNumber
- });
- }
- colorStops.push({
- color: this.getControllerVisual(dataInterval[1], 'color', opts),
- offset: 1
- });
- return colorStops;
- };
- ContinuousView.prototype._createBarPoints = function (handleEnds, symbolSizes) {
- var itemSize = this.visualMapModel.itemSize;
- return [[itemSize[0] - symbolSizes[0], handleEnds[0]], [itemSize[0], handleEnds[0]], [itemSize[0], handleEnds[1]], [itemSize[0] - symbolSizes[1], handleEnds[1]]];
- };
- ContinuousView.prototype._createBarGroup = function (itemAlign) {
- var orient = this._orient;
- var inverse = this.visualMapModel.get('inverse');
- return new graphic.Group(orient === 'horizontal' && !inverse ? {
- scaleX: itemAlign === 'bottom' ? 1 : -1,
- rotation: Math.PI / 2
- } : orient === 'horizontal' && inverse ? {
- scaleX: itemAlign === 'bottom' ? -1 : 1,
- rotation: -Math.PI / 2
- } : orient === 'vertical' && !inverse ? {
- scaleX: itemAlign === 'left' ? 1 : -1,
- scaleY: -1
- } : {
- scaleX: itemAlign === 'left' ? 1 : -1
- });
- };
- ContinuousView.prototype._updateHandle = function (handleEnds, visualInRange) {
- if (!this._useHandle) {
- return;
- }
- var shapes = this._shapes;
- var visualMapModel = this.visualMapModel;
- var handleThumbs = shapes.handleThumbs;
- var handleLabels = shapes.handleLabels;
- var itemSize = visualMapModel.itemSize;
- var dataExtent = visualMapModel.getExtent();
- each([0, 1], function (handleIndex) {
- var handleThumb = handleThumbs[handleIndex];
- handleThumb.setStyle('fill', visualInRange.handlesColor[handleIndex]);
- handleThumb.y = handleEnds[handleIndex];
- var val = linearMap(handleEnds[handleIndex], [0, itemSize[1]], dataExtent, true);
- var symbolSize = this.getControllerVisual(val, 'symbolSize');
- handleThumb.scaleX = handleThumb.scaleY = symbolSize / itemSize[0];
- handleThumb.x = itemSize[0] - symbolSize / 2;
- // Update handle label position.
- var textPoint = graphic.applyTransform(shapes.handleLabelPoints[handleIndex], graphic.getTransform(handleThumb, this.group));
- handleLabels[handleIndex].setStyle({
- x: textPoint[0],
- y: textPoint[1],
- text: visualMapModel.formatValueText(this._dataInterval[handleIndex]),
- verticalAlign: 'middle',
- align: this._orient === 'vertical' ? this._applyTransform('left', shapes.mainGroup) : 'center'
- });
- }, this);
- };
- ContinuousView.prototype._showIndicator = function (cursorValue, textValue, rangeSymbol, halfHoverLinkSize) {
- var visualMapModel = this.visualMapModel;
- var dataExtent = visualMapModel.getExtent();
- var itemSize = visualMapModel.itemSize;
- var sizeExtent = [0, itemSize[1]];
- var shapes = this._shapes;
- var indicator = shapes.indicator;
- if (!indicator) {
- return;
- }
- indicator.attr('invisible', false);
- var opts = {
- convertOpacityToAlpha: true
- };
- var color = this.getControllerVisual(cursorValue, 'color', opts);
- var symbolSize = this.getControllerVisual(cursorValue, 'symbolSize');
- var y = linearMap(cursorValue, dataExtent, sizeExtent, true);
- var x = itemSize[0] - symbolSize / 2;
- var oldIndicatorPos = {
- x: indicator.x,
- y: indicator.y
- };
- // Update handle label position.
- indicator.y = y;
- indicator.x = x;
- var textPoint = graphic.applyTransform(shapes.indicatorLabelPoint, graphic.getTransform(indicator, this.group));
- var indicatorLabel = shapes.indicatorLabel;
- indicatorLabel.attr('invisible', false);
- var align = this._applyTransform('left', shapes.mainGroup);
- var orient = this._orient;
- var isHorizontal = orient === 'horizontal';
- indicatorLabel.setStyle({
- text: (rangeSymbol ? rangeSymbol : '') + visualMapModel.formatValueText(textValue),
- verticalAlign: isHorizontal ? align : 'middle',
- align: isHorizontal ? 'center' : align
- });
- var indicatorNewProps = {
- x: x,
- y: y,
- style: {
- fill: color
- }
- };
- var labelNewProps = {
- style: {
- x: textPoint[0],
- y: textPoint[1]
- }
- };
- if (visualMapModel.ecModel.isAnimationEnabled() && !this._firstShowIndicator) {
- var animationCfg = {
- duration: 100,
- easing: 'cubicInOut',
- additive: true
- };
- indicator.x = oldIndicatorPos.x;
- indicator.y = oldIndicatorPos.y;
- indicator.animateTo(indicatorNewProps, animationCfg);
- indicatorLabel.animateTo(labelNewProps, animationCfg);
- } else {
- indicator.attr(indicatorNewProps);
- indicatorLabel.attr(labelNewProps);
- }
- this._firstShowIndicator = false;
- var handleLabels = this._shapes.handleLabels;
- if (handleLabels) {
- for (var i = 0; i < handleLabels.length; i++) {
- // Fade out handle labels.
- // NOTE: Must use api enter/leave on emphasis/blur/select state. Or the global states manager will change it.
- this.api.enterBlur(handleLabels[i]);
- }
- }
- };
- ContinuousView.prototype._enableHoverLinkToSeries = function () {
- var self = this;
- this._shapes.mainGroup.on('mousemove', function (e) {
- self._hovering = true;
- if (!self._dragging) {
- var itemSize = self.visualMapModel.itemSize;
- var pos = self._applyTransform([e.offsetX, e.offsetY], self._shapes.mainGroup, true, true);
- // For hover link show when hover handle, which might be
- // below or upper than sizeExtent.
- pos[1] = mathMin(mathMax(0, pos[1]), itemSize[1]);
- self._doHoverLinkToSeries(pos[1], 0 <= pos[0] && pos[0] <= itemSize[0]);
- }
- }).on('mouseout', function () {
- // When mouse is out of handle, hoverLink still need
- // to be displayed when realtime is set as false.
- self._hovering = false;
- !self._dragging && self._clearHoverLinkToSeries();
- });
- };
- ContinuousView.prototype._enableHoverLinkFromSeries = function () {
- var zr = this.api.getZr();
- if (this.visualMapModel.option.hoverLink) {
- zr.on('mouseover', this._hoverLinkFromSeriesMouseOver, this);
- zr.on('mouseout', this._hideIndicator, this);
- } else {
- this._clearHoverLinkFromSeries();
- }
- };
- ContinuousView.prototype._doHoverLinkToSeries = function (cursorPos, hoverOnBar) {
- var visualMapModel = this.visualMapModel;
- var itemSize = visualMapModel.itemSize;
- if (!visualMapModel.option.hoverLink) {
- return;
- }
- var sizeExtent = [0, itemSize[1]];
- var dataExtent = visualMapModel.getExtent();
- // For hover link show when hover handle, which might be below or upper than sizeExtent.
- cursorPos = mathMin(mathMax(sizeExtent[0], cursorPos), sizeExtent[1]);
- var halfHoverLinkSize = getHalfHoverLinkSize(visualMapModel, dataExtent, sizeExtent);
- var hoverRange = [cursorPos - halfHoverLinkSize, cursorPos + halfHoverLinkSize];
- var cursorValue = linearMap(cursorPos, sizeExtent, dataExtent, true);
- var valueRange = [linearMap(hoverRange[0], sizeExtent, dataExtent, true), linearMap(hoverRange[1], sizeExtent, dataExtent, true)];
- // Consider data range is out of visualMap range, see test/visualMap-continuous.html,
- // where china and india has very large population.
- hoverRange[0] < sizeExtent[0] && (valueRange[0] = -Infinity);
- hoverRange[1] > sizeExtent[1] && (valueRange[1] = Infinity);
- // Do not show indicator when mouse is over handle,
- // otherwise labels overlap, especially when dragging.
- if (hoverOnBar) {
- if (valueRange[0] === -Infinity) {
- this._showIndicator(cursorValue, valueRange[1], '< ', halfHoverLinkSize);
- } else if (valueRange[1] === Infinity) {
- this._showIndicator(cursorValue, valueRange[0], '> ', halfHoverLinkSize);
- } else {
- this._showIndicator(cursorValue, cursorValue, '≈ ', halfHoverLinkSize);
- }
- }
- // When realtime is set as false, handles, which are in barGroup,
- // also trigger hoverLink, which help user to realize where they
- // focus on when dragging. (see test/heatmap-large.html)
- // When realtime is set as true, highlight will not show when hover
- // handle, because the label on handle, which displays a exact value
- // but not range, might mislead users.
- var oldBatch = this._hoverLinkDataIndices;
- var newBatch = [];
- if (hoverOnBar || useHoverLinkOnHandle(visualMapModel)) {
- newBatch = this._hoverLinkDataIndices = visualMapModel.findTargetDataIndices(valueRange);
- }
- var resultBatches = modelUtil.compressBatches(oldBatch, newBatch);
- this._dispatchHighDown('downplay', helper.makeHighDownBatch(resultBatches[0], visualMapModel));
- this._dispatchHighDown('highlight', helper.makeHighDownBatch(resultBatches[1], visualMapModel));
- };
- ContinuousView.prototype._hoverLinkFromSeriesMouseOver = function (e) {
- var ecData;
- findEventDispatcher(e.target, function (target) {
- var currECData = getECData(target);
- if (currECData.dataIndex != null) {
- ecData = currECData;
- return true;
- }
- }, true);
- if (!ecData) {
- return;
- }
- var dataModel = this.ecModel.getSeriesByIndex(ecData.seriesIndex);
- var visualMapModel = this.visualMapModel;
- if (!visualMapModel.isTargetSeries(dataModel)) {
- return;
- }
- var data = dataModel.getData(ecData.dataType);
- var value = data.getStore().get(visualMapModel.getDataDimensionIndex(data), ecData.dataIndex);
- if (!isNaN(value)) {
- this._showIndicator(value, value);
- }
- };
- ContinuousView.prototype._hideIndicator = function () {
- var shapes = this._shapes;
- shapes.indicator && shapes.indicator.attr('invisible', true);
- shapes.indicatorLabel && shapes.indicatorLabel.attr('invisible', true);
- var handleLabels = this._shapes.handleLabels;
- if (handleLabels) {
- for (var i = 0; i < handleLabels.length; i++) {
- // Fade out handle labels.
- // NOTE: Must use api enter/leave on emphasis/blur/select state. Or the global states manager will change it.
- this.api.leaveBlur(handleLabels[i]);
- }
- }
- };
- ContinuousView.prototype._clearHoverLinkToSeries = function () {
- this._hideIndicator();
- var indices = this._hoverLinkDataIndices;
- this._dispatchHighDown('downplay', helper.makeHighDownBatch(indices, this.visualMapModel));
- indices.length = 0;
- };
- ContinuousView.prototype._clearHoverLinkFromSeries = function () {
- this._hideIndicator();
- var zr = this.api.getZr();
- zr.off('mouseover', this._hoverLinkFromSeriesMouseOver);
- zr.off('mouseout', this._hideIndicator);
- };
- ContinuousView.prototype._applyTransform = function (vertex, element, inverse, global) {
- var transform = graphic.getTransform(element, global ? null : this.group);
- return zrUtil.isArray(vertex) ? graphic.applyTransform(vertex, transform, inverse) : graphic.transformDirection(vertex, transform, inverse);
- };
- // TODO: TYPE more specified payload types.
- ContinuousView.prototype._dispatchHighDown = function (type, batch) {
- batch && batch.length && this.api.dispatchAction({
- type: type,
- batch: batch
- });
- };
- /**
- * @override
- */
- ContinuousView.prototype.dispose = function () {
- this._clearHoverLinkFromSeries();
- this._clearHoverLinkToSeries();
- };
- ContinuousView.type = 'visualMap.continuous';
- return ContinuousView;
- }(VisualMapView);
- function createPolygon(points, cursor, onDrift, onDragEnd) {
- return new graphic.Polygon({
- shape: {
- points: points
- },
- draggable: !!onDrift,
- cursor: cursor,
- drift: onDrift,
- onmousemove: function (e) {
- // For mobile device, prevent screen slider on the button.
- eventTool.stop(e.event);
- },
- ondragend: onDragEnd
- });
- }
- function getHalfHoverLinkSize(visualMapModel, dataExtent, sizeExtent) {
- var halfHoverLinkSize = HOVER_LINK_SIZE / 2;
- var hoverLinkDataSize = visualMapModel.get('hoverLinkDataSize');
- if (hoverLinkDataSize) {
- halfHoverLinkSize = linearMap(hoverLinkDataSize, dataExtent, sizeExtent, true) / 2;
- }
- return halfHoverLinkSize;
- }
- function useHoverLinkOnHandle(visualMapModel) {
- var hoverLinkOnHandle = visualMapModel.get('hoverLinkOnHandle');
- return !!(hoverLinkOnHandle == null ? visualMapModel.get('realtime') : hoverLinkOnHandle);
- }
- function getCursor(orient) {
- return orient === 'vertical' ? 'ns-resize' : 'ew-resize';
- }
- export default ContinuousView;
|