123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484 |
- /*
- * 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 ZRText from 'zrender/lib/graphic/Text.js';
- import { isFunction, retrieve2, extend, keys, trim } from 'zrender/lib/core/util.js';
- import { SPECIAL_STATES, DISPLAY_STATES } from '../util/states.js';
- import { deprecateReplaceLog } from '../util/log.js';
- import { makeInner, interpolateRawValues } from '../util/model.js';
- import { initProps, updateProps } from '../util/graphic.js';
- var EMPTY_OBJ = {};
- export function setLabelText(label, labelTexts) {
- for (var i = 0; i < SPECIAL_STATES.length; i++) {
- var stateName = SPECIAL_STATES[i];
- var text = labelTexts[stateName];
- var state = label.ensureState(stateName);
- state.style = state.style || {};
- state.style.text = text;
- }
- var oldStates = label.currentStates.slice();
- label.clearStates(true);
- label.setStyle({
- text: labelTexts.normal
- });
- label.useStates(oldStates, true);
- }
- function getLabelText(opt, stateModels, interpolatedValue) {
- var labelFetcher = opt.labelFetcher;
- var labelDataIndex = opt.labelDataIndex;
- var labelDimIndex = opt.labelDimIndex;
- var normalModel = stateModels.normal;
- var baseText;
- if (labelFetcher) {
- baseText = labelFetcher.getFormattedLabel(labelDataIndex, 'normal', null, labelDimIndex, normalModel && normalModel.get('formatter'), interpolatedValue != null ? {
- interpolatedValue: interpolatedValue
- } : null);
- }
- if (baseText == null) {
- baseText = isFunction(opt.defaultText) ? opt.defaultText(labelDataIndex, opt, interpolatedValue) : opt.defaultText;
- }
- var statesText = {
- normal: baseText
- };
- for (var i = 0; i < SPECIAL_STATES.length; i++) {
- var stateName = SPECIAL_STATES[i];
- var stateModel = stateModels[stateName];
- statesText[stateName] = retrieve2(labelFetcher ? labelFetcher.getFormattedLabel(labelDataIndex, stateName, null, labelDimIndex, stateModel && stateModel.get('formatter')) : null, baseText);
- }
- return statesText;
- }
- function setLabelStyle(targetEl, labelStatesModels, opt, stateSpecified
- // TODO specified position?
- ) {
- opt = opt || EMPTY_OBJ;
- var isSetOnText = targetEl instanceof ZRText;
- var needsCreateText = false;
- for (var i = 0; i < DISPLAY_STATES.length; i++) {
- var stateModel = labelStatesModels[DISPLAY_STATES[i]];
- if (stateModel && stateModel.getShallow('show')) {
- needsCreateText = true;
- break;
- }
- }
- var textContent = isSetOnText ? targetEl : targetEl.getTextContent();
- if (needsCreateText) {
- if (!isSetOnText) {
- // Reuse the previous
- if (!textContent) {
- textContent = new ZRText();
- targetEl.setTextContent(textContent);
- }
- // Use same state proxy
- if (targetEl.stateProxy) {
- textContent.stateProxy = targetEl.stateProxy;
- }
- }
- var labelStatesTexts = getLabelText(opt, labelStatesModels);
- var normalModel = labelStatesModels.normal;
- var showNormal = !!normalModel.getShallow('show');
- var normalStyle = createTextStyle(normalModel, stateSpecified && stateSpecified.normal, opt, false, !isSetOnText);
- normalStyle.text = labelStatesTexts.normal;
- if (!isSetOnText) {
- // Always create new
- targetEl.setTextConfig(createTextConfig(normalModel, opt, false));
- }
- for (var i = 0; i < SPECIAL_STATES.length; i++) {
- var stateName = SPECIAL_STATES[i];
- var stateModel = labelStatesModels[stateName];
- if (stateModel) {
- var stateObj = textContent.ensureState(stateName);
- var stateShow = !!retrieve2(stateModel.getShallow('show'), showNormal);
- if (stateShow !== showNormal) {
- stateObj.ignore = !stateShow;
- }
- stateObj.style = createTextStyle(stateModel, stateSpecified && stateSpecified[stateName], opt, true, !isSetOnText);
- stateObj.style.text = labelStatesTexts[stateName];
- if (!isSetOnText) {
- var targetElEmphasisState = targetEl.ensureState(stateName);
- targetElEmphasisState.textConfig = createTextConfig(stateModel, opt, true);
- }
- }
- }
- // PENDING: if there is many requirements that emphasis position
- // need to be different from normal position, we might consider
- // auto silent is those cases.
- textContent.silent = !!normalModel.getShallow('silent');
- // Keep x and y
- if (textContent.style.x != null) {
- normalStyle.x = textContent.style.x;
- }
- if (textContent.style.y != null) {
- normalStyle.y = textContent.style.y;
- }
- textContent.ignore = !showNormal;
- // Always create new style.
- textContent.useStyle(normalStyle);
- textContent.dirty();
- if (opt.enableTextSetter) {
- labelInner(textContent).setLabelText = function (interpolatedValue) {
- var labelStatesTexts = getLabelText(opt, labelStatesModels, interpolatedValue);
- setLabelText(textContent, labelStatesTexts);
- };
- }
- } else if (textContent) {
- // Not display rich text.
- textContent.ignore = true;
- }
- targetEl.dirty();
- }
- export { setLabelStyle };
- export function getLabelStatesModels(itemModel, labelName) {
- labelName = labelName || 'label';
- var statesModels = {
- normal: itemModel.getModel(labelName)
- };
- for (var i = 0; i < SPECIAL_STATES.length; i++) {
- var stateName = SPECIAL_STATES[i];
- statesModels[stateName] = itemModel.getModel([stateName, labelName]);
- }
- return statesModels;
- }
- /**
- * Set basic textStyle properties.
- */
- export function createTextStyle(textStyleModel, specifiedTextStyle,
- // Fixed style in the code. Can't be set by model.
- opt, isNotNormal, isAttached // If text is attached on an element. If so, auto color will handling in zrender.
- ) {
- var textStyle = {};
- setTextStyleCommon(textStyle, textStyleModel, opt, isNotNormal, isAttached);
- specifiedTextStyle && extend(textStyle, specifiedTextStyle);
- // textStyle.host && textStyle.host.dirty && textStyle.host.dirty(false);
- return textStyle;
- }
- export function createTextConfig(textStyleModel, opt, isNotNormal) {
- opt = opt || {};
- var textConfig = {};
- var labelPosition;
- var labelRotate = textStyleModel.getShallow('rotate');
- var labelDistance = retrieve2(textStyleModel.getShallow('distance'), isNotNormal ? null : 5);
- var labelOffset = textStyleModel.getShallow('offset');
- labelPosition = textStyleModel.getShallow('position') || (isNotNormal ? null : 'inside');
- // 'outside' is not a valid zr textPostion value, but used
- // in bar series, and magric type should be considered.
- labelPosition === 'outside' && (labelPosition = opt.defaultOutsidePosition || 'top');
- if (labelPosition != null) {
- textConfig.position = labelPosition;
- }
- if (labelOffset != null) {
- textConfig.offset = labelOffset;
- }
- if (labelRotate != null) {
- labelRotate *= Math.PI / 180;
- textConfig.rotation = labelRotate;
- }
- if (labelDistance != null) {
- textConfig.distance = labelDistance;
- }
- // fill and auto is determined by the color of path fill if it's not specified by developers.
- textConfig.outsideFill = textStyleModel.get('color') === 'inherit' ? opt.inheritColor || null : 'auto';
- return textConfig;
- }
- /**
- * The uniform entry of set text style, that is, retrieve style definitions
- * from `model` and set to `textStyle` object.
- *
- * Never in merge mode, but in overwrite mode, that is, all of the text style
- * properties will be set. (Consider the states of normal and emphasis and
- * default value can be adopted, merge would make the logic too complicated
- * to manage.)
- */
- function setTextStyleCommon(textStyle, textStyleModel, opt, isNotNormal, isAttached) {
- // Consider there will be abnormal when merge hover style to normal style if given default value.
- opt = opt || EMPTY_OBJ;
- var ecModel = textStyleModel.ecModel;
- var globalTextStyle = ecModel && ecModel.option.textStyle;
- // Consider case:
- // {
- // data: [{
- // value: 12,
- // label: {
- // rich: {
- // // no 'a' here but using parent 'a'.
- // }
- // }
- // }],
- // rich: {
- // a: { ... }
- // }
- // }
- var richItemNames = getRichItemNames(textStyleModel);
- var richResult;
- if (richItemNames) {
- richResult = {};
- for (var name_1 in richItemNames) {
- if (richItemNames.hasOwnProperty(name_1)) {
- // Cascade is supported in rich.
- var richTextStyle = textStyleModel.getModel(['rich', name_1]);
- // In rich, never `disableBox`.
- // FIXME: consider `label: {formatter: '{a|xx}', color: 'blue', rich: {a: {}}}`,
- // the default color `'blue'` will not be adopted if no color declared in `rich`.
- // That might confuses users. So probably we should put `textStyleModel` as the
- // root ancestor of the `richTextStyle`. But that would be a break change.
- setTokenTextStyle(richResult[name_1] = {}, richTextStyle, globalTextStyle, opt, isNotNormal, isAttached, false, true);
- }
- }
- }
- if (richResult) {
- textStyle.rich = richResult;
- }
- var overflow = textStyleModel.get('overflow');
- if (overflow) {
- textStyle.overflow = overflow;
- }
- var margin = textStyleModel.get('minMargin');
- if (margin != null) {
- textStyle.margin = margin;
- }
- setTokenTextStyle(textStyle, textStyleModel, globalTextStyle, opt, isNotNormal, isAttached, true, false);
- }
- // Consider case:
- // {
- // data: [{
- // value: 12,
- // label: {
- // rich: {
- // // no 'a' here but using parent 'a'.
- // }
- // }
- // }],
- // rich: {
- // a: { ... }
- // }
- // }
- // TODO TextStyleModel
- function getRichItemNames(textStyleModel) {
- // Use object to remove duplicated names.
- var richItemNameMap;
- while (textStyleModel && textStyleModel !== textStyleModel.ecModel) {
- var rich = (textStyleModel.option || EMPTY_OBJ).rich;
- if (rich) {
- richItemNameMap = richItemNameMap || {};
- var richKeys = keys(rich);
- for (var i = 0; i < richKeys.length; i++) {
- var richKey = richKeys[i];
- richItemNameMap[richKey] = 1;
- }
- }
- textStyleModel = textStyleModel.parentModel;
- }
- return richItemNameMap;
- }
- var TEXT_PROPS_WITH_GLOBAL = ['fontStyle', 'fontWeight', 'fontSize', 'fontFamily', 'textShadowColor', 'textShadowBlur', 'textShadowOffsetX', 'textShadowOffsetY'];
- var TEXT_PROPS_SELF = ['align', 'lineHeight', 'width', 'height', 'tag', 'verticalAlign', 'ellipsis'];
- var TEXT_PROPS_BOX = ['padding', 'borderWidth', 'borderRadius', 'borderDashOffset', 'backgroundColor', 'borderColor', 'shadowColor', 'shadowBlur', 'shadowOffsetX', 'shadowOffsetY'];
- function setTokenTextStyle(textStyle, textStyleModel, globalTextStyle, opt, isNotNormal, isAttached, isBlock, inRich) {
- // In merge mode, default value should not be given.
- globalTextStyle = !isNotNormal && globalTextStyle || EMPTY_OBJ;
- var inheritColor = opt && opt.inheritColor;
- var fillColor = textStyleModel.getShallow('color');
- var strokeColor = textStyleModel.getShallow('textBorderColor');
- var opacity = retrieve2(textStyleModel.getShallow('opacity'), globalTextStyle.opacity);
- if (fillColor === 'inherit' || fillColor === 'auto') {
- if (process.env.NODE_ENV !== 'production') {
- if (fillColor === 'auto') {
- deprecateReplaceLog('color: \'auto\'', 'color: \'inherit\'');
- }
- }
- if (inheritColor) {
- fillColor = inheritColor;
- } else {
- fillColor = null;
- }
- }
- if (strokeColor === 'inherit' || strokeColor === 'auto') {
- if (process.env.NODE_ENV !== 'production') {
- if (strokeColor === 'auto') {
- deprecateReplaceLog('color: \'auto\'', 'color: \'inherit\'');
- }
- }
- if (inheritColor) {
- strokeColor = inheritColor;
- } else {
- strokeColor = null;
- }
- }
- if (!isAttached) {
- // Only use default global textStyle.color if text is individual.
- // Otherwise it will use the strategy of attached text color because text may be on a path.
- fillColor = fillColor || globalTextStyle.color;
- strokeColor = strokeColor || globalTextStyle.textBorderColor;
- }
- if (fillColor != null) {
- textStyle.fill = fillColor;
- }
- if (strokeColor != null) {
- textStyle.stroke = strokeColor;
- }
- var textBorderWidth = retrieve2(textStyleModel.getShallow('textBorderWidth'), globalTextStyle.textBorderWidth);
- if (textBorderWidth != null) {
- textStyle.lineWidth = textBorderWidth;
- }
- var textBorderType = retrieve2(textStyleModel.getShallow('textBorderType'), globalTextStyle.textBorderType);
- if (textBorderType != null) {
- textStyle.lineDash = textBorderType;
- }
- var textBorderDashOffset = retrieve2(textStyleModel.getShallow('textBorderDashOffset'), globalTextStyle.textBorderDashOffset);
- if (textBorderDashOffset != null) {
- textStyle.lineDashOffset = textBorderDashOffset;
- }
- if (!isNotNormal && opacity == null && !inRich) {
- opacity = opt && opt.defaultOpacity;
- }
- if (opacity != null) {
- textStyle.opacity = opacity;
- }
- // TODO
- if (!isNotNormal && !isAttached) {
- // Set default finally.
- if (textStyle.fill == null && opt.inheritColor) {
- textStyle.fill = opt.inheritColor;
- }
- }
- // Do not use `getFont` here, because merge should be supported, where
- // part of these properties may be changed in emphasis style, and the
- // others should remain their original value got from normal style.
- for (var i = 0; i < TEXT_PROPS_WITH_GLOBAL.length; i++) {
- var key = TEXT_PROPS_WITH_GLOBAL[i];
- var val = retrieve2(textStyleModel.getShallow(key), globalTextStyle[key]);
- if (val != null) {
- textStyle[key] = val;
- }
- }
- for (var i = 0; i < TEXT_PROPS_SELF.length; i++) {
- var key = TEXT_PROPS_SELF[i];
- var val = textStyleModel.getShallow(key);
- if (val != null) {
- textStyle[key] = val;
- }
- }
- if (textStyle.verticalAlign == null) {
- var baseline = textStyleModel.getShallow('baseline');
- if (baseline != null) {
- textStyle.verticalAlign = baseline;
- }
- }
- if (!isBlock || !opt.disableBox) {
- for (var i = 0; i < TEXT_PROPS_BOX.length; i++) {
- var key = TEXT_PROPS_BOX[i];
- var val = textStyleModel.getShallow(key);
- if (val != null) {
- textStyle[key] = val;
- }
- }
- var borderType = textStyleModel.getShallow('borderType');
- if (borderType != null) {
- textStyle.borderDash = borderType;
- }
- if ((textStyle.backgroundColor === 'auto' || textStyle.backgroundColor === 'inherit') && inheritColor) {
- if (process.env.NODE_ENV !== 'production') {
- if (textStyle.backgroundColor === 'auto') {
- deprecateReplaceLog('backgroundColor: \'auto\'', 'backgroundColor: \'inherit\'');
- }
- }
- textStyle.backgroundColor = inheritColor;
- }
- if ((textStyle.borderColor === 'auto' || textStyle.borderColor === 'inherit') && inheritColor) {
- if (process.env.NODE_ENV !== 'production') {
- if (textStyle.borderColor === 'auto') {
- deprecateReplaceLog('borderColor: \'auto\'', 'borderColor: \'inherit\'');
- }
- }
- textStyle.borderColor = inheritColor;
- }
- }
- }
- export function getFont(opt, ecModel) {
- var gTextStyleModel = ecModel && ecModel.getModel('textStyle');
- return trim([
- // FIXME in node-canvas fontWeight is before fontStyle
- opt.fontStyle || gTextStyleModel && gTextStyleModel.getShallow('fontStyle') || '', opt.fontWeight || gTextStyleModel && gTextStyleModel.getShallow('fontWeight') || '', (opt.fontSize || gTextStyleModel && gTextStyleModel.getShallow('fontSize') || 12) + 'px', opt.fontFamily || gTextStyleModel && gTextStyleModel.getShallow('fontFamily') || 'sans-serif'].join(' '));
- }
- export var labelInner = makeInner();
- export function setLabelValueAnimation(label, labelStatesModels, value, getDefaultText) {
- if (!label) {
- return;
- }
- var obj = labelInner(label);
- obj.prevValue = obj.value;
- obj.value = value;
- var normalLabelModel = labelStatesModels.normal;
- obj.valueAnimation = normalLabelModel.get('valueAnimation');
- if (obj.valueAnimation) {
- obj.precision = normalLabelModel.get('precision');
- obj.defaultInterpolatedText = getDefaultText;
- obj.statesModels = labelStatesModels;
- }
- }
- export function animateLabelValue(textEl, dataIndex, data, animatableModel, labelFetcher) {
- var labelInnerStore = labelInner(textEl);
- if (!labelInnerStore.valueAnimation || labelInnerStore.prevValue === labelInnerStore.value) {
- // Value not changed, no new label animation
- return;
- }
- var defaultInterpolatedText = labelInnerStore.defaultInterpolatedText;
- // Consider the case that being animating, do not use the `obj.value`,
- // Otherwise it will jump to the `obj.value` when this new animation started.
- var currValue = retrieve2(labelInnerStore.interpolatedValue, labelInnerStore.prevValue);
- var targetValue = labelInnerStore.value;
- function during(percent) {
- var interpolated = interpolateRawValues(data, labelInnerStore.precision, currValue, targetValue, percent);
- labelInnerStore.interpolatedValue = percent === 1 ? null : interpolated;
- var labelText = getLabelText({
- labelDataIndex: dataIndex,
- labelFetcher: labelFetcher,
- defaultText: defaultInterpolatedText ? defaultInterpolatedText(interpolated) : interpolated + ''
- }, labelInnerStore.statesModels, interpolated);
- setLabelText(textEl, labelText);
- }
- textEl.percent = 0;
- (labelInnerStore.prevValue == null ? initProps : updateProps)(textEl, {
- // percent is used to prevent animation from being aborted #15916
- percent: 1
- }, animatableModel, dataIndex, null, during);
- }
|