plantuml/src/net/sourceforge/plantuml/svek/GeneralImageBuilder.java

792 lines
31 KiB
Java
Raw Normal View History

2011-08-08 17:48:29 +00:00
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
2022-03-07 19:33:46 +00:00
* (C) Copyright 2009-2023, Arnaud Roques
2011-08-08 17:48:29 +00:00
*
2016-03-06 16:47:34 +00:00
* Project Info: http://plantuml.com
2011-08-08 17:48:29 +00:00
*
2017-03-15 19:13:31 +00:00
* If you like this project or if you find it useful, you can support us at:
*
* http://plantuml.com/patreon (only 1$ per month!)
* http://plantuml.com/paypal
*
2011-08-08 17:48:29 +00:00
* This file is part of PlantUML.
*
* PlantUML is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* PlantUML distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
2013-12-10 19:36:50 +00:00
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
2011-08-08 17:48:29 +00:00
* License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA.
*
*
* Original Author: Arnaud Roques
* Contribution : Hisashi Miyashita
2020-05-18 20:01:37 +00:00
* Contribution : Serge Wenger
2011-08-08 17:48:29 +00:00
*
*
*/
package net.sourceforge.plantuml.svek;
2019-09-22 17:20:16 +00:00
import java.awt.geom.Rectangle2D;
2011-08-08 17:48:29 +00:00
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
2016-07-25 19:25:28 +00:00
import java.util.Map;
2013-12-10 19:36:50 +00:00
import java.util.regex.Matcher;
import java.util.regex.Pattern;
2011-08-08 17:48:29 +00:00
2016-05-11 21:31:47 +00:00
import net.sourceforge.plantuml.BaseFile;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.ColorParam;
2019-09-22 17:20:16 +00:00
import net.sourceforge.plantuml.Dimension2DDouble;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.FontParam;
2019-03-29 22:14:07 +00:00
import net.sourceforge.plantuml.Guillemet;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.ISkinParam;
2020-06-14 20:35:42 +00:00
import net.sourceforge.plantuml.LineParam;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.Log;
import net.sourceforge.plantuml.OptionFlags;
import net.sourceforge.plantuml.Pragma;
import net.sourceforge.plantuml.SkinParamForecolored;
import net.sourceforge.plantuml.SkinParamSameClassWidth;
2018-03-09 21:37:34 +00:00
import net.sourceforge.plantuml.SkinParamUtils;
2015-05-31 18:56:03 +00:00
import net.sourceforge.plantuml.StringUtils;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.UmlDiagramType;
2020-12-01 21:39:27 +00:00
import net.sourceforge.plantuml.UseStyle;
2019-02-09 21:56:24 +00:00
import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend;
2022-03-01 18:11:51 +00:00
import net.sourceforge.plantuml.awt.geom.Dimension2D;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.core.UmlSource;
import net.sourceforge.plantuml.cucadiagram.Display;
2021-11-09 17:47:19 +00:00
import net.sourceforge.plantuml.cucadiagram.DisplayPositioned;
2015-04-07 18:18:37 +00:00
import net.sourceforge.plantuml.cucadiagram.EntityPortion;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.cucadiagram.EntityPosition;
2019-09-22 17:20:16 +00:00
import net.sourceforge.plantuml.cucadiagram.GroupRoot;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.cucadiagram.GroupType;
import net.sourceforge.plantuml.cucadiagram.IEntity;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.cucadiagram.IGroup;
import net.sourceforge.plantuml.cucadiagram.ILeaf;
import net.sourceforge.plantuml.cucadiagram.LeafType;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.cucadiagram.Link;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.cucadiagram.PortionShower;
import net.sourceforge.plantuml.cucadiagram.Stereotype;
import net.sourceforge.plantuml.cucadiagram.UnparsableGraphvizException;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.cucadiagram.dot.DotData;
2016-07-25 19:25:28 +00:00
import net.sourceforge.plantuml.cucadiagram.dot.ExeState;
2020-09-19 15:43:24 +00:00
import net.sourceforge.plantuml.cucadiagram.dot.GraphvizUtils;
2015-04-07 18:18:37 +00:00
import net.sourceforge.plantuml.cucadiagram.dot.GraphvizVersion;
import net.sourceforge.plantuml.cucadiagram.dot.Neighborhood;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.cucadiagram.entity.EntityFactory;
2018-05-21 19:15:19 +00:00
import net.sourceforge.plantuml.descdiagram.EntityImageDesignedDomain;
import net.sourceforge.plantuml.descdiagram.EntityImageDomain;
import net.sourceforge.plantuml.descdiagram.EntityImageMachine;
import net.sourceforge.plantuml.descdiagram.EntityImageRequirement;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.GraphicStrings;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
2019-09-22 17:20:16 +00:00
import net.sourceforge.plantuml.graphic.InnerStrategy;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.TextBlock;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.graphic.TextBlockEmpty;
2011-08-08 17:48:29 +00:00
import net.sourceforge.plantuml.graphic.TextBlockUtils;
2015-04-07 18:18:37 +00:00
import net.sourceforge.plantuml.graphic.USymbol;
2021-02-02 10:12:15 +00:00
import net.sourceforge.plantuml.graphic.USymbolHexagon;
2015-04-07 18:18:37 +00:00
import net.sourceforge.plantuml.graphic.USymbolInterface;
2022-02-24 18:18:19 +00:00
import net.sourceforge.plantuml.graphic.USymbols;
2020-06-07 10:03:18 +00:00
import net.sourceforge.plantuml.style.PName;
2019-08-26 17:07:21 +00:00
import net.sourceforge.plantuml.style.SName;
import net.sourceforge.plantuml.style.Style;
2022-05-04 17:52:00 +00:00
import net.sourceforge.plantuml.style.StyleSignature;
2022-03-01 18:11:51 +00:00
import net.sourceforge.plantuml.style.StyleSignatureBasic;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageActivity;
import net.sourceforge.plantuml.svek.image.EntityImageArcCircle;
import net.sourceforge.plantuml.svek.image.EntityImageAssociation;
import net.sourceforge.plantuml.svek.image.EntityImageAssociationPoint;
import net.sourceforge.plantuml.svek.image.EntityImageBranch;
import net.sourceforge.plantuml.svek.image.EntityImageCircleEnd;
import net.sourceforge.plantuml.svek.image.EntityImageCircleStart;
import net.sourceforge.plantuml.svek.image.EntityImageClass;
2020-05-18 20:01:37 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageDeepHistory;
2015-07-11 09:32:49 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageDescription;
2015-08-05 20:17:01 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageEmptyPackage;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageGroup;
2022-03-01 18:11:51 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageJson;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageLollipopInterface;
2015-04-07 18:18:37 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageLollipopInterfaceEye1;
import net.sourceforge.plantuml.svek.image.EntityImageLollipopInterfaceEye2;
2020-04-05 15:13:04 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageMap;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageNote;
import net.sourceforge.plantuml.svek.image.EntityImageObject;
import net.sourceforge.plantuml.svek.image.EntityImagePort;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImagePseudoState;
import net.sourceforge.plantuml.svek.image.EntityImageState;
2015-04-07 18:18:37 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageState2;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageStateBorder;
import net.sourceforge.plantuml.svek.image.EntityImageStateEmptyDescription;
import net.sourceforge.plantuml.svek.image.EntityImageSynchroBar;
2015-05-31 18:56:03 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageTips;
2013-12-10 19:36:50 +00:00
import net.sourceforge.plantuml.svek.image.EntityImageUseCase;
2019-09-22 17:20:16 +00:00
import net.sourceforge.plantuml.ugraphic.MinMax;
import net.sourceforge.plantuml.ugraphic.UGraphic;
2020-06-14 20:35:42 +00:00
import net.sourceforge.plantuml.ugraphic.UStroke;
2020-03-18 10:50:02 +00:00
import net.sourceforge.plantuml.ugraphic.color.HColor;
2011-08-08 17:48:29 +00:00
2018-08-26 12:09:50 +00:00
public final class GeneralImageBuilder {
2011-08-08 17:48:29 +00:00
2019-08-26 17:07:21 +00:00
public static IEntityImage createEntityImageBlock(ILeaf leaf, ISkinParam skinParam,
boolean isHideEmptyDescriptionForState, PortionShower portionShower, Bibliotekon bibliotekon,
GraphvizVersion graphvizVersion, UmlDiagramType umlDiagramType, Collection<Link> links) {
2021-04-02 17:26:59 +00:00
final IEntityImage result = createEntityImageBlockInternal(leaf, skinParam, isHideEmptyDescriptionForState,
portionShower, bibliotekon, graphvizVersion, umlDiagramType, links);
// System.err.println("leaf " + leaf + " " + result.getClass());
return result;
}
private static IEntityImage createEntityImageBlockInternal(ILeaf leaf, ISkinParam skinParam,
boolean isHideEmptyDescriptionForState, PortionShower portionShower, Bibliotekon bibliotekon,
GraphvizVersion graphvizVersion, UmlDiagramType umlDiagramType, Collection<Link> links) {
2019-08-26 17:07:21 +00:00
if (leaf.isRemoved()) {
throw new IllegalStateException();
}
if (leaf.getLeafType().isLikeClass()) {
final EntityImageClass entityImageClass = new EntityImageClass(graphvizVersion, (ILeaf) leaf, skinParam,
portionShower);
final Neighborhood neighborhood = leaf.getNeighborhood();
if (neighborhood != null) {
return new EntityImageProtected(entityImageClass, 20, neighborhood, bibliotekon);
}
return entityImageClass;
}
if (leaf.getLeafType() == LeafType.NOTE) {
2021-09-19 17:05:24 +00:00
return new EntityImageNote(leaf, skinParam, umlDiagramType);
2019-08-26 17:07:21 +00:00
}
if (leaf.getLeafType() == LeafType.ACTIVITY) {
return new EntityImageActivity(leaf, skinParam, bibliotekon);
}
if ((leaf.getLeafType() == LeafType.PORT) || (leaf.getLeafType() == LeafType.PORTIN)
|| (leaf.getLeafType() == LeafType.PORTOUT)) {
final Cluster parent = bibliotekon.getCluster(leaf.getParentContainer());
2022-02-10 18:16:18 +00:00
return new EntityImagePort(leaf, skinParam, parent, bibliotekon, umlDiagramType.getStyleName());
}
2019-08-26 17:07:21 +00:00
if (leaf.getLeafType() == LeafType.STATE) {
if (leaf.getEntityPosition() != EntityPosition.NORMAL) {
final Cluster stateParent = bibliotekon.getCluster(leaf.getParentContainer());
2022-02-10 18:16:18 +00:00
return new EntityImageStateBorder(leaf, skinParam, stateParent, bibliotekon,
umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
2020-12-14 18:31:06 +00:00
if (isHideEmptyDescriptionForState && leaf.getBodier().getRawBody().size() == 0) {
2019-08-26 17:07:21 +00:00
return new EntityImageStateEmptyDescription(leaf, skinParam);
}
if (leaf.getStereotype() != null
&& "<<sdlreceive>>".equals(leaf.getStereotype().getLabel(Guillemet.DOUBLE_COMPARATOR))) {
2022-02-12 17:27:51 +00:00
return new EntityImageState2(leaf, skinParam, umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
return new EntityImageState(leaf, skinParam);
}
if (leaf.getLeafType() == LeafType.CIRCLE_START) {
ColorParam param = ColorParam.activityStart;
if (umlDiagramType == UmlDiagramType.STATE) {
param = ColorParam.stateStart;
}
return new EntityImageCircleStart(leaf, skinParam, param);
}
if (leaf.getLeafType() == LeafType.CIRCLE_END) {
ColorParam param = ColorParam.activityEnd;
if (umlDiagramType == UmlDiagramType.STATE) {
param = ColorParam.stateEnd;
}
return new EntityImageCircleEnd(leaf, skinParam, param);
}
if (leaf.getLeafType() == LeafType.BRANCH || leaf.getLeafType() == LeafType.STATE_CHOICE) {
return new EntityImageBranch(leaf, skinParam);
}
if (leaf.getLeafType() == LeafType.LOLLIPOP_FULL || leaf.getLeafType() == LeafType.LOLLIPOP_HALF) {
2022-02-10 18:16:18 +00:00
return new EntityImageLollipopInterface(leaf, skinParam, umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
if (leaf.getLeafType() == LeafType.CIRCLE) {
2020-06-14 20:35:42 +00:00
return new EntityImageDescription(leaf, skinParam, portionShower, links, umlDiagramType.getStyleName(),
2021-03-07 12:23:24 +00:00
bibliotekon);
2019-08-26 17:07:21 +00:00
}
if (leaf.getLeafType() == LeafType.DESCRIPTION) {
if (OptionFlags.USE_INTERFACE_EYE1 && leaf.getUSymbol() instanceof USymbolInterface) {
return new EntityImageLollipopInterfaceEye1(leaf, skinParam, bibliotekon);
} else if (OptionFlags.USE_INTERFACE_EYE2 && leaf.getUSymbol() instanceof USymbolInterface) {
return new EntityImageLollipopInterfaceEye2(leaf, skinParam, portionShower);
} else {
2020-06-14 20:35:42 +00:00
return new EntityImageDescription(leaf, skinParam, portionShower, links, umlDiagramType.getStyleName(),
2021-03-07 12:23:24 +00:00
bibliotekon);
2019-08-26 17:07:21 +00:00
}
}
if (leaf.getLeafType() == LeafType.USECASE) {
return new EntityImageUseCase(leaf, skinParam, portionShower);
}
2020-10-12 20:56:58 +00:00
if (leaf.getLeafType() == LeafType.USECASE_BUSINESS) {
return new EntityImageUseCase(leaf, skinParam, portionShower);
}
2019-08-26 17:07:21 +00:00
// if (leaf.getEntityType() == LeafType.CIRCLE_INTERFACE) {
// return new EntityImageCircleInterface(leaf, skinParam);
// }
if (leaf.getLeafType() == LeafType.OBJECT) {
return new EntityImageObject(leaf, skinParam, portionShower);
}
2020-04-05 15:13:04 +00:00
if (leaf.getLeafType() == LeafType.MAP) {
return new EntityImageMap(leaf, skinParam, portionShower);
}
2022-03-01 18:11:51 +00:00
if (leaf.getLeafType() == LeafType.JSON) {
return new EntityImageJson(leaf, skinParam, portionShower);
}
2019-08-26 17:07:21 +00:00
if (leaf.getLeafType() == LeafType.SYNCHRO_BAR || leaf.getLeafType() == LeafType.STATE_FORK_JOIN) {
2021-11-21 11:09:15 +00:00
return new EntityImageSynchroBar(leaf, skinParam, umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
if (leaf.getLeafType() == LeafType.ARC_CIRCLE) {
return new EntityImageArcCircle(leaf, skinParam);
}
if (leaf.getLeafType() == LeafType.POINT_FOR_ASSOCIATION) {
return new EntityImageAssociationPoint(leaf, skinParam);
}
if (leaf.isGroup()) {
return new EntityImageGroup(leaf, skinParam);
}
if (leaf.getLeafType() == LeafType.EMPTY_PACKAGE) {
if (leaf.getUSymbol() != null) {
2020-03-18 10:50:02 +00:00
final HColor black = SkinParamUtils.getColor(skinParam, leaf.getStereotype(),
2020-02-18 21:24:31 +00:00
leaf.getUSymbol().getColorParamBorder());
2019-08-26 17:07:21 +00:00
return new EntityImageDescription(leaf, new SkinParamForecolored(skinParam, black), portionShower,
2021-03-07 12:23:24 +00:00
links, umlDiagramType.getStyleName(), bibliotekon);
2019-08-26 17:07:21 +00:00
}
return new EntityImageEmptyPackage(leaf, skinParam, portionShower, umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
if (leaf.getLeafType() == LeafType.ASSOCIATION) {
2022-02-12 17:27:51 +00:00
return new EntityImageAssociation(leaf, skinParam, umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
if (leaf.getLeafType() == LeafType.PSEUDO_STATE) {
2022-02-12 17:27:51 +00:00
return new EntityImagePseudoState(leaf, skinParam, umlDiagramType.getStyleName());
2019-08-26 17:07:21 +00:00
}
2020-05-18 20:01:37 +00:00
if (leaf.getLeafType() == LeafType.DEEP_HISTORY) {
2022-02-12 17:27:51 +00:00
return new EntityImageDeepHistory(leaf, skinParam, umlDiagramType.getStyleName());
2020-05-18 20:01:37 +00:00
}
2020-05-30 15:20:23 +00:00
2019-08-26 17:07:21 +00:00
if (leaf.getLeafType() == LeafType.TIPS) {
2021-09-19 17:05:24 +00:00
return new EntityImageTips(leaf, skinParam, bibliotekon, umlDiagramType);
2019-08-26 17:07:21 +00:00
}
// TODO Clean
if (leaf.getLeafType() == LeafType.DOMAIN && leaf.getStereotype() != null
&& leaf.getStereotype().isMachineOrSpecification()) {
return new EntityImageMachine(leaf, skinParam);
} else if (leaf.getLeafType() == LeafType.DOMAIN && leaf.getStereotype() != null
&& leaf.getStereotype().isDesignedOrSolved()) {
return new EntityImageDesignedDomain(leaf, skinParam);
} else if (leaf.getLeafType() == LeafType.REQUIREMENT) {
return new EntityImageRequirement(leaf, skinParam);
} else if (leaf.getLeafType() == LeafType.DOMAIN && leaf.getStereotype() != null
&& leaf.getStereotype().isLexicalOrGiven()) {
return new EntityImageDomain(leaf, skinParam, 'X');
} else if (leaf.getLeafType() == LeafType.DOMAIN && leaf.getStereotype() != null
&& leaf.getStereotype().isCausal()) {
return new EntityImageDomain(leaf, skinParam, 'C');
} else if (leaf.getLeafType() == LeafType.DOMAIN && leaf.getStereotype() != null
&& leaf.getStereotype().isBiddableOrUncertain()) {
return new EntityImageDomain(leaf, skinParam, 'B');
} else if (leaf.getLeafType() == LeafType.DOMAIN) {
return new EntityImageDomain(leaf, skinParam, 'P');
} else
throw new UnsupportedOperationException(leaf.getLeafType().toString());
}
2020-06-14 20:35:42 +00:00
public static UStroke getForcedStroke(Stereotype stereotype, ISkinParam skinParam) {
UStroke stroke = skinParam.getThickness(LineParam.packageBorder, stereotype);
2022-03-07 19:33:46 +00:00
if (stroke == null)
2020-06-14 20:35:42 +00:00
stroke = new UStroke(1.5);
2022-03-07 19:33:46 +00:00
2020-06-14 20:35:42 +00:00
return stroke;
}
2011-08-08 17:48:29 +00:00
private final DotData dotData;
2013-12-10 19:36:50 +00:00
private final EntityFactory entityFactory;
private final UmlSource source;
private final Pragma pragma;
2019-09-22 17:20:16 +00:00
private final boolean strictUmlStyle;
2019-12-10 21:45:49 +00:00
private Map<String, Double> maxX;
2011-08-08 17:48:29 +00:00
2016-08-25 20:45:37 +00:00
private final StringBounder stringBounder;
2020-02-18 21:24:31 +00:00
private final boolean mergeIntricated;
private final SName styleName;
2011-08-08 17:48:29 +00:00
2020-02-18 21:24:31 +00:00
public GeneralImageBuilder(boolean mergeIntricated, DotData dotData, EntityFactory entityFactory, UmlSource source,
Pragma pragma, StringBounder stringBounder, SName styleName) {
2011-08-08 17:48:29 +00:00
this.dotData = dotData;
this.styleName = styleName;
2013-12-10 19:36:50 +00:00
this.entityFactory = entityFactory;
this.source = source;
this.pragma = pragma;
2016-08-25 20:45:37 +00:00
this.stringBounder = stringBounder;
2019-09-22 17:20:16 +00:00
this.strictUmlStyle = dotData.getSkinParam().strictUmlStyle();
2020-02-18 21:24:31 +00:00
this.mergeIntricated = mergeIntricated;
2011-08-08 17:48:29 +00:00
}
2021-03-07 12:23:24 +00:00
final public StyleSignature getDefaultStyleDefinitionArrow(Stereotype stereotype) {
2022-03-01 18:11:51 +00:00
StyleSignature result = StyleSignatureBasic.of(SName.root, SName.element, styleName, SName.arrow);
2022-03-07 19:33:46 +00:00
if (stereotype != null)
2022-03-01 18:11:51 +00:00
result = result.withTOBECHANGED(stereotype);
2022-03-07 19:33:46 +00:00
2021-03-07 12:23:24 +00:00
return result;
2019-08-26 17:07:21 +00:00
}
2019-09-22 17:20:16 +00:00
private boolean isOpalisable(IEntity entity) {
2022-03-07 19:33:46 +00:00
if (strictUmlStyle)
2019-09-22 17:20:16 +00:00
return false;
2022-03-07 19:33:46 +00:00
2019-09-22 17:20:16 +00:00
return entity.isGroup() == false && entity.getLeafType() == LeafType.NOTE && onlyOneLink(entity);
}
static class EntityImageSimpleEmpty implements IEntityImage {
private final HColor backColor;
EntityImageSimpleEmpty(HColor backColor) {
this.backColor = backColor;
}
2019-09-22 17:20:16 +00:00
public boolean isHidden() {
return false;
}
2020-03-18 10:50:02 +00:00
public HColor getBackcolor() {
return backColor;
2019-09-22 17:20:16 +00:00
}
public Dimension2D calculateDimension(StringBounder stringBounder) {
return new Dimension2DDouble(10, 10);
}
public MinMax getMinMax(StringBounder stringBounder) {
return MinMax.fromDim(calculateDimension(stringBounder));
}
public Rectangle2D getInnerPosition(String member, StringBounder stringBounder, InnerStrategy strategy) {
return null;
}
public void drawU(UGraphic ug) {
}
public ShapeType getShapeType() {
return ShapeType.RECTANGLE;
}
public Margins getShield(StringBounder stringBounder) {
return Margins.NONE;
}
public double getOverscanX(StringBounder stringBounder) {
return 0;
}
}
2020-06-07 10:03:18 +00:00
// Duplicate SvekResult / GeneralImageBuilder
private HColor getBackcolor() {
2020-12-01 21:39:27 +00:00
if (UseStyle.useBetaStyle()) {
2022-03-01 18:11:51 +00:00
final Style style = StyleSignatureBasic.of(SName.root, SName.document)
2020-06-07 10:03:18 +00:00
.getMergedStyle(dotData.getSkinParam().getCurrentStyleBuilder());
2021-05-06 21:23:05 +00:00
return style.value(PName.BackGroundColor).asColor(dotData.getSkinParam().getThemeStyle(),
dotData.getSkinParam().getIHtmlColorSet());
2020-06-07 10:03:18 +00:00
}
return dotData.getSkinParam().getBackgroundColor();
2020-06-07 10:03:18 +00:00
}
2020-06-14 20:35:42 +00:00
2016-07-25 19:25:28 +00:00
public IEntityImage buildImage(BaseFile basefile, String dotStrings[]) {
2022-03-07 19:33:46 +00:00
if (dotData.isDegeneratedWithFewEntities(0))
return new EntityImageSimpleEmpty(dotData.getSkinParam().getBackgroundColor());
2022-03-07 19:33:46 +00:00
2019-09-22 17:20:16 +00:00
if (dotData.isDegeneratedWithFewEntities(1) && dotData.getUmlDiagramType() != UmlDiagramType.STATE) {
final ILeaf single = dotData.getLeafs().iterator().next();
final IGroup group = single.getParentContainer();
2021-02-02 10:12:15 +00:00
if (group instanceof GroupRoot && single.getUSymbol() instanceof USymbolHexagon == false) {
2020-06-07 10:03:18 +00:00
final IEntityImage tmp = GeneralImageBuilder.createEntityImageBlock(single, dotData.getSkinParam(),
2019-09-22 17:20:16 +00:00
dotData.isHideEmptyDescriptionForState(), dotData, null, null, dotData.getUmlDiagramType(),
2020-06-07 10:03:18 +00:00
dotData.getLinks());
return new EntityImageDegenerated(tmp, getBackcolor());
2019-09-22 17:20:16 +00:00
}
}
2015-04-07 18:18:37 +00:00
dotData.removeIrrelevantSametail();
2016-07-25 19:25:28 +00:00
final DotStringFactory dotStringFactory = new DotStringFactory(stringBounder, dotData);
2011-08-08 17:48:29 +00:00
2016-07-25 19:25:28 +00:00
printGroups(dotStringFactory, dotData.getRootGroup());
printEntities(dotStringFactory, getUnpackagedEntities());
2011-08-08 17:48:29 +00:00
for (Link link : dotData.getLinks()) {
2022-03-07 19:33:46 +00:00
if (link.isRemoved())
2013-12-10 19:36:50 +00:00
continue;
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
try {
final ISkinParam skinParam = dotData.getSkinParam();
2021-04-20 20:19:49 +00:00
final FontConfiguration labelFont = getFontForLink(link, skinParam);
2013-12-10 19:36:50 +00:00
2021-04-20 20:19:49 +00:00
final SvekLine line = new SvekLine(link, dotStringFactory.getColorSequence(), skinParam, stringBounder,
labelFont, dotStringFactory.getBibliotekon(), pragma);
2013-12-10 19:36:50 +00:00
2016-07-25 19:25:28 +00:00
dotStringFactory.getBibliotekon().addLine(line);
2013-12-10 19:36:50 +00:00
2019-09-22 17:20:16 +00:00
if (isOpalisable(link.getEntity1())) {
2021-02-02 10:12:15 +00:00
final SvekNode node = dotStringFactory.getBibliotekon().getNode(link.getEntity1());
final SvekNode other = dotStringFactory.getBibliotekon().getNode(link.getEntity2());
2016-01-09 12:15:40 +00:00
if (other != null) {
2020-02-18 21:24:31 +00:00
((EntityImageNote) node.getImage()).setOpaleLine(line, node, other);
2016-01-09 12:15:40 +00:00
line.setOpale(true);
}
2019-09-22 17:20:16 +00:00
} else if (isOpalisable(link.getEntity2())) {
2021-02-02 10:12:15 +00:00
final SvekNode node = dotStringFactory.getBibliotekon().getNode(link.getEntity2());
final SvekNode other = dotStringFactory.getBibliotekon().getNode(link.getEntity1());
2016-01-09 12:15:40 +00:00
if (other != null) {
2020-02-18 21:24:31 +00:00
((EntityImageNote) node.getImage()).setOpaleLine(line, node, other);
2016-01-09 12:15:40 +00:00
line.setOpale(true);
}
2013-12-10 19:36:50 +00:00
}
} catch (IllegalStateException e) {
e.printStackTrace();
2011-09-08 10:42:27 +00:00
}
2011-08-08 17:48:29 +00:00
}
2022-03-07 19:33:46 +00:00
if (dotStringFactory.illegalDotExe())
2011-08-08 17:48:29 +00:00
return error(dotStringFactory.getDotExe());
2022-03-07 19:33:46 +00:00
if (basefile == null && isSvekTrace())
2022-03-19 12:48:23 +00:00
basefile = new BaseFile(null);
2019-09-22 17:20:16 +00:00
2015-04-07 18:18:37 +00:00
final String svg;
try {
2016-05-11 21:31:47 +00:00
svg = dotStringFactory.getSvg(basefile, dotStrings);
2015-04-07 18:18:37 +00:00
} catch (IOException e) {
2020-12-14 18:31:06 +00:00
return new GraphvizCrash(source.getPlainString(), GraphvizUtils.graphviz244onWindows(), e);
2015-04-07 18:18:37 +00:00
}
2022-03-07 19:33:46 +00:00
if (svg.length() == 0)
2020-12-14 18:31:06 +00:00
return new GraphvizCrash(source.getPlainString(), GraphvizUtils.graphviz244onWindows(),
new EmptySvgException());
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
final String graphvizVersion = extractGraphvizVersion(svg);
try {
2020-06-07 10:03:18 +00:00
dotStringFactory.solve(mergeIntricated, dotData.getEntityFactory(), svg);
final SvekResult result = new SvekResult(dotData, dotStringFactory);
2016-07-25 19:25:28 +00:00
this.maxX = dotStringFactory.getBibliotekon().getMaxX();
2013-12-10 19:36:50 +00:00
return result;
} catch (Exception e) {
Log.error("Exception " + e);
throw new UnparsableGraphvizException(e, graphvizVersion, svg, source.getPlainString());
}
}
2011-09-08 10:42:27 +00:00
2021-04-20 20:19:49 +00:00
private FontConfiguration getFontForLink(Link link, final ISkinParam skinParam) {
final FontConfiguration labelFont;
if (UseStyle.useBetaStyle()) {
final Style style = getDefaultStyleDefinitionArrow(link.getStereotype())
.getMergedStyle(link.getStyleBuilder());
2021-05-06 21:23:05 +00:00
labelFont = style.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
2021-04-20 20:19:49 +00:00
} else {
2022-03-19 12:48:23 +00:00
labelFont = FontConfiguration.create(skinParam, FontParam.ARROW, null);
2021-04-20 20:19:49 +00:00
}
return labelFont;
}
2013-12-10 19:36:50 +00:00
private boolean isSvekTrace() {
final String value = pragma.getValue("svek_trace");
return "true".equalsIgnoreCase(value) || "on".equalsIgnoreCase(value);
}
private String extractGraphvizVersion(String svg) {
final Pattern pGraph = Pattern.compile("(?mi)!-- generated by graphviz(.*)");
final Matcher mGraph = pGraph.matcher(svg);
2022-03-07 19:33:46 +00:00
if (mGraph.find())
2015-05-31 18:56:03 +00:00
return StringUtils.trin(mGraph.group(1));
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
return null;
2011-09-08 10:42:27 +00:00
}
2011-08-08 17:48:29 +00:00
2011-09-08 10:42:27 +00:00
private boolean onlyOneLink(IEntity ent) {
2013-12-10 19:36:50 +00:00
int nb = 0;
for (Link link : dotData.getLinks()) {
2022-03-07 19:33:46 +00:00
if (link.isInvis())
2013-12-10 19:36:50 +00:00
continue;
2022-03-07 19:33:46 +00:00
if (link.contains(ent))
2013-12-10 19:36:50 +00:00
nb++;
2022-03-07 19:33:46 +00:00
if (nb > 1)
2013-12-10 19:36:50 +00:00
return false;
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
}
return nb == 1;
2011-08-08 17:48:29 +00:00
}
private IEntityImage error(File dotExe) {
2021-05-14 08:42:57 +00:00
final List<String> msg = new ArrayList<>();
2011-08-08 17:48:29 +00:00
msg.add("Dot Executable: " + dotExe);
2016-07-25 19:25:28 +00:00
final ExeState exeState = ExeState.checkFile(dotExe);
msg.add(exeState.getTextMessage());
2011-08-08 17:48:29 +00:00
msg.add("Cannot find Graphviz. You should try");
msg.add(" ");
msg.add("@startuml");
msg.add("testdot");
msg.add("@enduml");
msg.add(" ");
msg.add(" or ");
msg.add(" ");
msg.add("java -jar plantuml.jar -testdot");
2013-12-10 19:36:50 +00:00
msg.add(" ");
2016-11-18 21:12:09 +00:00
return GraphicStrings.createForError(msg, false);
2011-08-08 17:48:29 +00:00
}
2016-07-25 19:25:28 +00:00
private void printEntities(DotStringFactory dotStringFactory, Collection<ILeaf> entities2) {
2013-12-10 19:36:50 +00:00
for (ILeaf ent : entities2) {
2022-03-07 19:33:46 +00:00
if (ent.isRemoved())
2013-12-10 19:36:50 +00:00
continue;
2022-03-07 19:33:46 +00:00
2016-07-25 19:25:28 +00:00
printEntity(dotStringFactory, ent);
2011-08-08 17:48:29 +00:00
}
}
2016-07-25 19:25:28 +00:00
private void printEntity(DotStringFactory dotStringFactory, ILeaf ent) {
2022-03-07 19:33:46 +00:00
if (ent.isRemoved())
2013-12-10 19:36:50 +00:00
throw new IllegalStateException();
2022-03-07 19:33:46 +00:00
2016-07-25 19:25:28 +00:00
final IEntityImage image = printEntityInternal(dotStringFactory, ent);
2021-03-07 12:23:24 +00:00
final SvekNode node = dotStringFactory.getBibliotekon().createNode(ent, image,
dotStringFactory.getColorSequence(), stringBounder);
2020-02-18 21:24:31 +00:00
dotStringFactory.addNode(node);
2013-12-10 19:36:50 +00:00
}
2016-07-25 19:25:28 +00:00
private IEntityImage printEntityInternal(DotStringFactory dotStringFactory, ILeaf ent) {
2022-03-07 19:33:46 +00:00
if (ent.isRemoved())
2013-12-10 19:36:50 +00:00
throw new IllegalStateException();
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
if (ent.getSvekImage() == null) {
ISkinParam skinParam = dotData.getSkinParam();
2016-03-06 16:47:34 +00:00
if (skinParam.sameClassWidth()) {
2016-07-25 19:25:28 +00:00
final double width = getMaxWidth(dotStringFactory);
2016-03-06 16:47:34 +00:00
skinParam = new SkinParamSameClassWidth(skinParam, width);
2013-12-10 19:36:50 +00:00
}
return createEntityImageBlock(ent, skinParam, dotData.isHideEmptyDescriptionForState(), dotData,
2016-07-25 19:25:28 +00:00
dotStringFactory.getBibliotekon(), dotStringFactory.getGraphvizVersion(),
2017-05-10 19:51:15 +00:00
dotData.getUmlDiagramType(), dotData.getLinks());
2013-12-10 19:36:50 +00:00
}
return ent.getSvekImage();
}
2016-07-25 19:25:28 +00:00
private double getMaxWidth(DotStringFactory dotStringFactory) {
2013-12-10 19:36:50 +00:00
double result = 0;
for (ILeaf ent : dotData.getLeafs()) {
2022-03-07 19:33:46 +00:00
if (ent.getLeafType().isLikeClass() == false)
2013-12-10 19:36:50 +00:00
continue;
2022-03-07 19:33:46 +00:00
2015-04-07 18:18:37 +00:00
final IEntityImage im = new EntityImageClass(dotStringFactory.getGraphvizVersion(), ent,
dotData.getSkinParam(), dotData);
2013-12-10 19:36:50 +00:00
final double w = im.calculateDimension(stringBounder).getWidth();
2022-03-07 19:33:46 +00:00
if (w > result)
2013-12-10 19:36:50 +00:00
result = w;
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
}
return result;
2011-08-08 17:48:29 +00:00
}
2013-12-10 19:36:50 +00:00
private Collection<ILeaf> getUnpackagedEntities() {
2021-05-14 08:42:57 +00:00
final List<ILeaf> result = new ArrayList<>();
2022-03-07 19:33:46 +00:00
for (ILeaf ent : dotData.getLeafs())
if (dotData.getTopParent() == ent.getParentContainer())
2011-08-08 17:48:29 +00:00
result.add(ent);
2022-03-07 19:33:46 +00:00
2011-08-08 17:48:29 +00:00
return result;
}
2016-07-25 19:25:28 +00:00
private void printGroups(DotStringFactory dotStringFactory, IGroup parent) {
2020-02-18 21:24:31 +00:00
final Collection<IGroup> groups = dotData.getGroupHierarchy().getChildrenGroups(parent);
for (IGroup g : groups) {
2022-03-07 19:33:46 +00:00
if (g.isRemoved())
2013-12-10 19:36:50 +00:00
continue;
2022-03-07 19:33:46 +00:00
2013-12-10 19:36:50 +00:00
if (dotData.isEmpty(g) && g.getGroupType() == GroupType.PACKAGE) {
2020-02-18 21:24:31 +00:00
final ISkinParam skinParam = dotData.getSkinParam();
2019-12-10 21:45:49 +00:00
entityFactory.thisIsGoingToBeALeaf(g.getIdent());
2020-02-18 21:24:31 +00:00
final ILeaf folder = entityFactory.createLeafForEmptyGroup(g, skinParam);
2016-07-25 19:25:28 +00:00
printEntity(dotStringFactory, folder);
2011-08-08 17:48:29 +00:00
} else {
2016-07-25 19:25:28 +00:00
printGroup(dotStringFactory, g);
2011-08-08 17:48:29 +00:00
}
}
}
2016-07-25 19:25:28 +00:00
private void printGroup(DotStringFactory dotStringFactory, IGroup g) {
2022-03-07 19:33:46 +00:00
if (g.getGroupType() == GroupType.CONCURRENT_STATE)
2011-08-08 17:48:29 +00:00
return;
2022-03-07 19:33:46 +00:00
2020-02-18 21:24:31 +00:00
if (mergeIntricated) {
final IGroup intricated = dotData.getEntityFactory().isIntricated(g);
if (intricated != null) {
printGroup(dotStringFactory, intricated);
return;
}
}
2013-12-10 19:36:50 +00:00
int titleAndAttributeWidth = 0;
int titleAndAttributeHeight = 0;
final TextBlock title = getTitleBlock(g);
final TextBlock stereo = getStereoBlock(g);
final TextBlock stereoAndTitle = TextBlockUtils.mergeTB(stereo, title, HorizontalAlignment.CENTER);
final Dimension2D dimLabel = stereoAndTitle.calculateDimension(stringBounder);
if (dimLabel.getWidth() > 0) {
2021-10-17 09:02:33 +00:00
final Dimension2D dimAttribute = stateHeader((IEntity) g, getStyleState(FontParam.STATE_ATTRIBUTE),
2020-12-14 18:31:06 +00:00
dotData.getSkinParam()).calculateDimension(stringBounder);
2013-12-10 19:36:50 +00:00
final double attributeHeight = dimAttribute.getHeight();
final double attributeWidth = dimAttribute.getWidth();
final double marginForFields = attributeHeight > 0 ? IEntityImage.MARGIN : 0;
2015-04-07 18:18:37 +00:00
final USymbol uSymbol = g.getUSymbol();
final int suppHeightBecauseOfShape = uSymbol == null ? 0 : uSymbol.suppHeightBecauseOfShape();
final int suppWidthBecauseOfShape = uSymbol == null ? 0 : uSymbol.suppWidthBecauseOfShape();
2013-12-10 19:36:50 +00:00
2015-04-07 18:18:37 +00:00
titleAndAttributeWidth = (int) Math.max(dimLabel.getWidth(), attributeWidth) + suppWidthBecauseOfShape;
2020-02-18 21:24:31 +00:00
titleAndAttributeHeight = (int) (dimLabel.getHeight() + attributeHeight + marginForFields
+ suppHeightBecauseOfShape);
2013-12-10 19:36:50 +00:00
}
2020-02-18 21:24:31 +00:00
dotStringFactory.openCluster(titleAndAttributeWidth, titleAndAttributeHeight, title, stereo, g);
2016-07-25 19:25:28 +00:00
this.printEntities(dotStringFactory, g.getLeafsDirect());
2013-12-10 19:36:50 +00:00
2016-07-25 19:25:28 +00:00
printGroups(dotStringFactory, g);
2011-08-08 17:48:29 +00:00
dotStringFactory.closeCluster();
}
2020-12-14 18:31:06 +00:00
public static TextBlock stateHeader(IEntity group, Style style, ISkinParam skinParam) {
final List<CharSequence> details = group.getBodier().getRawBody();
2022-03-07 19:33:46 +00:00
if (details.size() == 0)
2020-12-14 18:31:06 +00:00
return new TextBlockEmpty();
2022-03-07 19:33:46 +00:00
2020-12-14 18:31:06 +00:00
final FontConfiguration fontConfiguration;
2022-03-07 19:33:46 +00:00
if (style == null)
2022-03-19 12:48:23 +00:00
fontConfiguration = FontConfiguration.create(skinParam, FontParam.STATE_ATTRIBUTE, null);
2022-03-07 19:33:46 +00:00
else
2022-03-19 12:48:23 +00:00
fontConfiguration = FontConfiguration.create(skinParam, style);
2022-03-07 19:33:46 +00:00
2020-12-14 18:31:06 +00:00
Display display = null;
2022-03-07 19:33:46 +00:00
for (CharSequence s : details)
if (display == null)
2020-12-14 18:31:06 +00:00
display = Display.getWithNewlines(s.toString());
2022-03-07 19:33:46 +00:00
else
2020-12-14 18:31:06 +00:00
display = display.addAll(Display.getWithNewlines(s.toString()));
return display.create(fontConfiguration, HorizontalAlignment.LEFT, skinParam);
}
2021-10-17 09:02:33 +00:00
private Style getStyleState(FontParam fontParam) {
2020-12-01 21:39:27 +00:00
return fontParam.getStyleDefinition(SName.stateDiagram)
.getMergedStyle(dotData.getSkinParam().getCurrentStyleBuilder());
}
2013-12-10 19:36:50 +00:00
private TextBlock getTitleBlock(IGroup g) {
final Display label = g.getDisplay();
2022-03-07 19:33:46 +00:00
if (label == null)
2013-12-10 19:36:50 +00:00
return TextBlockUtils.empty(0, 0);
2022-03-07 19:33:46 +00:00
2016-01-09 12:15:40 +00:00
final ISkinParam skinParam = dotData.getSkinParam();
2022-02-24 18:18:19 +00:00
2022-05-04 17:52:00 +00:00
final SName sname = dotData.getUmlDiagramType().getStyleName();
final StyleSignatureBasic signature;
final USymbol uSymbol = g.getUSymbol();
if (g.getGroupType() == GroupType.STATE)
signature = StyleSignatureBasic.of(SName.root, SName.element, SName.stateDiagram, SName.state,
SName.header);
else if (uSymbol == USymbols.RECTANGLE)
signature = StyleSignatureBasic.of(SName.root, SName.element, sname, uSymbol.getSName(), SName.title);
else
signature = StyleSignatureBasic.of(SName.root, SName.element, sname, SName.title);
final Style style = signature //
.withTOBECHANGED(g.getStereotype()) //
.with(g.getStereostyles()) //
.getMergedStyle(skinParam.getCurrentStyleBuilder());
final FontConfiguration fontConfiguration = style.getFontConfiguration(skinParam.getThemeStyle(),
skinParam.getIHtmlColorSet());
2022-02-24 18:18:19 +00:00
2021-10-17 09:02:33 +00:00
final HorizontalAlignment alignment = HorizontalAlignment.CENTER;
return label.create(fontConfiguration, alignment, dotData.getSkinParam());
2011-08-08 17:48:29 +00:00
}
2021-11-09 17:47:19 +00:00
private TextBlock addLegend(TextBlock original, DisplayPositioned legend) {
2022-03-07 19:33:46 +00:00
if (legend == null || legend.isNull())
2019-02-09 21:56:24 +00:00
return original;
2022-03-07 19:33:46 +00:00
2019-03-29 22:14:07 +00:00
final TextBlock legendBlock = EntityImageLegend.create(legend.getDisplay(), dotData.getSkinParam());
2019-04-21 20:40:01 +00:00
return DecorateEntityImage.add(legendBlock, original, legend.getHorizontalAlignment(),
legend.getVerticalAlignment());
2019-02-09 21:56:24 +00:00
}
2013-12-10 19:36:50 +00:00
private TextBlock getStereoBlock(IGroup g) {
2021-11-09 17:47:19 +00:00
final DisplayPositioned legend = g.getLegend();
2019-02-09 21:56:24 +00:00
return addLegend(getStereoBlockWithoutLegend(g), legend);
}
private TextBlock getStereoBlockWithoutLegend(IGroup g) {
2016-01-09 12:15:40 +00:00
final Stereotype stereotype = g.getStereotype();
2019-03-29 22:14:07 +00:00
// final DisplayPositionned legend = g.getLegend();
2022-03-07 19:33:46 +00:00
if (stereotype == null)
2013-12-10 19:36:50 +00:00
return TextBlockUtils.empty(0, 0);
2022-03-07 19:33:46 +00:00
2019-03-01 22:16:29 +00:00
final TextBlock tmp = stereotype.getSprite(dotData.getSkinParam());
2022-03-07 19:33:46 +00:00
if (tmp != null)
2019-03-01 22:16:29 +00:00
return tmp;
2019-03-29 22:14:07 +00:00
final List<String> stereos = stereotype.getLabels(dotData.getSkinParam().guillemet());
2022-03-07 19:33:46 +00:00
if (stereos == null)
2013-12-10 19:36:50 +00:00
return TextBlockUtils.empty(0, 0);
2022-03-07 19:33:46 +00:00
2015-04-07 18:18:37 +00:00
final boolean show = dotData.showPortion(EntityPortion.STEREOTYPE, g);
2022-03-07 19:33:46 +00:00
if (show == false)
2015-04-07 18:18:37 +00:00
return TextBlockUtils.empty(0, 0);
2022-03-07 19:33:46 +00:00
if (UseStyle.useBetaStyle()) {
final Style style = Cluster
.getDefaultStyleDefinition(dotData.getUmlDiagramType().getStyleName(), g.getUSymbol())
.forStereotypeItself(g.getStereotype())
.getMergedStyle(dotData.getSkinParam().getCurrentStyleBuilder());
final FontConfiguration fontConfiguration = style.getFontConfiguration(
dotData.getSkinParam().getThemeStyle(), dotData.getSkinParam().getIHtmlColorSet());
return Display.create(stereos).create(fontConfiguration, HorizontalAlignment.CENTER,
dotData.getSkinParam());
}
2015-08-05 20:17:01 +00:00
final FontParam fontParam = FontParam.PACKAGE_STEREOTYPE;
2022-03-19 12:48:23 +00:00
return Display.create(stereos).create(FontConfiguration.create(dotData.getSkinParam(), fontParam, stereotype),
2015-08-05 20:17:01 +00:00
HorizontalAlignment.CENTER, dotData.getSkinParam());
2011-08-08 17:48:29 +00:00
}
2016-07-25 19:25:28 +00:00
public String getWarningOrError(int warningOrError) {
2022-03-07 19:33:46 +00:00
if (maxX == null)
2016-07-25 19:25:28 +00:00
return "";
2022-03-07 19:33:46 +00:00
2016-07-25 19:25:28 +00:00
final StringBuilder sb = new StringBuilder();
2022-03-07 19:33:46 +00:00
for (Map.Entry<String, Double> ent : maxX.entrySet())
2016-07-25 19:25:28 +00:00
if (ent.getValue() > warningOrError) {
sb.append(ent.getKey() + " is overpassing the width limit.");
sb.append("\n");
}
2022-03-07 19:33:46 +00:00
2016-07-25 19:25:28 +00:00
return sb.length() == 0 ? "" : sb.toString();
}
2011-08-08 17:48:29 +00:00
}