1
0
mirror of https://github.com/octoleo/plantuml.git synced 2025-01-03 07:12:29 +00:00

version 8035

This commit is contained in:
Arnaud Roques 2016-01-30 13:20:07 +01:00
parent 703a77ee1c
commit 94542f7760
89 changed files with 1138 additions and 601 deletions

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18790 $
* *
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
@ -43,6 +43,9 @@ import net.sourceforge.plantuml.command.ProtectedCommand;
import net.sourceforge.plantuml.core.Diagram; import net.sourceforge.plantuml.core.Diagram;
import net.sourceforge.plantuml.core.UmlSource; import net.sourceforge.plantuml.core.UmlSource;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
import net.sourceforge.plantuml.version.License; import net.sourceforge.plantuml.version.License;
import net.sourceforge.plantuml.version.Version; import net.sourceforge.plantuml.version.Version;
@ -87,11 +90,11 @@ public abstract class AbstractPSystem implements Diagram {
return 1; return 1;
} }
public Display getTitle() { public DisplayPositionned getTitle() {
if (source == null) { if (source == null) {
return Display.empty(); return new DisplayPositionned(Display.empty(), HorizontalAlignment.CENTER, VerticalAlignment.TOP);
} }
return source.getTitle(); return new DisplayPositionned(source.getTitle(), HorizontalAlignment.CENTER, VerticalAlignment.TOP);
} }
public String getWarningOrError() { public String getWarningOrError() {

View File

@ -0,0 +1,50 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 18790 $
*
*/
package net.sourceforge.plantuml;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
public interface Annotated {
public DisplayPositionned getTitle();
public DisplayPositionned getCaption();
public DisplayPositionned getLegend();
public DisplayPositionned getHeader();
public DisplayPositionned getFooter();
}

View File

@ -0,0 +1,134 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 18790 $
*
*/
package net.sourceforge.plantuml;
import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.graphic.TextBlockUtils;
import net.sourceforge.plantuml.svek.DecorateEntityImage;
import net.sourceforge.plantuml.svek.TextBlockBackcolored;
public class AnnotatedWorker {
private final Annotated annotated;
private final ISkinParam skinParam;
public AnnotatedWorker(Annotated annotated, ISkinParam skinParam) {
this.annotated = annotated;
this.skinParam = skinParam;
}
public TextBlockBackcolored addAdd(TextBlock result) {
result = addLegend(result);
result = addTitle(result);
result = addCaption(result);
result = addHeaderAndFooter(result);
return (TextBlockBackcolored) result;
}
private TextBlock addLegend(TextBlock original) {
if (DisplayPositionned.isNull(annotated.getLegend())) {
return original;
}
final TextBlock text = EntityImageLegend.create(annotated.getLegend().getDisplay(), getSkinParam());
return DecorateEntityImage.add(original, text, annotated.getLegend().getHorizontalAlignment(), annotated
.getLegend().getVerticalAlignment());
}
private ISkinParam getSkinParam() {
return skinParam;
}
private TextBlock addCaption(TextBlock original) {
if (DisplayPositionned.isNull(annotated.getCaption())) {
return original;
}
final TextBlock text = getCaption();
return DecorateEntityImage.addBottom(original, text, HorizontalAlignment.CENTER);
}
public TextBlock getCaption() {
if (DisplayPositionned.isNull(annotated.getCaption())) {
return TextBlockUtils.empty(0, 0);
}
return annotated
.getCaption()
.getDisplay()
.create(new FontConfiguration(getSkinParam(), FontParam.CAPTION, null), HorizontalAlignment.CENTER,
getSkinParam());
}
private TextBlock addTitle(TextBlock original) {
if (DisplayPositionned.isNull(annotated.getTitle())) {
return original;
}
final TextBlock text = annotated
.getTitle()
.getDisplay()
.create(new FontConfiguration(getSkinParam(), FontParam.TITLE, null), HorizontalAlignment.CENTER,
getSkinParam());
return DecorateEntityImage.addTop(original, text, HorizontalAlignment.CENTER);
// return new DecorateTextBlock(original, text, HorizontalAlignment.CENTER);
}
private TextBlock addHeaderAndFooter(TextBlock original) {
if (DisplayPositionned.isNull(annotated.getFooter()) && DisplayPositionned.isNull(annotated.getHeader())) {
return original;
}
final TextBlock textFooter = DisplayPositionned.isNull(annotated.getFooter()) ? null : annotated
.getFooter()
.getDisplay()
.create(new FontConfiguration(getSkinParam(), FontParam.FOOTER, null),
annotated.getFooter().getHorizontalAlignment(), getSkinParam());
final TextBlock textHeader = DisplayPositionned.isNull(annotated.getHeader()) ? null : annotated
.getHeader()
.getDisplay()
.create(new FontConfiguration(getSkinParam(), FontParam.HEADER, null),
annotated.getHeader().getHorizontalAlignment(), getSkinParam());
// return new DecorateTextBlock(original, textHeader, annotated.getHeader().getHorizontalAlignment(),
// textFooter,
// annotated.getFooter().getHorizontalAlignment());
return new DecorateEntityImage(original, textHeader, annotated.getHeader().getHorizontalAlignment(),
textFooter, annotated.getFooter().getHorizontalAlignment());
}
}

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18802 $
* *
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
@ -88,6 +88,7 @@ public enum FontParam {
STATE_ATTRIBUTE(12, Font.PLAIN), // STATE_ATTRIBUTE(12, Font.PLAIN), //
LEGEND(14, Font.PLAIN), // LEGEND(14, Font.PLAIN), //
TITLE(18, Font.PLAIN), // TITLE(18, Font.PLAIN), //
CAPTION(14, Font.PLAIN), //
SWIMLANE_TITLE(18, Font.PLAIN), // SWIMLANE_TITLE(18, Font.PLAIN), //
FOOTER(10, Font.PLAIN, "#888888", FontParamConstant.FAMILY), // FOOTER(10, Font.PLAIN, "#888888", FontParamConstant.FAMILY), //
HEADER(10, Font.PLAIN, "#888888", FontParamConstant.FAMILY), // HEADER(10, Font.PLAIN, "#888888", FontParamConstant.FAMILY), //

View File

@ -118,8 +118,6 @@ public interface ISkinParam extends ISkinSimple {
public boolean useOctagonForActivity(Stereotype stereotype); public boolean useOctagonForActivity(Stereotype stereotype);
public IHtmlColorSet getIHtmlColorSet();
public int groupInheritance(); public int groupInheritance();
public boolean useGuillemet(); public boolean useGuillemet();

View File

@ -33,6 +33,8 @@
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
import net.sourceforge.plantuml.graphic.IHtmlColorSet;
public interface ISkinSimple extends SpriteContainer { public interface ISkinSimple extends SpriteContainer {
public String getValue(String key); public String getValue(String key);
@ -43,4 +45,6 @@ public interface ISkinSimple extends SpriteContainer {
public int getTabSize(); public int getTabSize();
public IHtmlColorSet getIHtmlColorSet();
} }

View File

@ -36,6 +36,7 @@ package net.sourceforge.plantuml;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStream; import java.io.OutputStream;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.List; import java.util.List;
import net.sourceforge.plantuml.command.BlocLines; import net.sourceforge.plantuml.command.BlocLines;
@ -136,4 +137,8 @@ public class NewpagedDiagram extends AbstractPSystem {
} }
} }
public final List<Diagram> getDiagrams() {
return Collections.unmodifiableList(diagrams);
}
} }

View File

@ -75,6 +75,7 @@ import net.sourceforge.plantuml.sequencediagram.SequenceDiagramFactory;
import net.sourceforge.plantuml.statediagram.StateDiagramFactory; import net.sourceforge.plantuml.statediagram.StateDiagramFactory;
import net.sourceforge.plantuml.sudoku.PSystemSudokuFactory; import net.sourceforge.plantuml.sudoku.PSystemSudokuFactory;
import net.sourceforge.plantuml.turing.PSystemTuringFactory; import net.sourceforge.plantuml.turing.PSystemTuringFactory;
import net.sourceforge.plantuml.ugraphic.sprite.PSystemListInternalSpritesFactory;
import net.sourceforge.plantuml.version.License; import net.sourceforge.plantuml.version.License;
import net.sourceforge.plantuml.version.PSystemLicenseFactory; import net.sourceforge.plantuml.version.PSystemLicenseFactory;
import net.sourceforge.plantuml.version.PSystemVersionFactory; import net.sourceforge.plantuml.version.PSystemVersionFactory;
@ -129,6 +130,7 @@ public class PSystemBuilder {
factories.add(new PSystemListFontsFactory()); factories.add(new PSystemListFontsFactory());
factories.add(new PSystemOpenIconicFactory()); factories.add(new PSystemOpenIconicFactory());
factories.add(new PSystemListOpenIconicFactory()); factories.add(new PSystemListOpenIconicFactory());
factories.add(new PSystemListInternalSpritesFactory());
factories.add(new PSystemSaltFactory(DiagramType.SALT)); factories.add(new PSystemSaltFactory(DiagramType.SALT));
factories.add(new PSystemSaltFactory(DiagramType.UML)); factories.add(new PSystemSaltFactory(DiagramType.UML));
factories.add(new PSystemDotFactory(DiagramType.DOT)); factories.add(new PSystemDotFactory(DiagramType.DOT));

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18790 $
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
@ -323,7 +323,7 @@ public class PSystemError extends AbstractPSystem {
final StringBuilder sb = new StringBuilder(); final StringBuilder sb = new StringBuilder();
sb.append(getDescription()); sb.append(getDescription());
sb.append('\n'); sb.append('\n');
for (CharSequence t : getTitle()) { for (CharSequence t : getTitle().getDisplay()) {
sb.append(t); sb.append(t);
sb.append('\n'); sb.append('\n');
} }

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18309 $
* *
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
@ -64,8 +64,8 @@ import net.sourceforge.plantuml.preproc.Defines;
import net.sourceforge.plantuml.sequencediagram.SequenceDiagramFactory; import net.sourceforge.plantuml.sequencediagram.SequenceDiagramFactory;
import net.sourceforge.plantuml.statediagram.StateDiagramFactory; import net.sourceforge.plantuml.statediagram.StateDiagramFactory;
import net.sourceforge.plantuml.swing.MainWindow2; import net.sourceforge.plantuml.swing.MainWindow2;
import net.sourceforge.plantuml.ugraphic.SpriteGrayLevel; import net.sourceforge.plantuml.ugraphic.sprite.SpriteGrayLevel;
import net.sourceforge.plantuml.ugraphic.SpriteUtils; import net.sourceforge.plantuml.ugraphic.sprite.SpriteUtils;
import net.sourceforge.plantuml.version.Version; import net.sourceforge.plantuml.version.Version;
public class Run { public class Run {

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18291 $ * Revision $Revision: 18309 $
* *
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
@ -62,10 +62,10 @@ import net.sourceforge.plantuml.svek.PackageStyle;
import net.sourceforge.plantuml.ugraphic.ColorMapper; import net.sourceforge.plantuml.ugraphic.ColorMapper;
import net.sourceforge.plantuml.ugraphic.ColorMapperIdentity; import net.sourceforge.plantuml.ugraphic.ColorMapperIdentity;
import net.sourceforge.plantuml.ugraphic.ColorMapperMonochrome; import net.sourceforge.plantuml.ugraphic.ColorMapperMonochrome;
import net.sourceforge.plantuml.ugraphic.Sprite;
import net.sourceforge.plantuml.ugraphic.SpriteImage;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
import net.sourceforge.plantuml.ugraphic.UStroke; import net.sourceforge.plantuml.ugraphic.UStroke;
import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
import net.sourceforge.plantuml.ugraphic.sprite.SpriteImage;
public class SkinParam implements ISkinParam { public class SkinParam implements ISkinParam {

View File

@ -45,9 +45,9 @@ import net.sourceforge.plantuml.graphic.color.Colors;
import net.sourceforge.plantuml.svek.ConditionStyle; import net.sourceforge.plantuml.svek.ConditionStyle;
import net.sourceforge.plantuml.svek.PackageStyle; import net.sourceforge.plantuml.svek.PackageStyle;
import net.sourceforge.plantuml.ugraphic.ColorMapper; import net.sourceforge.plantuml.ugraphic.ColorMapper;
import net.sourceforge.plantuml.ugraphic.Sprite;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
import net.sourceforge.plantuml.ugraphic.UStroke; import net.sourceforge.plantuml.ugraphic.UStroke;
import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
public class SkinParamDelegator implements ISkinParam { public class SkinParamDelegator implements ISkinParam {

View File

@ -33,7 +33,7 @@
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
import net.sourceforge.plantuml.ugraphic.Sprite; import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
public interface SpriteContainer { public interface SpriteContainer {

View File

@ -34,12 +34,15 @@
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
import net.sourceforge.plantuml.creole.CommandCreoleMonospaced; import net.sourceforge.plantuml.creole.CommandCreoleMonospaced;
import net.sourceforge.plantuml.ugraphic.Sprite; import net.sourceforge.plantuml.graphic.HtmlColorSetSimple;
import net.sourceforge.plantuml.graphic.IHtmlColorSet;
import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
import net.sourceforge.plantuml.ugraphic.sprite.SpriteImage;
public class SpriteContainerEmpty implements SpriteContainer, ISkinSimple { public class SpriteContainerEmpty implements SpriteContainer, ISkinSimple {
public Sprite getSprite(String name) { public Sprite getSprite(String name) {
return null; return SpriteImage.fromInternal(name);
} }
public String getValue(String key) { public String getValue(String key) {
@ -62,4 +65,8 @@ public class SpriteContainerEmpty implements SpriteContainer, ISkinSimple {
return 8; return 8;
} }
public IHtmlColorSet getIHtmlColorSet() {
return new HtmlColorSetSimple();
}
} }

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18801 $
* *
*/ */
package net.sourceforge.plantuml; package net.sourceforge.plantuml;
@ -59,7 +59,7 @@ import net.sourceforge.plantuml.command.CommandExecutionResult;
import net.sourceforge.plantuml.core.Diagram; import net.sourceforge.plantuml.core.Diagram;
import net.sourceforge.plantuml.core.ImageData; import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.core.UmlSource; import net.sourceforge.plantuml.core.UmlSource;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.cucadiagram.UnparsableGraphvizException; import net.sourceforge.plantuml.cucadiagram.UnparsableGraphvizException;
import net.sourceforge.plantuml.flashcode.FlashCodeFactory; import net.sourceforge.plantuml.flashcode.FlashCodeFactory;
import net.sourceforge.plantuml.flashcode.FlashCodeUtils; import net.sourceforge.plantuml.flashcode.FlashCodeUtils;
@ -77,41 +77,47 @@ import net.sourceforge.plantuml.svek.EmptySvgException;
import net.sourceforge.plantuml.svek.GraphvizCrash; import net.sourceforge.plantuml.svek.GraphvizCrash;
import net.sourceforge.plantuml.ugraphic.ColorMapperIdentity; import net.sourceforge.plantuml.ugraphic.ColorMapperIdentity;
import net.sourceforge.plantuml.ugraphic.ImageBuilder; import net.sourceforge.plantuml.ugraphic.ImageBuilder;
import net.sourceforge.plantuml.ugraphic.Sprite;
import net.sourceforge.plantuml.ugraphic.UAntiAliasing; import net.sourceforge.plantuml.ugraphic.UAntiAliasing;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
import net.sourceforge.plantuml.ugraphic.UGraphic; import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UImage; import net.sourceforge.plantuml.ugraphic.UImage;
import net.sourceforge.plantuml.ugraphic.UTranslate; import net.sourceforge.plantuml.ugraphic.UTranslate;
import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
import net.sourceforge.plantuml.version.Version; import net.sourceforge.plantuml.version.Version;
public abstract class UmlDiagram extends AbstractPSystem implements Diagram { public abstract class UmlDiagram extends AbstractPSystem implements Diagram, Annotated {
private boolean rotation; private boolean rotation;
private boolean hideUnlinkedData; private boolean hideUnlinkedData;
private int minwidth = Integer.MAX_VALUE; private int minwidth = Integer.MAX_VALUE;
private Display title = Display.NULL; private DisplayPositionned title = DisplayPositionned.none(HorizontalAlignment.CENTER, VerticalAlignment.TOP);
private Display header = Display.NULL; private DisplayPositionned caption = DisplayPositionned.none(HorizontalAlignment.CENTER, VerticalAlignment.BOTTOM);
private Display footer = Display.NULL; private DisplayPositionned header = DisplayPositionned.none(HorizontalAlignment.RIGHT, VerticalAlignment.TOP);
private Display legend = Display.NULL; private DisplayPositionned footer = DisplayPositionned.none(HorizontalAlignment.CENTER, VerticalAlignment.BOTTOM);
private HorizontalAlignment legendAlignment = HorizontalAlignment.CENTER; private DisplayPositionned legend = DisplayPositionned.none(HorizontalAlignment.CENTER, VerticalAlignment.BOTTOM);
private VerticalAlignment legendVerticalAlignment = VerticalAlignment.BOTTOM;
private HorizontalAlignment headerAlignment = HorizontalAlignment.RIGHT;
private HorizontalAlignment footerAlignment = HorizontalAlignment.CENTER;
private final Pragma pragma = new Pragma(); private final Pragma pragma = new Pragma();
private Scale scale; private Scale scale;
private Animation animation; private Animation animation;
private final SkinParam skinParam = new SkinParam(); private final SkinParam skinParam = new SkinParam();
final public void setTitle(Display strings) { final public void setTitle(DisplayPositionned title) {
this.title = strings; this.title = title;
} }
final public Display getTitle() { final public void setCaption(DisplayPositionned caption) {
this.caption = caption;
}
final public DisplayPositionned getCaption() {
return caption;
}
@Override
final public DisplayPositionned getTitle() {
return title; return title;
} }
@ -139,45 +145,23 @@ public abstract class UmlDiagram extends AbstractPSystem implements Diagram {
skinParam.setParam(StringUtils.goLowerCase(key), value); skinParam.setParam(StringUtils.goLowerCase(key), value);
} }
public final Display getHeader() { public final DisplayPositionned getHeader() {
return header; return header;
} }
public final void setHeader(Display header) { public final void setHeader(DisplayPositionned header) {
this.header = header; this.header = header;
} }
public final Display getFooter() { public final DisplayPositionned getFooter() {
return footer; return footer;
} }
public final void setFooter(Display footer) { public final void setFooter(DisplayPositionned footer) {
this.footer = footer; this.footer = footer;
} }
public final HorizontalAlignment getHeaderAlignment() { public final DisplayPositionned getFooterOrHeaderTeoz(FontParam param) {
return headerAlignment;
}
public final void setHeaderAlignment(HorizontalAlignment headerAlignment) {
this.headerAlignment = headerAlignment;
}
public final HorizontalAlignment getFooterAlignment() {
return footerAlignment;
}
public final HorizontalAlignment getAlignmentTeoz(FontParam param) {
if (param == FontParam.FOOTER) {
return getFooterAlignment();
}
if (param == FontParam.HEADER) {
return getHeaderAlignment();
}
throw new IllegalArgumentException();
}
public final Display getFooterOrHeaderTeoz(FontParam param) {
if (param == FontParam.FOOTER) { if (param == FontParam.FOOTER) {
return getFooter(); return getFooter();
} }
@ -187,10 +171,6 @@ public abstract class UmlDiagram extends AbstractPSystem implements Diagram {
throw new IllegalArgumentException(); throw new IllegalArgumentException();
} }
public final void setFooterAlignment(HorizontalAlignment footerAlignment) {
this.footerAlignment = footerAlignment;
}
abstract public UmlDiagramType getUmlDiagramType(); abstract public UmlDiagramType getUmlDiagramType();
public Pragma getPragma() { public Pragma getPragma() {
@ -431,21 +411,11 @@ public abstract class UmlDiagram extends AbstractPSystem implements Diagram {
skinParam.addSprite(name, sprite); skinParam.addSprite(name, sprite);
} }
public final Display getLegend() { public final DisplayPositionned getLegend() {
return legend; return legend;
} }
public final HorizontalAlignment getLegendAlignment() { public final void setLegend(DisplayPositionned legend) {
return legendAlignment;
}
public final VerticalAlignment getLegendVerticalAlignment() {
return legendVerticalAlignment;
}
public final void setLegend(Display legend, HorizontalAlignment horizontalAlignment, VerticalAlignment valignment) {
this.legend = legend; this.legend = legend;
this.legendAlignment = horizontalAlignment;
this.legendVerticalAlignment = valignment;
} }
} }

View File

@ -37,26 +37,22 @@ import java.awt.geom.Dimension2D;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStream; import java.io.OutputStream;
import net.sourceforge.plantuml.AnnotatedWorker;
import net.sourceforge.plantuml.ColorParam; import net.sourceforge.plantuml.ColorParam;
import net.sourceforge.plantuml.Dimension2DDouble; import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.FileFormatOption; import net.sourceforge.plantuml.FileFormatOption;
import net.sourceforge.plantuml.FontParam;
import net.sourceforge.plantuml.ISkinParam; import net.sourceforge.plantuml.ISkinParam;
import net.sourceforge.plantuml.Scale; import net.sourceforge.plantuml.Scale;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.UmlDiagramType; import net.sourceforge.plantuml.UmlDiagramType;
import net.sourceforge.plantuml.Url; import net.sourceforge.plantuml.Url;
import net.sourceforge.plantuml.activitydiagram3.ftile.BoxStyle; import net.sourceforge.plantuml.activitydiagram3.ftile.BoxStyle;
import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend;
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlanes; import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlanes;
import net.sourceforge.plantuml.command.CommandExecutionResult; import net.sourceforge.plantuml.command.CommandExecutionResult;
import net.sourceforge.plantuml.core.DiagramDescription; import net.sourceforge.plantuml.core.DiagramDescription;
import net.sourceforge.plantuml.core.DiagramDescriptionImpl; import net.sourceforge.plantuml.core.DiagramDescriptionImpl;
import net.sourceforge.plantuml.core.ImageData; import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.Stereotype;
import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.TextBlock; import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.graphic.TextBlockCompressed; import net.sourceforge.plantuml.graphic.TextBlockCompressed;
@ -65,10 +61,7 @@ import net.sourceforge.plantuml.graphic.TextBlockUtils;
import net.sourceforge.plantuml.graphic.color.Colors; import net.sourceforge.plantuml.graphic.color.Colors;
import net.sourceforge.plantuml.sequencediagram.NotePosition; import net.sourceforge.plantuml.sequencediagram.NotePosition;
import net.sourceforge.plantuml.skin.rose.Rose; import net.sourceforge.plantuml.skin.rose.Rose;
import net.sourceforge.plantuml.svek.DecorateEntityImage;
import net.sourceforge.plantuml.svek.DecorateTextBlock;
import net.sourceforge.plantuml.ugraphic.ImageBuilder; import net.sourceforge.plantuml.ugraphic.ImageBuilder;
import net.sourceforge.plantuml.ugraphic.UFont;
public class ActivityDiagram3 extends UmlDiagram { public class ActivityDiagram3 extends UmlDiagram {
@ -160,16 +153,6 @@ public class ActivityDiagram3 extends UmlDiagram {
return UmlDiagramType.ACTIVITY; return UmlDiagramType.ACTIVITY;
} }
private TextBlock addLegend(TextBlock original) {
final Display legend = getLegend();
if (Display.isNull(legend)) {
return original;
}
final TextBlock text = EntityImageLegend.create(legend, getSkinParam());
return DecorateEntityImage.add(original, text, getLegendAlignment(), getLegendVerticalAlignment());
}
@Override @Override
protected ImageData exportDiagramInternal(OutputStream os, int index, FileFormatOption fileFormatOption) protected ImageData exportDiagramInternal(OutputStream os, int index, FileFormatOption fileFormatOption)
throws IOException { throws IOException {
@ -178,10 +161,8 @@ public class ActivityDiagram3 extends UmlDiagram {
// TextBlock result = swinlanes; // TextBlock result = swinlanes;
TextBlock result = new TextBlockCompressed(swinlanes); TextBlock result = new TextBlockCompressed(swinlanes);
result = new TextBlockRecentred(result); result = new TextBlockRecentred(result);
result = addLegend(result);
result = addTitle(result);
result = addHeaderAndFooter(result);
final ISkinParam skinParam = getSkinParam(); final ISkinParam skinParam = getSkinParam();
result = new AnnotatedWorker(this, skinParam).addAdd(result);
final Dimension2D dim = TextBlockUtils.getMinMax(result).getDimension(); final Dimension2D dim = TextBlockUtils.getMinMax(result).getDimension();
final double margin = 10; final double margin = 10;
final double dpiFactor = getDpiFactor(fileFormatOption, Dimension2DDouble.delta(dim, 2 * margin, 0)); final double dpiFactor = getDpiFactor(fileFormatOption, Dimension2DDouble.delta(dim, 2 * margin, 0));
@ -206,40 +187,15 @@ public class ActivityDiagram3 extends UmlDiagram {
return dpiFactor; return dpiFactor;
} }
private TextBlock addTitle(TextBlock original) { // private final UFont getFont(FontParam fontParam) {
final Display title = getTitle(); // final ISkinParam skinParam = getSkinParam();
if (Display.isNull(title)) { // return skinParam.getFont(null, false, fontParam);
return original; // }
} //
final TextBlock text = title.create(new FontConfiguration(getSkinParam(), FontParam.TITLE, null), // private final HtmlColor getFontColor(FontParam fontParam, Stereotype stereotype2) {
HorizontalAlignment.CENTER, getSkinParam()); // final ISkinParam skinParam = getSkinParam();
// return skinParam.getFontHtmlColor(stereotype2, fontParam);
return new DecorateTextBlock(original, text, HorizontalAlignment.CENTER); // }
}
private TextBlock addHeaderAndFooter(TextBlock original) {
final Display footer = getFooter();
final Display header = getHeader();
if (Display.isNull(footer) && Display.isNull(header)) {
return original;
}
final TextBlock textFooter = Display.isNull(footer) ? null : footer.create(new FontConfiguration(
getSkinParam(), FontParam.FOOTER, null), getFooterAlignment(), getSkinParam());
final TextBlock textHeader = Display.isNull(header) ? null : header.create(new FontConfiguration(
getSkinParam(), FontParam.HEADER, null), getHeaderAlignment(), getSkinParam());
return new DecorateTextBlock(original, textHeader, getHeaderAlignment(), textFooter, getFooterAlignment());
}
private final UFont getFont(FontParam fontParam) {
final ISkinParam skinParam = getSkinParam();
return skinParam.getFont(null, false, fontParam);
}
private final HtmlColor getFontColor(FontParam fontParam, Stereotype stereotype2) {
final ISkinParam skinParam = getSkinParam();
return skinParam.getFontHtmlColor(stereotype2, fontParam);
}
public void fork() { public void fork() {
final InstructionFork instructionFork = new InstructionFork(current(), nextLinkRenderer()); final InstructionFork instructionFork = new InstructionFork(current(), nextLinkRenderer());
@ -307,7 +263,10 @@ public class ActivityDiagram3 extends UmlDiagram {
public CommandExecutionResult elseIf(Display test, Display whenThen, HtmlColor color) { public CommandExecutionResult elseIf(Display test, Display whenThen, HtmlColor color) {
if (current() instanceof InstructionIf) { if (current() instanceof InstructionIf) {
((InstructionIf) current()).elseIf(test, whenThen, nextLinkRenderer(), color); final boolean ok = ((InstructionIf) current()).elseIf(test, whenThen, nextLinkRenderer(), color);
if (ok == false) {
return CommandExecutionResult.error("You cannot put an elseIf here");
}
setNextLinkRendererInternal(null); setNextLinkRendererInternal(null);
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }

View File

@ -108,13 +108,14 @@ public class InstructionIf implements Instruction, InstructionCollection {
return true; return true;
} }
public void elseIf(Display test, Display whenThen, LinkRendering nextLinkRenderer, HtmlColor color) { public boolean elseIf(Display test, Display whenThen, LinkRendering nextLinkRenderer, HtmlColor color) {
if (elseBranch != null) { if (elseBranch != null) {
throw new IllegalStateException(); return false;
} }
this.current.setInlinkRendering(nextLinkRenderer); this.current.setInlinkRendering(nextLinkRenderer);
this.current = new Branch(swimlane, whenThen, test, color); this.current = new Branch(swimlane, whenThen, test, color);
this.thens.add(current); this.thens.add(current);
return true;
} }

View File

@ -40,7 +40,6 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileKilled; import net.sourceforge.plantuml.activitydiagram3.ftile.FtileKilled;
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane; import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.color.Colors; import net.sourceforge.plantuml.graphic.color.Colors;
import net.sourceforge.plantuml.sequencediagram.NotePosition; import net.sourceforge.plantuml.sequencediagram.NotePosition;

View File

@ -42,6 +42,8 @@ import net.sourceforge.plantuml.sequencediagram.NotePosition;
public class InstructionStop extends MonoSwimable implements Instruction { public class InstructionStop extends MonoSwimable implements Instruction {
private final LinkRendering inlinkRendering; private final LinkRendering inlinkRendering;
private Display note;
private NotePosition notePosition;
public InstructionStop(Swimlane swimlane, LinkRendering inlinkRendering) { public InstructionStop(Swimlane swimlane, LinkRendering inlinkRendering) {
super(swimlane); super(swimlane);
@ -49,7 +51,11 @@ public class InstructionStop extends MonoSwimable implements Instruction {
} }
public Ftile createFtile(FtileFactory factory) { public Ftile createFtile(FtileFactory factory) {
return factory.stop(getSwimlaneIn()); Ftile result = factory.stop(getSwimlaneIn());
if (note != null) {
result = factory.addNote(result, note, notePosition);
}
return result;
} }
public void add(Instruction other) { public void add(Instruction other) {
@ -65,7 +71,9 @@ public class InstructionStop extends MonoSwimable implements Instruction {
} }
public boolean addNote(Display note, NotePosition position) { public boolean addNote(Display note, NotePosition position) {
throw new UnsupportedOperationException(); this.note = note;
this.notePosition = position;
return true;
} }
} }

View File

@ -46,12 +46,13 @@ import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.graphic.FontConfiguration; import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.IHtmlColorSet;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.TextBlock; import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.graphic.color.Colors; import net.sourceforge.plantuml.graphic.color.Colors;
import net.sourceforge.plantuml.sequencediagram.NotePosition; import net.sourceforge.plantuml.sequencediagram.NotePosition;
import net.sourceforge.plantuml.skin.rose.Rose; import net.sourceforge.plantuml.skin.rose.Rose;
import net.sourceforge.plantuml.ugraphic.Sprite; import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
public class FtileFactoryDelegator implements FtileFactory { public class FtileFactoryDelegator implements FtileFactory {
@ -200,4 +201,8 @@ public class FtileFactoryDelegator implements FtileFactory {
return skinParam.getTabSize(); return skinParam.getTabSize();
} }
public IHtmlColorSet getIHtmlColorSet() {
return skinParam.getIHtmlColorSet();
}
} }

View File

@ -55,12 +55,13 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDecorateIn;
import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDecorateOut; import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDecorateOut;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.IHtmlColorSet;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.color.Colors; import net.sourceforge.plantuml.graphic.color.Colors;
import net.sourceforge.plantuml.sequencediagram.NotePosition; import net.sourceforge.plantuml.sequencediagram.NotePosition;
import net.sourceforge.plantuml.skin.rose.Rose; import net.sourceforge.plantuml.skin.rose.Rose;
import net.sourceforge.plantuml.ugraphic.Sprite;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
public class VCompactFactory implements FtileFactory { public class VCompactFactory implements FtileFactory {
@ -187,4 +188,8 @@ public class VCompactFactory implements FtileFactory {
return skinParam.getTabSize(); return skinParam.getTabSize();
} }
public IHtmlColorSet getIHtmlColorSet() {
return skinParam.getIHtmlColorSet();
}
} }

View File

@ -37,6 +37,7 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.sourceforge.plantuml.AbstractPSystem; import net.sourceforge.plantuml.AbstractPSystem;
import net.sourceforge.plantuml.NewpagedDiagram;
import net.sourceforge.plantuml.UmlDiagramType; import net.sourceforge.plantuml.UmlDiagramType;
import net.sourceforge.plantuml.classdiagram.command.CommandAddMethod; import net.sourceforge.plantuml.classdiagram.command.CommandAddMethod;
import net.sourceforge.plantuml.classdiagram.command.CommandAllowMixing; import net.sourceforge.plantuml.classdiagram.command.CommandAllowMixing;
@ -67,8 +68,9 @@ import net.sourceforge.plantuml.command.note.FactoryNoteOnEntityCommand;
import net.sourceforge.plantuml.command.note.FactoryNoteOnLinkCommand; import net.sourceforge.plantuml.command.note.FactoryNoteOnLinkCommand;
import net.sourceforge.plantuml.command.note.FactoryTipOnEntityCommand; import net.sourceforge.plantuml.command.note.FactoryTipOnEntityCommand;
import net.sourceforge.plantuml.command.regex.RegexLeaf; import net.sourceforge.plantuml.command.regex.RegexLeaf;
import net.sourceforge.plantuml.core.Diagram;
import net.sourceforge.plantuml.cucadiagram.Link; import net.sourceforge.plantuml.cucadiagram.Link;
import net.sourceforge.plantuml.objectdiagram.command.CommandAddData; import net.sourceforge.plantuml.descdiagram.command.CommandNewpage;
import net.sourceforge.plantuml.objectdiagram.command.CommandCreateEntityObject; import net.sourceforge.plantuml.objectdiagram.command.CommandCreateEntityObject;
import net.sourceforge.plantuml.objectdiagram.command.CommandCreateEntityObjectMultilines; import net.sourceforge.plantuml.objectdiagram.command.CommandCreateEntityObjectMultilines;
@ -87,6 +89,7 @@ public class ClassDiagramFactory extends UmlDiagramFactory {
addCommonCommands(cmds); addCommonCommands(cmds);
cmds.add(new CommandRankDir()); cmds.add(new CommandRankDir());
cmds.add(new CommandNewpage(this));
cmds.add(new CommandPage()); cmds.add(new CommandPage());
cmds.add(new CommandAddMethod()); cmds.add(new CommandAddMethod());
@ -145,8 +148,18 @@ public class ClassDiagramFactory extends UmlDiagramFactory {
@Override @Override
public String checkFinalError(AbstractPSystem sys) { public String checkFinalError(AbstractPSystem sys) {
if (sys instanceof NewpagedDiagram) {
for (Diagram p : ((NewpagedDiagram) sys).getDiagrams()) {
checkFinal((ClassDiagram) p);
}
} else {
final ClassDiagram system = (ClassDiagram) sys; final ClassDiagram system = (ClassDiagram) sys;
checkFinal(system);
}
return super.checkFinalError(sys);
}
private void checkFinal(final ClassDiagram system) {
for (Link link : system.getLinks()) { for (Link link : system.getLinks()) {
final int len = link.getLength(); final int len = link.getLength();
if (len == 1) { if (len == 1) {
@ -157,23 +170,7 @@ public class ClassDiagramFactory extends UmlDiagramFactory {
} }
} }
} }
system.applySingleStrategy(); system.applySingleStrategy();
// for (IGroup g : system.getGroups(true)) {
// final List<ILeaf> standalones = new ArrayList<ILeaf>();
// for (ILeaf ent : g.getLeafsDirect()) {
// if (system.isStandalone(ent)) {
// standalones.add(ent);
// }
// }
// if (standalones.size() < 3) {
// continue;
// }
// final Magma magma = new Magma(system, standalones);
// magma.putInSquare();
// }
return super.checkFinalError(system);
} }
} }

View File

@ -0,0 +1,57 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 18788 $
*
*/
package net.sourceforge.plantuml.command;
import java.util.List;
import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandCaption extends SingleLineCommand<UmlDiagram> {
public CommandCaption() {
super("(?i)^caption(?:[%s]*:[%s]*|[%s]+)(.*[\\p{L}0-9_.].*)$");
}
@Override
protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) {
diagram.setCaption(new DisplayPositionned(Display.getWithNewlines(arg.get(0)), HorizontalAlignment.CENTER,
VerticalAlignment.BOTTOM));
return CommandExecutionResult.ok();
}
}

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18789 $
* *
*/ */
package net.sourceforge.plantuml.command; package net.sourceforge.plantuml.command;
@ -38,7 +38,9 @@ import java.util.List;
import net.sourceforge.plantuml.StringUtils; import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandFooter extends SingleLineCommand<UmlDiagram> { public class CommandFooter extends SingleLineCommand<UmlDiagram> {
@ -49,11 +51,8 @@ public class CommandFooter extends SingleLineCommand<UmlDiagram> {
@Override @Override
protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) { protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) {
final String align = arg.get(0); final String align = arg.get(0);
if (align != null) { diagram.setFooter(new DisplayPositionned(Display.getWithNewlines(arg.get(1)), HorizontalAlignment.fromString(
diagram.setFooterAlignment(HorizontalAlignment.valueOf(StringUtils.goUpperCase(align))); align, HorizontalAlignment.CENTER), VerticalAlignment.BOTTOM));
}
diagram.setFooter(Display.getWithNewlines(arg.get(1)));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }
} }

View File

@ -28,17 +28,18 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18789 $
* *
*/ */
package net.sourceforge.plantuml.command; package net.sourceforge.plantuml.command;
import java.util.List; import java.util.List;
import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandHeader extends SingleLineCommand<UmlDiagram> { public class CommandHeader extends SingleLineCommand<UmlDiagram> {
@ -49,11 +50,8 @@ public class CommandHeader extends SingleLineCommand<UmlDiagram> {
@Override @Override
protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) { protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) {
final String align = arg.get(0); final String align = arg.get(0);
if (align != null) { diagram.setHeader(new DisplayPositionned(Display.getWithNewlines(arg.get(1)), HorizontalAlignment.fromString(
diagram.setHeaderAlignment(HorizontalAlignment.valueOf(StringUtils.goUpperCase(align))); align, HorizontalAlignment.RIGHT), VerticalAlignment.TOP));
}
diagram.setHeader(Display.getWithNewlines(arg.get(1)));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }
} }

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18789 $
* *
*/ */
package net.sourceforge.plantuml.command; package net.sourceforge.plantuml.command;
@ -38,7 +38,9 @@ import java.util.regex.Matcher;
import net.sourceforge.plantuml.StringUtils; import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandMultilinesFooter extends CommandMultilines<UmlDiagram> { public class CommandMultilinesFooter extends CommandMultilines<UmlDiagram> {
@ -58,13 +60,11 @@ public class CommandMultilinesFooter extends CommandMultilines<UmlDiagram> {
throw new IllegalStateException(); throw new IllegalStateException();
} }
final String align = m.group(1); final String align = m.group(1);
if (align != null) {
diagram.setFooterAlignment(HorizontalAlignment.valueOf(StringUtils.goUpperCase(align)));
}
lines = lines.subExtract(1, 1); lines = lines.subExtract(1, 1);
final Display strings = lines.toDisplay(); final Display strings = lines.toDisplay();
if (strings.size() > 0) { if (strings.size() > 0) {
diagram.setFooter(strings); diagram.setFooter(new DisplayPositionned(strings, HorizontalAlignment.fromString(align,
HorizontalAlignment.CENTER), VerticalAlignment.BOTTOM));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }
return CommandExecutionResult.error("Empty footer"); return CommandExecutionResult.error("Empty footer");

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18789 $
* *
*/ */
package net.sourceforge.plantuml.command; package net.sourceforge.plantuml.command;
@ -38,7 +38,9 @@ import java.util.regex.Matcher;
import net.sourceforge.plantuml.StringUtils; import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandMultilinesHeader extends CommandMultilines<UmlDiagram> { public class CommandMultilinesHeader extends CommandMultilines<UmlDiagram> {
@ -51,7 +53,6 @@ public class CommandMultilinesHeader extends CommandMultilines<UmlDiagram> {
return "(?i)^end[%s]?header$"; return "(?i)^end[%s]?header$";
} }
public CommandExecutionResult execute(final UmlDiagram diagram, BlocLines lines) { public CommandExecutionResult execute(final UmlDiagram diagram, BlocLines lines) {
lines = lines.trim(false); lines = lines.trim(false);
final Matcher m = getStartingPattern().matcher(StringUtils.trin(lines.getFirst499())); final Matcher m = getStartingPattern().matcher(StringUtils.trin(lines.getFirst499()));
@ -59,13 +60,11 @@ public class CommandMultilinesHeader extends CommandMultilines<UmlDiagram> {
throw new IllegalStateException(); throw new IllegalStateException();
} }
final String align = m.group(1); final String align = m.group(1);
if (align != null) {
diagram.setHeaderAlignment(HorizontalAlignment.valueOf(StringUtils.goUpperCase(align)));
}
lines = lines.subExtract(1, 1); lines = lines.subExtract(1, 1);
final Display strings = lines.toDisplay(); final Display strings = lines.toDisplay();
if (strings.size() > 0) { if (strings.size() > 0) {
diagram.setHeader(strings); diagram.setHeader(new DisplayPositionned(strings, HorizontalAlignment.fromString(align,
HorizontalAlignment.RIGHT), VerticalAlignment.TOP));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }
return CommandExecutionResult.error("Empty header"); return CommandExecutionResult.error("Empty header");

View File

@ -39,6 +39,7 @@ import net.sourceforge.plantuml.command.regex.RegexConcat;
import net.sourceforge.plantuml.command.regex.RegexLeaf; import net.sourceforge.plantuml.command.regex.RegexLeaf;
import net.sourceforge.plantuml.command.regex.RegexResult; import net.sourceforge.plantuml.command.regex.RegexResult;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment; import net.sourceforge.plantuml.graphic.VerticalAlignment;
@ -76,7 +77,7 @@ public class CommandMultilinesLegend extends CommandMultilines2<UmlDiagram> {
if (alignment == null) { if (alignment == null) {
alignment = HorizontalAlignment.CENTER; alignment = HorizontalAlignment.CENTER;
} }
diagram.setLegend(strings, alignment, valignment); diagram.setLegend(new DisplayPositionned(strings, alignment, valignment));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }
return CommandExecutionResult.error("No legend defined"); return CommandExecutionResult.error("No legend defined");

View File

@ -28,13 +28,16 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18788 $
* *
*/ */
package net.sourceforge.plantuml.command; package net.sourceforge.plantuml.command;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandMultilinesTitle extends CommandMultilines<UmlDiagram> { public class CommandMultilinesTitle extends CommandMultilines<UmlDiagram> {
@ -52,7 +55,7 @@ public class CommandMultilinesTitle extends CommandMultilines<UmlDiagram> {
lines = lines.removeEmptyColumns(); lines = lines.removeEmptyColumns();
final Display strings = lines.toDisplay(); final Display strings = lines.toDisplay();
if (strings.size() > 0) { if (strings.size() > 0) {
diagram.setTitle(strings); diagram.setTitle(new DisplayPositionned(strings, HorizontalAlignment.CENTER, VerticalAlignment.TOP));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }
return CommandExecutionResult.error("No title defined"); return CommandExecutionResult.error("No title defined");

View File

@ -46,7 +46,7 @@ import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.command.regex.RegexConcat; import net.sourceforge.plantuml.command.regex.RegexConcat;
import net.sourceforge.plantuml.command.regex.RegexLeaf; import net.sourceforge.plantuml.command.regex.RegexLeaf;
import net.sourceforge.plantuml.command.regex.RegexResult; import net.sourceforge.plantuml.command.regex.RegexResult;
import net.sourceforge.plantuml.ugraphic.SpriteImage; import net.sourceforge.plantuml.ugraphic.sprite.SpriteImage;
import net.sourceforge.plantuml.version.PSystemVersion; import net.sourceforge.plantuml.version.PSystemVersion;
public class CommandSpriteFile extends SingleLineCommand2<UmlDiagram> { public class CommandSpriteFile extends SingleLineCommand2<UmlDiagram> {

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18788 $
* *
*/ */
package net.sourceforge.plantuml.command; package net.sourceforge.plantuml.command;
@ -37,6 +37,9 @@ import java.util.List;
import net.sourceforge.plantuml.UmlDiagram; import net.sourceforge.plantuml.UmlDiagram;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class CommandTitle extends SingleLineCommand<UmlDiagram> { public class CommandTitle extends SingleLineCommand<UmlDiagram> {
@ -46,7 +49,8 @@ public class CommandTitle extends SingleLineCommand<UmlDiagram> {
@Override @Override
protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) { protected CommandExecutionResult executeArg(UmlDiagram diagram, List<String> arg) {
diagram.setTitle(Display.getWithNewlines(arg.get(0))); diagram.setTitle(new DisplayPositionned(Display.getWithNewlines(arg.get(0)), HorizontalAlignment.CENTER,
VerticalAlignment.TOP));
return CommandExecutionResult.ok(); return CommandExecutionResult.ok();
} }

View File

@ -43,8 +43,8 @@ import net.sourceforge.plantuml.command.note.SingleMultiFactoryCommand;
import net.sourceforge.plantuml.command.regex.RegexConcat; import net.sourceforge.plantuml.command.regex.RegexConcat;
import net.sourceforge.plantuml.command.regex.RegexLeaf; import net.sourceforge.plantuml.command.regex.RegexLeaf;
import net.sourceforge.plantuml.command.regex.RegexResult; import net.sourceforge.plantuml.command.regex.RegexResult;
import net.sourceforge.plantuml.ugraphic.Sprite; import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
import net.sourceforge.plantuml.ugraphic.SpriteGrayLevel; import net.sourceforge.plantuml.ugraphic.sprite.SpriteGrayLevel;
public final class FactorySpriteCommand implements SingleMultiFactoryCommand<UmlDiagram> { public final class FactorySpriteCommand implements SingleMultiFactoryCommand<UmlDiagram> {

View File

@ -264,6 +264,7 @@ public abstract class UmlDiagramFactory extends PSystemAbstractFactory {
cmds.add(new CommandMultilinesComment()); cmds.add(new CommandMultilinesComment());
cmds.add(new CommandPragma()); cmds.add(new CommandPragma());
cmds.add(new CommandTitle()); cmds.add(new CommandTitle());
cmds.add(new CommandCaption());
cmds.add(new CommandMultilinesTitle()); cmds.add(new CommandMultilinesTitle());
cmds.add(new CommandMultilinesLegend()); cmds.add(new CommandMultilinesLegend());

View File

@ -109,6 +109,6 @@ class AtomEmbededSystem implements Atom {
private Diagram getSystem() throws IOException, InterruptedException { private Diagram getSystem() throws IOException, InterruptedException {
final BlockUml blockUml = new BlockUml(lines2, 0); final BlockUml blockUml = new BlockUml(lines2, 0);
return blockUml.getDiagram(); return blockUml.getDiagram();
} }
} }

View File

@ -50,7 +50,6 @@ import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.FileSystem; import net.sourceforge.plantuml.FileSystem;
import net.sourceforge.plantuml.code.Base64Coder; import net.sourceforge.plantuml.code.Base64Coder;
import net.sourceforge.plantuml.graphic.FontConfiguration; import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.HtmlColorUtils;
import net.sourceforge.plantuml.graphic.ImgValign; import net.sourceforge.plantuml.graphic.ImgValign;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
@ -150,4 +149,5 @@ public class AtomImg implements Atom {
// tileImage.drawU(ug.apply(new UTranslate(0, -h))); // tileImage.drawU(ug.apply(new UTranslate(0, -h)));
} }
} }

View File

@ -42,18 +42,27 @@ import java.util.Map;
import net.sourceforge.plantuml.Dimension2DDouble; import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.ugraphic.UChangeBackColor;
import net.sourceforge.plantuml.ugraphic.UChangeColor; import net.sourceforge.plantuml.ugraphic.UChangeColor;
import net.sourceforge.plantuml.ugraphic.UGraphic; import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.ULine; import net.sourceforge.plantuml.ugraphic.ULine;
import net.sourceforge.plantuml.ugraphic.URectangle;
import net.sourceforge.plantuml.ugraphic.UTranslate; import net.sourceforge.plantuml.ugraphic.UTranslate;
public class AtomTable implements Atom { public class AtomTable implements Atom {
class Line { class Line {
private final List<Atom> cells = new ArrayList<Atom>(); private final List<Atom> cells = new ArrayList<Atom>();
private final List<HtmlColor> cellsBackColor = new ArrayList<HtmlColor>();
private final HtmlColor lineBackColor;
public void add(Atom cell) { private Line(HtmlColor lineBackColor) {
this.lineBackColor = lineBackColor;
}
public void add(Atom cell, HtmlColor cellBackColor) {
cells.add(cell); cells.add(cell);
cellsBackColor.add(cellBackColor);
} }
public int size() { public int size() {
@ -87,8 +96,27 @@ public class AtomTable implements Atom {
public void drawU(UGraphic ug) { public void drawU(UGraphic ug) {
initMap(ug.getStringBounder()); initMap(ug.getStringBounder());
for (Line line : lines) { for (int i = 0; i < getNbLines(); i++) {
for (Atom cell : line.cells) { final Line line = lines.get(i);
if (line.lineBackColor != null) {
final double y1 = getStartingY(i);
final double y2 = getStartingY(i + 1);
final double x1 = getStartingX(0);
final double x2 = getStartingX(getNbCols());
ug.apply(new UChangeColor(null)).apply(new UChangeBackColor(line.lineBackColor))
.apply(new UTranslate(x1, y1)).draw(new URectangle(x2 - x1, y2 - y1));
}
for (int j = 0; j < getNbCols(); j++) {
final Atom cell = line.cells.get(j);
final HtmlColor cellBackColor = line.cellsBackColor.get(j);
if (cellBackColor != null) {
final double y1 = getStartingY(i);
final double y2 = getStartingY(i + 1);
final double x1 = getStartingX(j);
final double x2 = getStartingX(j + 1);
ug.apply(new UChangeColor(null)).apply(new UChangeBackColor(cellBackColor))
.apply(new UTranslate(x1, y1)).draw(new URectangle(x2 - x1, y2 - y1));
}
final Position pos = positions.get(cell); final Position pos = positions.get(cell);
cell.drawU(ug.apply(pos.getTranslate())); cell.drawU(ug.apply(pos.getTranslate()));
} }
@ -210,13 +238,12 @@ public class AtomTable implements Atom {
return lines.get(lines.size() - 1); return lines.get(lines.size() - 1);
} }
public void addCell(Atom cell) { public void addCell(Atom cell, HtmlColor cellBackColor) {
lastLine().add(cell); lastLine().add(cell, cellBackColor);
positions.clear(); positions.clear();
} }
public void newLine() { public void newLine(HtmlColor lineBackColor) {
lines.add(new Line()); lines.add(new Line(lineBackColor));
} }
} }

View File

@ -255,4 +255,5 @@ public class AtomText implements Atom {
public final String getText() { public final String getText() {
return text; return text;
} }
} }

View File

@ -62,7 +62,7 @@ public class CreoleParser {
} }
private Stripe createStripe(String line, CreoleContext context, Stripe lastStripe) { private Stripe createStripe(String line, CreoleContext context, Stripe lastStripe) {
if (lastStripe instanceof StripeTable && line.startsWith("|") && line.endsWith("|")) { if (lastStripe instanceof StripeTable && isTableLine(line)) {
final StripeTable table = (StripeTable) lastStripe; final StripeTable table = (StripeTable) lastStripe;
table.analyzeAndAddNormal(line); table.analyzeAndAddNormal(line);
return null; return null;
@ -70,7 +70,7 @@ public class CreoleParser {
final StripeTree tree = (StripeTree) lastStripe; final StripeTree tree = (StripeTree) lastStripe;
tree.analyzeAndAdd(line); tree.analyzeAndAdd(line);
return null; return null;
} else if (line.startsWith("|=") && line.endsWith("|")) { } else if (isTableLine(line)) {
return new StripeTable(fontConfiguration, skinParam, line); return new StripeTable(fontConfiguration, skinParam, line);
} else if (isTreeStart(line)) { } else if (isTreeStart(line)) {
return new StripeTree(fontConfiguration, skinParam, line); return new StripeTree(fontConfiguration, skinParam, line);
@ -79,6 +79,14 @@ public class CreoleParser {
.createStripe(context); .createStripe(context);
} }
private static boolean isTableLine(String line) {
return line.matches("^(\\<#\\w+\\>)?\\|(\\=)?.*\\|$");
}
public static boolean doesStartByColor(String line) {
return line.matches("^(\\<#\\w+\\>).*");
}
public static boolean isTreeStart(String line) { public static boolean isTreeStart(String line) {
// return false; // return false;
return line.startsWith("|_"); return line.startsWith("|_");

View File

@ -162,4 +162,5 @@ public class SheetBlock1 extends AbstractTextBlock implements TextBlock, Atom, S
public double getEndingX(StringBounder stringBounder, double y) { public double getEndingX(StringBounder stringBounder, double y) {
return calculateDimension(stringBounder).getWidth(); return calculateDimension(stringBounder).getWidth();
} }
} }

View File

@ -77,4 +77,5 @@ public class SheetBlock2 extends AbstractTextBlock implements TextBlock, Atom {
public Rectangle2D getInnerPosition(String member, StringBounder stringBounder) { public Rectangle2D getInnerPosition(String member, StringBounder stringBounder) {
return block.getInnerPosition(member, stringBounder); return block.getInnerPosition(member, stringBounder);
} }
} }

View File

@ -44,13 +44,13 @@ import net.sourceforge.plantuml.graphic.FontPosition;
import net.sourceforge.plantuml.graphic.FontStyle; import net.sourceforge.plantuml.graphic.FontStyle;
import net.sourceforge.plantuml.graphic.ImgValign; import net.sourceforge.plantuml.graphic.ImgValign;
import net.sourceforge.plantuml.openiconic.OpenIcon; import net.sourceforge.plantuml.openiconic.OpenIcon;
import net.sourceforge.plantuml.ugraphic.Sprite; import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
import net.sourceforge.plantuml.utils.CharHidder; import net.sourceforge.plantuml.utils.CharHidder;
public class StripeSimple implements Stripe { public class StripeSimple implements Stripe {
final private List<Atom> atoms = new ArrayList<Atom>(); final private List<Atom> atoms = new ArrayList<Atom>();
private final List<Command> commands = new ArrayList<Command>(); final private List<Command> commands = new ArrayList<Command>();
private FontConfiguration fontConfiguration; private FontConfiguration fontConfiguration;

View File

@ -41,6 +41,7 @@ import java.util.StringTokenizer;
import net.sourceforge.plantuml.ISkinSimple; import net.sourceforge.plantuml.ISkinSimple;
import net.sourceforge.plantuml.graphic.FontConfiguration; import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.HtmlColor;
public class StripeTable implements Stripe { public class StripeTable implements Stripe {
@ -74,10 +75,39 @@ public class StripeTable implements Stripe {
return new SheetBlock1(sheet, 0, padding); return new SheetBlock1(sheet, 0, padding);
} }
private HtmlColor getBackColor(String line) {
if (CreoleParser.doesStartByColor(line)) {
final int idx1 = line.indexOf('#');
final int idx2 = line.indexOf('>');
if (idx2 == -1) {
throw new IllegalStateException();
}
final String color = line.substring(idx1, idx2);
return skinParam.getIHtmlColorSet().getColorIfValid(color);
}
return null;
}
private String withouBackColor(String line) {
final int idx2 = line.indexOf('>');
if (idx2 == -1) {
throw new IllegalStateException();
}
return line.substring(idx2 + 1);
}
private void analyzeAndAddInternal(String line, Mode mode) { private void analyzeAndAddInternal(String line, Mode mode) {
table.newLine(); HtmlColor lineBackColor = getBackColor(line);
if (lineBackColor != null) {
line = withouBackColor(line);
}
table.newLine(lineBackColor);
for (final StringTokenizer st = new StringTokenizer(line, "|"); st.hasMoreTokens();) { for (final StringTokenizer st = new StringTokenizer(line, "|"); st.hasMoreTokens();) {
String v = st.nextToken(); String v = st.nextToken();
HtmlColor cellBackColor = getBackColor(v);
if (cellBackColor != null) {
v = withouBackColor(v);
}
if (mode == Mode.HEADER && v.startsWith("=")) { if (mode == Mode.HEADER && v.startsWith("=")) {
v = v.substring(1); v = v.substring(1);
} }
@ -89,7 +119,7 @@ public class StripeTable implements Stripe {
cell.analyzeAndAdd(s); cell.analyzeAndAdd(s);
cells.add(cell); cells.add(cell);
} }
table.addCell(asAtom(cells, skinParam.getPadding())); table.addCell(asAtom(cells, skinParam.getPadding()), cellBackColor);
} }
} }

View File

@ -0,0 +1,76 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 8218 $
*
*/
package net.sourceforge.plantuml.cucadiagram;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.VerticalAlignment;
public class DisplayPositionned {
private final Display display;
private final HorizontalAlignment horizontalAlignment;
private final VerticalAlignment verticalAlignment;
public DisplayPositionned(Display display, HorizontalAlignment horizontalAlignment,
VerticalAlignment verticalAlignment) {
this.display = display;
this.horizontalAlignment = horizontalAlignment;
this.verticalAlignment = verticalAlignment;
}
public static DisplayPositionned none(HorizontalAlignment horizontalAlignment, VerticalAlignment verticalAlignment) {
return new DisplayPositionned(Display.NULL, horizontalAlignment, verticalAlignment);
}
public final Display getDisplay() {
return display;
}
public final HorizontalAlignment getHorizontalAlignment() {
return horizontalAlignment;
}
public final VerticalAlignment getVerticalAlignment() {
return verticalAlignment;
}
public static boolean isNull(DisplayPositionned data) {
return data == null || Display.isNull(data.display);
}
public boolean hasUrl() {
return display.hasUrl();
}
}

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18823 $
* *
*/ */
package net.sourceforge.plantuml.cucadiagram; package net.sourceforge.plantuml.cucadiagram;
@ -245,6 +245,25 @@ public class Link implements Hideable, Removeable {
return result; return result;
} }
private boolean isReallyGroup(IEntity ent) {
if (ent.isGroup() == false) {
return false;
}
final IGroup group = (IGroup) ent;
return group.getChildren().size() + group.getLeafsDirect().size() > 0;
}
public LinkType getTypePatchCluster() {
LinkType result = getType();
if (isReallyGroup(getEntity1())) {
result = result.withoutDecors2();
}
if (isReallyGroup(getEntity2())) {
result = result.withoutDecors1();
}
return result;
}
private LinkType getTypeSpecialForPrinting() { private LinkType getTypeSpecialForPrinting() {
if (opale) { if (opale) {
return new LinkType(LinkDecor.NONE, LinkDecor.NONE); return new LinkType(LinkDecor.NONE, LinkDecor.NONE);

View File

@ -52,6 +52,14 @@ public class LinkType {
this(hat1, decor1, LinkStyle.NORMAL, LinkMiddleDecor.NONE, decor2, hat2); this(hat1, decor1, LinkStyle.NORMAL, LinkMiddleDecor.NONE, decor2, hat2);
} }
public LinkType withoutDecors1() {
return new LinkType(hat1, LinkDecor.NONE, style, middleDecor, decor2, hat2);
}
public LinkType withoutDecors2() {
return new LinkType(hat1, decor1, style, middleDecor, LinkDecor.NONE, hat2);
}
// public boolean contains(LinkDecor decors) { // public boolean contains(LinkDecor decors) {
// return decor1 == decors || decor2 == decors; // return decor1 == decors || decor2 == decors;
// } // }

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18291 $ * Revision $Revision: 18317 $
* *
*/ */
package net.sourceforge.plantuml.cucadiagram; package net.sourceforge.plantuml.cucadiagram;
@ -48,12 +48,13 @@ import net.sourceforge.plantuml.graphic.HtmlColorUtils;
import net.sourceforge.plantuml.graphic.IHtmlColorSet; import net.sourceforge.plantuml.graphic.IHtmlColorSet;
import net.sourceforge.plantuml.svek.PackageStyle; import net.sourceforge.plantuml.svek.PackageStyle;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
import net.sourceforge.plantuml.ugraphic.sprite.SpriteUtils;
public class Stereotype implements CharSequence, Hideable { public class Stereotype implements CharSequence, Hideable {
private final static Pattern circleChar = MyPattern private final static Pattern circleChar = MyPattern
.cmpile("\\<\\<[%s]*\\(?(\\S)[%s]*,[%s]*(#[0-9a-fA-F]{6}|\\w+)[%s]*(?:[),](.*?))?\\>\\>"); .cmpile("\\<\\<[%s]*\\(?(\\S)[%s]*,[%s]*(#[0-9a-fA-F]{6}|\\w+)[%s]*(?:[),](.*?))?\\>\\>");
private final static Pattern circleSprite = MyPattern private final static Pattern circleSprite = MyPattern.cmpile("\\<\\<[%s]*\\(?\\$(" + SpriteUtils.SPRITE_NAME
.cmpile("\\<\\<[%s]*\\(?\\$([-\\p{L}0-9_/]+)[%s]*(?:,[%s]*(#[0-9a-fA-F]{6}|\\w+))?[%s]*(?:[),](.*?))?\\>\\>"); + ")[%s]*(?:,[%s]*(#[0-9a-fA-F]{6}|\\w+))?[%s]*(?:[),](.*?))?\\>\\>");
private final String label; private final String label;
private final HtmlColor htmlColor; private final HtmlColor htmlColor;

View File

@ -59,8 +59,8 @@ public class CommandNewpage extends SingleLineCommand2<AbstractPSystem> {
@Override @Override
protected CommandExecutionResult executeArg(AbstractPSystem diagram, RegexResult arg) { protected CommandExecutionResult executeArg(AbstractPSystem diagram, RegexResult arg) {
// NewpagedDiagram result = NewpagedDiagram.newpage(diagram, factory.createEmptyDiagram());
NewpagedDiagram result = new NewpagedDiagram(diagram, factory.createEmptyDiagram()); NewpagedDiagram result = new NewpagedDiagram(diagram, factory.createEmptyDiagram());
// NewpagedDiagram result = NewpagedDiagram.newpage(diagram, factory.createEmptyDiagram());
return CommandExecutionResult.newDiagram(result); return CommandExecutionResult.newDiagram(result);
} }
} }

View File

@ -58,7 +58,7 @@ import net.sourceforge.plantuml.version.PSystemVersion;
public class PSystemDonors extends AbstractPSystem { public class PSystemDonors extends AbstractPSystem {
public static final String DONORS = "UDfTKa5osp0ClECLF6lIHoXMwuvi9ncxxI4tM48is3IXa9HRwMszzME5qigYZHDtW0LsGUGs-n_auOKYUPExA8wnWc-KpI5dMCiCVO1yek8UbdvEKGyxscE8ZCuyIUCWTxLuinIA0utFjpUjcChHmHgJGIv2mHDW2_dSMYwmwsO9FImvkmqdK4ugkm2xI6r3pYn4MlLNJ7CemEfyHnKF2x7ip5QwG51sT_diA6fa0Yt39b6DvnJggDpIBtIrhdFHi7OzeE_LwVPgsntWALKV1tYsV552mTL9bLypxE1pkBPsYOYCBb0CPuw-Dsjif4OenwM_DgZjaxgCxFnT6gTUr-GmQftgKrtbF_5qkd7bwXlumMHjP9Nsx2CFy7LErm8RhXgovX7Pzga3EwHYGhYNLXAwJoLMxnq5KtHxZ_grThR_GuwHgiQiF0QS9Hr8BpRvm9_ZeMc9MSc5qxlvk9plitz6s2QtF8wuyNbKTfjScPp6HJsAHuUsVJ2l557Q05lrYxusAnv_6hvOyUFwDtz-MwluBytvuOe0"; public static final String DONORS = "UDfTKa6MsZ0CtUiKNkTD3v4XBNq1PlgWxM9sWcY8m5YfxT26itNNYrMX3JPePJtfI__BlxJ5_o0FNoYIDwMBuXXty9MA57A2fQJK1oWdA6vXxbE91jZG5aDaTEP5MWUbQyIRkL2yqFXyVzUEgHqTB35Rv29KF2LieKoZvGoRFb4OOCx5VJY1UcBP1zX4wbfoPYRIgRvgsaC15gS7g7YOYMLdrj87Whf_g1S7KI5JqZ6iCjPuobDTLLhwXQxHSyvQrgbxz8CgNTzakpsyvEpZ1LujdnLGyUwep6yLTl0nt4QxZ4H1PwWk9uv-C4jifK6enwE_jQZZixw2RFekZUEWPt8OjK_vAQ_w7tawtgbopLrwHR8EiWfxzP4ly3cL6u4LxrgovXdP3ha2Uyd9XF18hIPq7shS_UWfcAhVUjIljKd-Tpb4shLcuJ5WehGdTMpsWJz7escBMSYPSzzSdVCjwMU4TURbSSMTpeEYkynbSXmFzImU7ThkoRnHHEa2h5Kl-iOiUFnf-6J5Z-TV_VbjxTK3oHysywgwwo_hGETg";
public ImageData exportDiagram(OutputStream os, int num, FileFormatOption fileFormat) throws IOException { public ImageData exportDiagram(OutputStream os, int num, FileFormatOption fileFormat) throws IOException {
final GraphicStrings result = getGraphicStrings(); final GraphicStrings result = getGraphicStrings();

View File

@ -517,6 +517,9 @@ public class EpsGraphics {
} }
protected void appendColor(Color c) { protected void appendColor(Color c) {
if (c == null) {
return;
}
final double r = c.getRed() / 255.0; final double r = c.getRed() / 255.0;
final double g = c.getGreen() / 255.0; final double g = c.getGreen() / 255.0;
final double b = c.getBlue() / 255.0; final double b = c.getBlue() / 255.0;
@ -524,6 +527,9 @@ public class EpsGraphics {
} }
protected void appendColorShort(Color c) { protected void appendColorShort(Color c) {
if (c == null) {
return;
}
final double r = c.getRed() / 255.0; final double r = c.getRed() / 255.0;
final double g = c.getGreen() / 255.0; final double g = c.getGreen() / 255.0;
final double b = c.getBlue() / 255.0; final double b = c.getBlue() / 255.0;

View File

@ -73,7 +73,7 @@ public class DateEventUtils {
"a character on a keyboard and seen it show up on their", "a character on a keyboard and seen it show up on their",
"own computer's screen right in front of them.\"", "\t\t\t\t\t\t\t\t\t\t<i>Steve Wozniak"); "own computer's screen right in front of them.\"", "\t\t\t\t\t\t\t\t\t\t<i>Steve Wozniak");
return TextBlockUtils.mergeTB(textBlock, getComment(asList, color), HorizontalAlignment.LEFT); return TextBlockUtils.mergeTB(textBlock, getComment(asList, color), HorizontalAlignment.LEFT);
} else if ("01-07".equals(today) || "01-08".equals(today)) { } else if ("01-07".equals(today)) {
return addCharlie(textBlock); return addCharlie(textBlock);
} }

View File

@ -28,11 +28,13 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18789 $
* *
*/ */
package net.sourceforge.plantuml.graphic; package net.sourceforge.plantuml.graphic;
import net.sourceforge.plantuml.StringUtils;
public enum HorizontalAlignment { public enum HorizontalAlignment {
LEFT, CENTER, RIGHT; LEFT, CENTER, RIGHT;
@ -50,4 +52,19 @@ public enum HorizontalAlignment {
return null; return null;
} }
public static HorizontalAlignment fromString(String s, HorizontalAlignment defaultValue) {
if (defaultValue == null) {
throw new IllegalArgumentException();
}
if (s == null) {
return defaultValue;
}
s = StringUtils.goUpperCase(s);
final HorizontalAlignment result = fromString(s);
if (result == null) {
return defaultValue;
}
return result;
}
} }

View File

@ -162,13 +162,13 @@ public class QuoteUtils {
"Take it easy, don't push the little button on the joystick!", // "Take it easy, don't push the little button on the joystick!", //
"I'm a very private person.", // "I'm a very private person.", //
"To sculpt an elephant from a big block of marble, just knock away all the bits that don't look like an elephant.", // "To sculpt an elephant from a big block of marble, just knock away all the bits that don't look like an elephant.", //
"Who said you could talk to me? Have I got something on my face ?" "Who said you could talk to me? Have I got something on my face ?", //
"We've been through worst", //
"United we stand", //
"We shall never surrender", //
"Absolute honesty isn't always the most diplomatic nor the safest form of communication with emotional beings.", //
"Humor: seventy-five percent. [Confirmed] Self destruct sequence in T minus 10, 9... " //
); );
// We've been through worst
// United we stand
// We shall never surrender
// Absolute honesty isn't always the most diplomatic nor the safest form of communication with emotional beings.
// Humor: seventy-five percent. [Confirmed] Self destruct sequence in T minus 10, 9...
private QuoteUtils() { private QuoteUtils() {
} }

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18309 $
* *
*/ */
package net.sourceforge.plantuml.graphic; package net.sourceforge.plantuml.graphic;
@ -40,9 +40,9 @@ import java.util.List;
import net.sourceforge.plantuml.Dimension2DDouble; import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.SpriteContainer; import net.sourceforge.plantuml.SpriteContainer;
import net.sourceforge.plantuml.Url; import net.sourceforge.plantuml.Url;
import net.sourceforge.plantuml.ugraphic.Sprite;
import net.sourceforge.plantuml.ugraphic.UGraphic; import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UTranslate; import net.sourceforge.plantuml.ugraphic.UTranslate;
import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
class SingleLine extends AbstractTextBlock implements Line { class SingleLine extends AbstractTextBlock implements Line {

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18317 $
* *
*/ */
package net.sourceforge.plantuml.graphic; package net.sourceforge.plantuml.graphic;
@ -41,8 +41,9 @@ import java.util.List;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
import net.sourceforge.plantuml.command.regex.MyPattern;
import net.sourceforge.plantuml.StringUtils; import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.command.regex.MyPattern;
import net.sourceforge.plantuml.ugraphic.sprite.SpriteUtils;
public class Splitter { public class Splitter {
@ -58,8 +59,8 @@ public class Splitter {
public static final String fontFamilyPattern = "\\<font[\\s:]+([^>]+)/?\\>"; public static final String fontFamilyPattern = "\\<font[\\s:]+([^>]+)/?\\>";
public static final String svgAttributePattern = "\\<text[\\s:]+([^>]+)/?\\>"; public static final String svgAttributePattern = "\\<text[\\s:]+([^>]+)/?\\>";
public static final String openiconPattern = "\\<&([-\\w]+)\\>"; public static final String openiconPattern = "\\<&([-\\w]+)\\>";
public static final String spritePattern = "\\<\\$[\\p{L}0-9_]+\\>"; public static final String spritePattern = "\\<\\$" + SpriteUtils.SPRITE_NAME + "\\>";
public static final String spritePattern2 = "\\<\\$([\\p{L}0-9_]+)\\>"; public static final String spritePattern2 = "\\<\\$(" + SpriteUtils.SPRITE_NAME + ")\\>";
static final String htmlTag; static final String htmlTag;
static final String linkPattern = "\\[\\[([^\\[\\]]+)\\]\\]"; static final String linkPattern = "\\[\\[([^\\[\\]]+)\\]\\]";

View File

@ -35,11 +35,12 @@ package net.sourceforge.plantuml.graphic;
import java.awt.geom.Dimension2D; import java.awt.geom.Dimension2D;
import net.sourceforge.plantuml.svek.TextBlockBackcolored;
import net.sourceforge.plantuml.ugraphic.MinMax; import net.sourceforge.plantuml.ugraphic.MinMax;
import net.sourceforge.plantuml.ugraphic.UGraphic; import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UTranslate; import net.sourceforge.plantuml.ugraphic.UTranslate;
public class TextBlockRecentred extends AbstractTextBlock implements TextBlock { public class TextBlockRecentred extends AbstractTextBlock implements TextBlockBackcolored {
private final TextBlock textBlock; private final TextBlock textBlock;
@ -57,4 +58,8 @@ public class TextBlockRecentred extends AbstractTextBlock implements TextBlock {
return minMax.getDimension(); return minMax.getDimension();
} }
public HtmlColor getBackcolor() {
return ((TextBlockBackcolored) textBlock).getBackcolor();
}
} }

View File

@ -543,9 +543,7 @@ public class DotPath implements UShape, Moveable {
if (tail != null) { if (tail != null) {
// System.err.println("beziers1=" + this.toString()); // System.err.println("beziers1=" + this.toString());
final ClusterPosition clusterPosition = tail.getClusterPosition(); final ClusterPosition clusterPosition = tail.getClusterPosition();
if (clusterPosition.contains(getStartPoint()) == false) { if (clusterPosition.contains(getStartPoint())) {
throw new IllegalStateException();
}
final DotPath result = new DotPath(); final DotPath result = new DotPath();
int idx = 0; int idx = 0;
while (idx + 1 < this.beziers.size() && clusterPosition.contains(this.beziers.get(idx).getP2())) { while (idx + 1 < this.beziers.size() && clusterPosition.contains(this.beziers.get(idx).getP2())) {
@ -579,14 +577,12 @@ public class DotPath implements UShape, Moveable {
me = result; me = result;
} }
} }
}
if (head != null) { if (head != null) {
// System.err.println("beziers2=" + me.toString()); // System.err.println("beziers2=" + me.toString());
final DotPath result = new DotPath(); final DotPath result = new DotPath();
final ClusterPosition clusterPosition = head.getClusterPosition(); final ClusterPosition clusterPosition = head.getClusterPosition();
if (clusterPosition.contains(getEndPoint()) == false) { if (clusterPosition.contains(getEndPoint())) {
// System.err.println("strange3");
return me;
}
for (CubicCurve2D.Double current : me.beziers) { for (CubicCurve2D.Double current : me.beziers) {
if (clusterPosition.contains(current.getP2()) == false) { if (clusterPosition.contains(current.getP2()) == false) {
result.beziers.add(current); result.beziers.add(current);
@ -615,6 +611,7 @@ public class DotPath implements UShape, Moveable {
return result; return result;
} }
} }
}
} }
return me; return me;

View File

@ -39,9 +39,11 @@ import java.util.Map;
import net.sourceforge.plantuml.ISkinSimple; import net.sourceforge.plantuml.ISkinSimple;
import net.sourceforge.plantuml.SpriteContainer; import net.sourceforge.plantuml.SpriteContainer;
import net.sourceforge.plantuml.creole.CommandCreoleMonospaced; import net.sourceforge.plantuml.creole.CommandCreoleMonospaced;
import net.sourceforge.plantuml.graphic.HtmlColorSetSimple;
import net.sourceforge.plantuml.graphic.IHtmlColorSet;
import net.sourceforge.plantuml.salt.element.Element; import net.sourceforge.plantuml.salt.element.Element;
import net.sourceforge.plantuml.salt.element.WrappedElement; import net.sourceforge.plantuml.salt.element.WrappedElement;
import net.sourceforge.plantuml.ugraphic.Sprite; import net.sourceforge.plantuml.ugraphic.sprite.Sprite;
public class Dictionary implements SpriteContainer, ISkinSimple { public class Dictionary implements SpriteContainer, ISkinSimple {
@ -83,4 +85,8 @@ public class Dictionary implements SpriteContainer, ISkinSimple {
return 8; return 8;
} }
public IHtmlColorSet getIHtmlColorSet() {
return new HtmlColorSetSimple();
}
} }

View File

@ -54,6 +54,7 @@ import net.sourceforge.plantuml.core.DiagramDescription;
import net.sourceforge.plantuml.core.DiagramDescriptionImpl; import net.sourceforge.plantuml.core.DiagramDescriptionImpl;
import net.sourceforge.plantuml.core.ImageData; import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.SymbolContext; import net.sourceforge.plantuml.graphic.SymbolContext;
import net.sourceforge.plantuml.sequencediagram.graphic.FileMaker; import net.sourceforge.plantuml.sequencediagram.graphic.FileMaker;
@ -473,7 +474,7 @@ public class SequenceDiagram extends UmlDiagram {
return true; return true;
} }
} }
if (Display.isNull(getLegend()) == false && getLegend().hasUrl()) { if (DisplayPositionned.isNull(getLegend()) == false && getLegend().hasUrl()) {
return true; return true;
} }
return false; return false;

View File

@ -28,12 +28,17 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18280 $ * Revision $Revision: 18806 $
* *
*/ */
package net.sourceforge.plantuml.sequencediagram.graphic; package net.sourceforge.plantuml.sequencediagram.graphic;
import java.awt.geom.Dimension2D;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.TextBlockUtils;
import net.sourceforge.plantuml.png.PngTitler;
import net.sourceforge.plantuml.utils.MathUtils;
public class SequenceDiagramArea { public class SequenceDiagramArea {
@ -47,6 +52,9 @@ public class SequenceDiagramArea {
private double titleWidth; private double titleWidth;
private double titleHeight; private double titleHeight;
private double captionWidth;
private double captionHeight;
private double footerWidth; private double footerWidth;
private double footerHeight; private double footerHeight;
private double footerMargin; private double footerMargin;
@ -56,9 +64,18 @@ public class SequenceDiagramArea {
this.sequenceHeight = height; this.sequenceHeight = height;
} }
public void setTitleArea(double titleWidth, double titleHeight) { public void setTitleArea(double width, double height) {
this.titleWidth = titleWidth; this.titleWidth = width;
this.titleHeight = titleHeight; this.titleHeight = height;
}
private void setCaptionArea(double width, double height) {
this.captionWidth = width;
this.captionHeight = height;
}
public void setCaptionArea(Dimension2D dim) {
setCaptionArea(dim.getWidth(), dim.getHeight());
} }
public void setHeaderArea(double headerWidth, double headerHeight, double headerMargin) { public void setHeaderArea(double headerWidth, double headerHeight, double headerMargin) {
@ -74,21 +91,11 @@ public class SequenceDiagramArea {
} }
public double getWidth() { public double getWidth() {
double result = sequenceWidth; return MathUtils.max(sequenceWidth, headerWidth, titleWidth, footerWidth, captionWidth);
if (headerWidth > result) {
result = headerWidth;
}
if (titleWidth > result) {
result = titleWidth;
}
if (footerWidth > result) {
result = footerWidth;
}
return result;
} }
public double getHeight() { public double getHeight() {
return sequenceHeight + headerHeight + headerMargin + titleHeight + footerMargin + footerHeight; return sequenceHeight + headerHeight + headerMargin + titleHeight + footerMargin + footerHeight + captionHeight;
} }
public double getTitleX() { public double getTitleX() {
@ -99,6 +106,14 @@ public class SequenceDiagramArea {
return headerHeight + headerMargin; return headerHeight + headerMargin;
} }
public double getCaptionX() {
return (getWidth() - captionWidth) / 2;
}
public double getCaptionY() {
return sequenceHeight + headerHeight + headerMargin + titleHeight;
}
public double getSequenceAreaX() { public double getSequenceAreaX() {
return (getWidth() - sequenceWidth) / 2; return (getWidth() - sequenceWidth) / 2;
} }
@ -112,7 +127,7 @@ public class SequenceDiagramArea {
} }
public double getFooterY() { public double getFooterY() {
return sequenceHeight + headerHeight + headerMargin + titleHeight + footerMargin; return sequenceHeight + headerHeight + headerMargin + titleHeight + footerMargin + captionHeight;
} }
public double getFooterX(HorizontalAlignment align) { public double getFooterX(HorizontalAlignment align) {
@ -141,4 +156,18 @@ public class SequenceDiagramArea {
throw new IllegalStateException(); throw new IllegalStateException();
} }
public void initFooter(PngTitler pngTitler) {
final Dimension2D dim = pngTitler.getTextDimension(TextBlockUtils.getDummyStringBounder());
if (dim != null) {
setFooterArea(dim.getWidth(), dim.getHeight(), 3);
}
}
public void initHeader(PngTitler pngTitler) {
final Dimension2D dim = pngTitler.getTextDimension(TextBlockUtils.getDummyStringBounder());
if (dim != null) {
setHeaderArea(dim.getWidth(), dim.getHeight(), 3);
}
}
} }

View File

@ -41,12 +41,14 @@ import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import net.sourceforge.plantuml.AnnotatedWorker;
import net.sourceforge.plantuml.Dimension2DDouble; import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.FileFormatOption; import net.sourceforge.plantuml.FileFormatOption;
import net.sourceforge.plantuml.FontParam; import net.sourceforge.plantuml.FontParam;
import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend; import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend;
import net.sourceforge.plantuml.core.ImageData; import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
@ -117,7 +119,8 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
for (Newpage n : newpages) { for (Newpage n : newpages) {
positions.put(n, initializer.getYposition(dummyStringBounder, n)); positions.put(n, initializer.getYposition(dummyStringBounder, n));
} }
pages = create(drawableSet, positions, sequenceDiagram.isShowFootbox(), sequenceDiagram.getTitle()).getPages(); pages = create(drawableSet, positions, sequenceDiagram.isShowFootbox(), sequenceDiagram.getTitle().getDisplay())
.getPages();
} }
public int getNbPages() { public int getNbPages() {
@ -144,6 +147,9 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
final SequenceDiagramArea area = new SequenceDiagramArea(fullDimension.getWidth(), page.getHeight()); final SequenceDiagramArea area = new SequenceDiagramArea(fullDimension.getWidth(), page.getHeight());
final Component compTitle; final Component compTitle;
final TextBlock caption = new AnnotatedWorker(diagram, diagram.getSkinParam()).getCaption();
area.setCaptionArea(caption.calculateDimension(dummyStringBounder));
if (Display.isNull(page.getTitle())) { if (Display.isNull(page.getTitle())) {
compTitle = null; compTitle = null;
} else { } else {
@ -152,17 +158,15 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
area.setTitleArea(compTitle.getPreferredWidth(dummyStringBounder), area.setTitleArea(compTitle.getPreferredWidth(dummyStringBounder),
compTitle.getPreferredHeight(dummyStringBounder)); compTitle.getPreferredHeight(dummyStringBounder));
} }
addFooter2(area); area.initFooter(getPngTitler(FontParam.FOOTER));
addHeader2(area); area.initHeader(getPngTitler(FontParam.HEADER));
// final FileFormat fileFormat = fileFormatOption.getFileFormat(); final DisplayPositionned legend = diagram.getLegend();
final Display legend = diagram.getLegend();
final TextBlock legendBlock; final TextBlock legendBlock;
if (Display.isNull(legend)) { if (DisplayPositionned.isNull(legend)) {
legendBlock = TextBlockUtils.empty(0, 0); legendBlock = TextBlockUtils.empty(0, 0);
} else { } else {
legendBlock = EntityImageLegend.create(legend, diagram.getSkinParam()); legendBlock = EntityImageLegend.create(legend.getDisplay(), diagram.getSkinParam());
} }
final Dimension2D dimLegend = TextBlockUtils.getDimension(legendBlock); final Dimension2D dimLegend = TextBlockUtils.getDimension(legendBlock);
@ -198,11 +202,12 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
compTitle.drawU(ug.apply(new UTranslate(area.getTitleX(), area.getTitleY())), new Area( compTitle.drawU(ug.apply(new UTranslate(area.getTitleX(), area.getTitleY())), new Area(
new Dimension2DDouble(w, h)), new SimpleContext2D(false)); new Dimension2DDouble(w, h)), new SimpleContext2D(false));
} }
caption.drawU(ug.apply(new UTranslate(area.getCaptionX(), area.getCaptionY())));
final double delta1 = Math.max(0, dimLegend.getWidth() - area.getWidth()); final double delta1 = Math.max(0, dimLegend.getWidth() - area.getWidth());
final boolean legendTop = Display.isNull(legend) == false final boolean legendTop = DisplayPositionned.isNull(legend) == false
&& diagram.getLegendVerticalAlignment() == VerticalAlignment.TOP; && legend.getVerticalAlignment() == VerticalAlignment.TOP;
double sequenceAreaY = area.getSequenceAreaY(); double sequenceAreaY = area.getSequenceAreaY();
if (legendTop) { if (legendTop) {
@ -211,14 +216,14 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
drawableSet.drawU22(ug.apply(new UTranslate(area.getSequenceAreaX() + delta1 / 2, sequenceAreaY)), drawableSet.drawU22(ug.apply(new UTranslate(area.getSequenceAreaX() + delta1 / 2, sequenceAreaY)),
delta, fullDimension.getWidth(), page, diagram.isShowFootbox()); delta, fullDimension.getWidth(), page, diagram.isShowFootbox());
addHeader3(area, ug); drawHeader(area, ug);
addFooter3(area, ug); drawFooter(area, ug);
if (Display.isNull(legend) == false) { if (DisplayPositionned.isNull(legend) == false) {
final double delta2; final double delta2;
if (diagram.getLegendAlignment() == HorizontalAlignment.LEFT) { if (legend.getHorizontalAlignment() == HorizontalAlignment.LEFT) {
delta2 = 0; delta2 = 0;
} else if (diagram.getLegendAlignment() == HorizontalAlignment.RIGHT) { } else if (legend.getHorizontalAlignment() == HorizontalAlignment.RIGHT) {
delta2 = Math.max(0, area.getWidth() - dimLegend.getWidth()); delta2 = Math.max(0, area.getWidth() - dimLegend.getWidth());
} else { } else {
delta2 = Math.max(0, area.getWidth() - dimLegend.getWidth()) / 2; delta2 = Math.max(0, area.getWidth() - dimLegend.getWidth()) / 2;
@ -232,6 +237,26 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
return imageBuilder.writeImageTOBEMOVED(fileFormatOption, os); return imageBuilder.writeImageTOBEMOVED(fileFormatOption, os);
} }
private void drawFooter(SequenceDiagramArea area, UGraphic ug) {
final PngTitler pngTitler = getPngTitler(FontParam.FOOTER);
final TextBlock text = pngTitler.getTextBlock();
if (text == null) {
return;
}
text.drawU(ug.apply(new UTranslate(area.getFooterX(diagram.getFooter().getHorizontalAlignment()), area
.getFooterY())));
}
private void drawHeader(SequenceDiagramArea area, UGraphic ug) {
final PngTitler pngTitler = getPngTitler(FontParam.HEADER);
final TextBlock text = pngTitler.getTextBlock();
if (text == null) {
return;
}
text.drawU(ug.apply(new UTranslate(area.getHeaderX(diagram.getHeader().getHorizontalAlignment()), area
.getHeaderY())));
}
private double oneOf(double a, double b) { private double oneOf(double a, double b) {
if (a == 1) { if (a == 1) {
return b; return b;
@ -259,58 +284,14 @@ public class SequenceDiagramFileMakerPuma2 implements FileMaker {
return diagram.getScale().getScale(width, height); return diagram.getScale().getScale(width, height);
} }
private void addFooter2(SequenceDiagramArea area) { private PngTitler getPngTitler(final FontParam fontParam) {
final HtmlColor hyperlinkColor = diagram.getSkinParam().getHyperlinkColor(); final HtmlColor hyperlinkColor = diagram.getSkinParam().getHyperlinkColor();
final HtmlColor titleColor = diagram.getSkinParam().getFontHtmlColor(null, FontParam.FOOTER); final HtmlColor titleColor = diagram.getSkinParam().getFontHtmlColor(null, fontParam);
final String fontFamily = diagram.getSkinParam().getFont(null, false, FontParam.FOOTER).getFamily(null); final String fontFamily = diagram.getSkinParam().getFont(null, false, fontParam).getFamily(null);
final int fontSize = diagram.getSkinParam().getFont(null, false, FontParam.FOOTER).getSize(); final int fontSize = diagram.getSkinParam().getFont(null, false, fontParam).getSize();
final PngTitler pngTitler = new PngTitler(titleColor, diagram.getFooter(), fontSize, fontFamily, return new PngTitler(titleColor, diagram.getFooterOrHeaderTeoz(fontParam).getDisplay(), fontSize, fontFamily,
diagram.getFooterAlignment(), hyperlinkColor, diagram.getSkinParam().useUnderlineForHyperlink()); diagram.getFooterOrHeaderTeoz(fontParam).getHorizontalAlignment(), hyperlinkColor, diagram
final Dimension2D dim = pngTitler.getTextDimension(dummyStringBounder); .getSkinParam().useUnderlineForHyperlink());
if (dim != null) {
area.setFooterArea(dim.getWidth(), dim.getHeight(), 3);
}
}
private void addHeader2(SequenceDiagramArea area) {
final HtmlColor hyperlinkColor = diagram.getSkinParam().getHyperlinkColor();
final HtmlColor titleColor = diagram.getSkinParam().getFontHtmlColor(null, FontParam.HEADER);
final String fontFamily = diagram.getSkinParam().getFont(null, false, FontParam.HEADER).getFamily(null);
final int fontSize = diagram.getSkinParam().getFont(null, false, FontParam.HEADER).getSize();
final PngTitler pngTitler = new PngTitler(titleColor, diagram.getHeader(), fontSize, fontFamily,
diagram.getHeaderAlignment(), hyperlinkColor, diagram.getSkinParam().useUnderlineForHyperlink());
final Dimension2D dim = pngTitler.getTextDimension(dummyStringBounder);
if (dim != null) {
area.setHeaderArea(dim.getWidth(), dim.getHeight(), 3);
}
}
private void addFooter3(SequenceDiagramArea area, UGraphic ug) {
final HtmlColor hyperlinkColor = diagram.getSkinParam().getHyperlinkColor();
final HtmlColor titleColor = diagram.getSkinParam().getFontHtmlColor(null, FontParam.FOOTER);
final String fontFamily = diagram.getSkinParam().getFont(null, false, FontParam.FOOTER).getFamily(null);
final int fontSize = diagram.getSkinParam().getFont(null, false, FontParam.FOOTER).getSize();
final PngTitler pngTitler = new PngTitler(titleColor, diagram.getFooter(), fontSize, fontFamily,
diagram.getFooterAlignment(), hyperlinkColor, diagram.getSkinParam().useUnderlineForHyperlink());
final TextBlock text = pngTitler.getTextBlock();
if (text == null) {
return;
}
text.drawU(ug.apply(new UTranslate(area.getFooterX(diagram.getFooterAlignment()), area.getFooterY())));
}
private void addHeader3(SequenceDiagramArea area, UGraphic ug) {
final HtmlColor hyperlinkColor = diagram.getSkinParam().getHyperlinkColor();
final HtmlColor titleColor = diagram.getSkinParam().getFontHtmlColor(null, FontParam.HEADER);
final String fontFamily = diagram.getSkinParam().getFont(null, false, FontParam.HEADER).getFamily(null);
final int fontSize = diagram.getSkinParam().getFont(null, false, FontParam.HEADER).getSize();
final PngTitler pngTitler = new PngTitler(titleColor, diagram.getHeader(), fontSize, fontFamily,
diagram.getHeaderAlignment(), hyperlinkColor, diagram.getSkinParam().useUnderlineForHyperlink());
final TextBlock text = pngTitler.getTextBlock();
if (text == null) {
return;
}
text.drawU(ug.apply(new UTranslate(area.getHeaderX(diagram.getHeaderAlignment()), area.getHeaderY())));
} }
} }

View File

@ -41,11 +41,11 @@ import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.FileFormatOption; import net.sourceforge.plantuml.FileFormatOption;
import net.sourceforge.plantuml.FontParam; import net.sourceforge.plantuml.FontParam;
import net.sourceforge.plantuml.ISkinParam; import net.sourceforge.plantuml.ISkinParam;
import net.sourceforge.plantuml.Scale;
import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend; import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend;
import net.sourceforge.plantuml.api.ImageDataSimple; import net.sourceforge.plantuml.api.ImageDataSimple;
import net.sourceforge.plantuml.core.ImageData; import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.cucadiagram.Display; import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.DisplayPositionned;
import net.sourceforge.plantuml.graphic.HorizontalAlignment; import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
@ -131,14 +131,14 @@ public class SequenceDiagramFileMakerTeoz implements FileMaker {
englobers.drawEnglobers(goDownForEnglobers(ug), main.calculateDimension(stringBounder).getHeight() englobers.drawEnglobers(goDownForEnglobers(ug), main.calculateDimension(stringBounder).getHeight()
+ this.heightEnglober1 + this.heightEnglober2 / 2, new SimpleContext2D(true)); + this.heightEnglober1 + this.heightEnglober2 / 2, new SimpleContext2D(true));
printAligned(ug, diagram.getAlignmentTeoz(FontParam.HEADER), header); printAligned(ug, diagram.getFooterOrHeaderTeoz(FontParam.HEADER).getHorizontalAlignment(), header);
ug = goDown(ug, header); ug = goDown(ug, header);
printAligned(ug, HorizontalAlignment.CENTER, title); printAligned(ug, HorizontalAlignment.CENTER, title);
ug = goDown(ug, title); ug = goDown(ug, title);
if (diagram.getLegendVerticalAlignment() == VerticalAlignment.TOP) { if (diagram.getLegend().getVerticalAlignment() == VerticalAlignment.TOP) {
printAligned(ug, diagram.getLegendAlignment(), legend); printAligned(ug, diagram.getLegend().getHorizontalAlignment(), legend);
ug = goDown(ug, legend); ug = goDown(ug, legend);
} }
@ -147,12 +147,12 @@ public class SequenceDiagramFileMakerTeoz implements FileMaker {
ug = goDown(ug, main); ug = goDown(ug, main);
ug = ug.apply(new UTranslate(0, this.heightEnglober2)); ug = ug.apply(new UTranslate(0, this.heightEnglober2));
if (diagram.getLegendVerticalAlignment() == VerticalAlignment.BOTTOM) { if (diagram.getLegend().getVerticalAlignment() == VerticalAlignment.BOTTOM) {
printAligned(ug, diagram.getLegendAlignment(), legend); printAligned(ug, diagram.getLegend().getHorizontalAlignment(), legend);
ug = goDown(ug, legend); ug = goDown(ug, legend);
} }
printAligned(ug, diagram.getAlignmentTeoz(FontParam.FOOTER), footer); printAligned(ug, diagram.getFooterOrHeaderTeoz(FontParam.FOOTER).getHorizontalAlignment(), footer);
ug2.writeImageTOBEMOVED(os, isWithMetadata ? diagram.getMetadata() : null, diagram.getDpi(fileFormatOption)); ug2.writeImageTOBEMOVED(os, isWithMetadata ? diagram.getMetadata() : null, diagram.getDpi(fileFormatOption));
@ -162,7 +162,7 @@ public class SequenceDiagramFileMakerTeoz implements FileMaker {
private UGraphic goDownForEnglobers(UGraphic ug) { private UGraphic goDownForEnglobers(UGraphic ug) {
ug = goDown(ug, title); ug = goDown(ug, title);
ug = goDown(ug, header); ug = goDown(ug, header);
if (diagram.getLegendVerticalAlignment() == VerticalAlignment.TOP) { if (diagram.getLegend().getVerticalAlignment() == VerticalAlignment.TOP) {
ug = goDown(ug, legend); ug = goDown(ug, legend);
} }
return ug; return ug;
@ -210,16 +210,16 @@ public class SequenceDiagramFileMakerTeoz implements FileMaker {
} }
private TextBlock getTitle() { private TextBlock getTitle() {
final Display title = diagram.getTitle(); if (DisplayPositionned.isNull(diagram.getTitle())) {
if (Display.isNull(title)) {
return new ComponentAdapter(null); return new ComponentAdapter(null);
} }
final Component compTitle = skin.createComponent(ComponentType.TITLE, null, getSkinParam(), title); final Component compTitle = skin.createComponent(ComponentType.TITLE, null, getSkinParam(), diagram.getTitle()
.getDisplay());
return new ComponentAdapter(compTitle); return new ComponentAdapter(compTitle);
} }
private TextBlock getLegend() { private TextBlock getLegend() {
final Display legend = diagram.getLegend(); final Display legend = diagram.getLegend().getDisplay();
if (Display.isNull(legend)) { if (Display.isNull(legend)) {
return TextBlockUtils.empty(0, 0); return TextBlockUtils.empty(0, 0);
} }
@ -227,16 +227,17 @@ public class SequenceDiagramFileMakerTeoz implements FileMaker {
} }
public TextBlock getFooterOrHeader(final FontParam param) { public TextBlock getFooterOrHeader(final FontParam param) {
final Display display = diagram.getFooterOrHeaderTeoz(param); if (DisplayPositionned.isNull(diagram.getFooterOrHeaderTeoz(param))) {
if (Display.isNull(display)) {
return new TeozLayer(null, stringBounder, param); return new TeozLayer(null, stringBounder, param);
} }
final Display display = diagram.getFooterOrHeaderTeoz(param).getDisplay();
final HtmlColor hyperlinkColor = getSkinParam().getHyperlinkColor(); final HtmlColor hyperlinkColor = getSkinParam().getHyperlinkColor();
final HtmlColor titleColor = getSkinParam().getFontHtmlColor(null, param); final HtmlColor titleColor = getSkinParam().getFontHtmlColor(null, param);
final String fontFamily = getSkinParam().getFont(null, false, param).getFamily(null); final String fontFamily = getSkinParam().getFont(null, false, param).getFamily(null);
final int fontSize = getSkinParam().getFont(null, false, param).getSize(); final int fontSize = getSkinParam().getFont(null, false, param).getSize();
final PngTitler pngTitler = new PngTitler(titleColor, display, fontSize, fontFamily, final PngTitler pngTitler = new PngTitler(titleColor, display, fontSize, fontFamily, diagram
diagram.getAlignmentTeoz(param), hyperlinkColor, getSkinParam().useUnderlineForHyperlink()); .getFooterOrHeaderTeoz(param).getHorizontalAlignment(), hyperlinkColor, getSkinParam()
.useUnderlineForHyperlink());
return new TeozLayer(pngTitler, stringBounder, param); return new TeozLayer(pngTitler, stringBounder, param);
} }

View File

@ -77,7 +77,7 @@ public class CommandLinkState extends SingleLineCommand2<StateDiagram> {
new RegexLeaf("[%s]*"), // new RegexLeaf("[%s]*"), //
getStatePattern("ENT2"), // getStatePattern("ENT2"), //
new RegexLeaf("[%s]*"), // new RegexLeaf("[%s]*"), //
new RegexLeaf("LABEL", "(?::[%s]*([^%g]+))?"), // new RegexLeaf("LABEL", "(?::[%s]*(.+))?"), //
new RegexLeaf("$")); new RegexLeaf("$"));
} }

View File

@ -40,29 +40,23 @@ import java.io.OutputStream;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.sourceforge.plantuml.AnnotatedWorker;
import net.sourceforge.plantuml.EmptyImageBuilder; import net.sourceforge.plantuml.EmptyImageBuilder;
import net.sourceforge.plantuml.FileFormat;
import net.sourceforge.plantuml.FileFormatOption; import net.sourceforge.plantuml.FileFormatOption;
import net.sourceforge.plantuml.FontParam; import net.sourceforge.plantuml.FontParam;
import net.sourceforge.plantuml.ISkinParam; import net.sourceforge.plantuml.ISkinParam;
import net.sourceforge.plantuml.Scale; import net.sourceforge.plantuml.Scale;
import net.sourceforge.plantuml.UmlDiagramType; import net.sourceforge.plantuml.UmlDiagramType;
import net.sourceforge.plantuml.activitydiagram3.ftile.EntityImageLegend;
import net.sourceforge.plantuml.core.ImageData; import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.cucadiagram.CucaDiagram; import net.sourceforge.plantuml.cucadiagram.CucaDiagram;
import net.sourceforge.plantuml.cucadiagram.Display;
import net.sourceforge.plantuml.cucadiagram.Link; import net.sourceforge.plantuml.cucadiagram.Link;
import net.sourceforge.plantuml.cucadiagram.Stereotype; import net.sourceforge.plantuml.cucadiagram.Stereotype;
import net.sourceforge.plantuml.cucadiagram.dot.CucaDiagramSimplifierActivity; import net.sourceforge.plantuml.cucadiagram.dot.CucaDiagramSimplifierActivity;
import net.sourceforge.plantuml.cucadiagram.dot.CucaDiagramSimplifierState; import net.sourceforge.plantuml.cucadiagram.dot.CucaDiagramSimplifierState;
import net.sourceforge.plantuml.cucadiagram.dot.DotData; import net.sourceforge.plantuml.cucadiagram.dot.DotData;
import net.sourceforge.plantuml.graphic.FontConfiguration;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.StringBounderUtils; import net.sourceforge.plantuml.graphic.StringBounderUtils;
import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.graphic.TextBlockUtils;
import net.sourceforge.plantuml.ugraphic.ImageBuilder; import net.sourceforge.plantuml.ugraphic.ImageBuilder;
import net.sourceforge.plantuml.ugraphic.UFont; import net.sourceforge.plantuml.ugraphic.UFont;
@ -116,9 +110,7 @@ public final class CucaDiagramFileMakerSvek implements CucaDiagramFileMaker {
svek2 = buildCucaDiagramFileMakerSvek2(DotMode.NO_LEFT_RIGHT); svek2 = buildCucaDiagramFileMakerSvek2(DotMode.NO_LEFT_RIGHT);
result = svek2.createFile(diagram.getDotStringSkek()); result = svek2.createFile(diagram.getDotStringSkek());
} }
result = addLegend(result); result = new AnnotatedWorker(diagram, diagram.getSkinParam()).addAdd(result);
result = addTitle(result);
result = addHeaderAndFooter(result);
final String widthwarning = diagram.getSkinParam().getValue("widthwarning"); final String widthwarning = diagram.getSkinParam().getValue("widthwarning");
if (widthwarning != null && widthwarning.matches("\\d+")) { if (widthwarning != null && widthwarning.matches("\\d+")) {
@ -169,45 +161,6 @@ public final class CucaDiagramFileMakerSvek implements CucaDiagramFileMaker {
return warningOrError; return warningOrError;
} }
private TextBlockBackcolored addHeaderAndFooter(TextBlockBackcolored original) {
final Display footer = diagram.getFooter();
final Display header = diagram.getHeader();
if (Display.isNull(footer) && Display.isNull(header)) {
return original;
}
final TextBlock textFooter = Display.isNull(footer) ? null : footer.create(
new FontConfiguration(diagram.getSkinParam(), FontParam.FOOTER, null), diagram.getFooterAlignment(),
diagram.getSkinParam());
final TextBlock textHeader = Display.isNull(header) ? null : header.create(
new FontConfiguration(diagram.getSkinParam(), FontParam.HEADER, null), diagram.getHeaderAlignment(),
diagram.getSkinParam());
return new DecorateEntityImage(original, textHeader, diagram.getHeaderAlignment(), textFooter,
diagram.getFooterAlignment());
}
private TextBlockBackcolored addTitle(TextBlockBackcolored original) {
final Display title = diagram.getTitle();
if (Display.isNull(title)) {
return original;
}
final TextBlock text = title.create(new FontConfiguration(diagram.getSkinParam(), FontParam.TITLE, null),
HorizontalAlignment.CENTER, diagram.getSkinParam());
return DecorateEntityImage.addTop(original, text, HorizontalAlignment.CENTER);
}
private TextBlockBackcolored addLegend(TextBlockBackcolored original) {
final Display legend = diagram.getLegend();
if (Display.isNull(legend)) {
return original;
}
final TextBlock text = EntityImageLegend.create(legend, diagram.getSkinParam());
return DecorateEntityImage.add(original, text, diagram.getLegendAlignment(),
diagram.getLegendVerticalAlignment());
}
private final UFont getFont(FontParam fontParam) { private final UFont getFont(FontParam fontParam) {
final ISkinParam skinParam = diagram.getSkinParam(); final ISkinParam skinParam = diagram.getSkinParam();
return skinParam.getFont(null, false, fontParam); return skinParam.getFont(null, false, fontParam);

View File

@ -1,136 +0,0 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 4236 $
*
*/
package net.sourceforge.plantuml.svek;
import java.awt.geom.Dimension2D;
import net.sourceforge.plantuml.Dimension2DDouble;
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UTranslate;
public class DecorateTextBlock extends AbstractTextBlock implements TextBlock {
private final TextBlock original;
private final HorizontalAlignment horizontal1;
private final TextBlock text1;
private final HorizontalAlignment horizontal2;
private final TextBlock text2;
private double deltaX;
private double deltaY;
public DecorateTextBlock(TextBlock original, TextBlock text, HorizontalAlignment horizontal) {
this(original, text, horizontal, null, null);
}
public DecorateTextBlock(TextBlock original, TextBlock text1, HorizontalAlignment horizontal1, TextBlock text2,
HorizontalAlignment horizontal2) {
this.original = original;
this.horizontal1 = horizontal1;
this.text1 = text1;
this.horizontal2 = horizontal2;
this.text2 = text2;
}
public void drawU(UGraphic ug) {
final StringBounder stringBounder = ug.getStringBounder();
final Dimension2D dimOriginal = original.calculateDimension(stringBounder);
final Dimension2D dimText1 = getTextDim(text1, stringBounder);
final Dimension2D dimText2 = getTextDim(text2, stringBounder);
final Dimension2D dimTotal = calculateDimension(stringBounder);
final double yText1 = 0;
final double yImage = yText1 + dimText1.getHeight();
final double yText2 = yImage + dimOriginal.getHeight();
final double xImage = (dimTotal.getWidth() - dimOriginal.getWidth()) / 2;
if (text1 != null) {
final double xText1 = getTextX(dimText1, dimTotal, horizontal1);
text1.drawU(ug.apply(new UTranslate(xText1, yText1)));
}
original.drawU(ug.apply(new UTranslate(xImage, yImage)));
deltaX = xImage;
deltaY = yImage;
if (text2 != null) {
final double xText2 = getTextX(dimText2, dimTotal, horizontal2);
text2.drawU(ug.apply(new UTranslate(xText2, yText2)));
}
}
private Dimension2D getTextDim(TextBlock text, StringBounder stringBounder) {
if (text == null) {
return new Dimension2DDouble(0, 0);
}
return text.calculateDimension(stringBounder);
}
private double getTextX(final Dimension2D dimText, final Dimension2D dimTotal, HorizontalAlignment h) {
if (h == HorizontalAlignment.CENTER) {
return (dimTotal.getWidth() - dimText.getWidth()) / 2;
} else if (h == HorizontalAlignment.LEFT) {
return 0;
} else if (h == HorizontalAlignment.RIGHT) {
return dimTotal.getWidth() - dimText.getWidth();
} else {
throw new IllegalStateException();
}
}
public Dimension2D calculateDimension(StringBounder stringBounder) {
final Dimension2D dimOriginal = original.calculateDimension(stringBounder);
final Dimension2D dimText = Dimension2DDouble.mergeTB(getTextDim(text1, stringBounder),
getTextDim(text2, stringBounder));
return Dimension2DDouble.mergeTB(dimOriginal, dimText);
}
private double getDeltaX() {
if (original instanceof DecorateTextBlock) {
return deltaX + ((DecorateTextBlock) original).deltaX;
}
return deltaX;
}
private double getDeltaY() {
if (original instanceof DecorateTextBlock) {
return deltaY + ((DecorateTextBlock) original).deltaY;
}
return deltaY;
}
}

View File

@ -50,6 +50,7 @@ import net.sourceforge.plantuml.UmlDiagramType;
import net.sourceforge.plantuml.cucadiagram.IGroup; import net.sourceforge.plantuml.cucadiagram.IGroup;
import net.sourceforge.plantuml.cucadiagram.Rankdir; import net.sourceforge.plantuml.cucadiagram.Rankdir;
import net.sourceforge.plantuml.cucadiagram.dot.DotData; import net.sourceforge.plantuml.cucadiagram.dot.DotData;
import net.sourceforge.plantuml.cucadiagram.dot.DotSplines;
import net.sourceforge.plantuml.cucadiagram.dot.Graphviz; import net.sourceforge.plantuml.cucadiagram.dot.Graphviz;
import net.sourceforge.plantuml.cucadiagram.dot.GraphvizUtils; import net.sourceforge.plantuml.cucadiagram.dot.GraphvizUtils;
import net.sourceforge.plantuml.cucadiagram.dot.GraphvizVersion; import net.sourceforge.plantuml.cucadiagram.dot.GraphvizVersion;
@ -166,6 +167,15 @@ public class DotStringFactory implements Moveable {
SvekUtils.println(sb); SvekUtils.println(sb);
} }
final DotSplines dotSplines = dotData.getSkinParam().getDotSplines();
if (dotSplines == DotSplines.POLYLINE) {
sb.append("splines=polyline;");
SvekUtils.println(sb);
} else if (dotSplines == DotSplines.ORTHO) {
sb.append("splines=ortho;");
SvekUtils.println(sb);
}
if (dotData.getSkinParam().getRankdir() == Rankdir.LEFT_TO_RIGHT) { if (dotData.getSkinParam().getRankdir() == Rankdir.LEFT_TO_RIGHT) {
sb.append("rankdir=LR;"); sb.append("rankdir=LR;");
SvekUtils.println(sb); SvekUtils.println(sb);

View File

@ -85,7 +85,6 @@ import net.sourceforge.plantuml.ugraphic.UPolygon;
import net.sourceforge.plantuml.ugraphic.UShape; import net.sourceforge.plantuml.ugraphic.UShape;
import net.sourceforge.plantuml.ugraphic.UStroke; import net.sourceforge.plantuml.ugraphic.UStroke;
import net.sourceforge.plantuml.ugraphic.UTranslate; import net.sourceforge.plantuml.ugraphic.UTranslate;
import net.sourceforge.plantuml.utils.MathUtils;
public class Line implements Moveable, Hideable { public class Line implements Moveable, Hideable {
@ -323,7 +322,7 @@ public class Line implements Moveable, Hideable {
sb.append(endUid); sb.append(endUid);
// } // }
sb.append("["); sb.append("[");
final LinkType linkType = link.getType(); final LinkType linkType = link.getTypePatchCluster();
String decoration = linkType.getSpecificDecorationSvek(); String decoration = linkType.getSpecificDecorationSvek();
if (decoration.endsWith(",") == false) { if (decoration.endsWith(",") == false) {
decoration += ","; decoration += ",";
@ -435,7 +434,7 @@ public class Line implements Moveable, Hideable {
} }
private UDrawable getExtremity(LinkHat hat, LinkDecor decor, PointListIterator pointListIterator, Point2D center, private UDrawable getExtremity(LinkHat hat, LinkDecor decor, PointListIterator pointListIterator, Point2D center,
double angle, Cluster cluster) { double angle, Cluster cluster, boolean isGroup) {
final ExtremityFactory extremityFactory = decor.getExtremityFactory(); final ExtremityFactory extremityFactory = decor.getExtremityFactory();
if (OptionFlags.USE_COMPOUND == false && cluster != null) { if (OptionFlags.USE_COMPOUND == false && cluster != null) {
@ -480,6 +479,7 @@ public class Line implements Moveable, Hideable {
} }
final int end = svg.indexOf("\"", idx + 3); final int end = svg.indexOf("\"", idx + 3);
final String path = svg.substring(idx + 3, end); final String path = svg.substring(idx + 3, end);
dotPath = new DotPath(path, fullHeight); dotPath = new DotPath(path, fullHeight);
if (OptionFlags.USE_COMPOUND == false) { if (OptionFlags.USE_COMPOUND == false) {
if (projectionCluster != null) { if (projectionCluster != null) {
@ -498,9 +498,9 @@ public class Line implements Moveable, Hideable {
final LinkType linkType = link.getType(); final LinkType linkType = link.getType();
this.extremity2 = getExtremity(linkType.getHat2(), linkType.getDecor2(), pointListIterator, this.extremity2 = getExtremity(linkType.getHat2(), linkType.getDecor2(), pointListIterator,
dotPath.getStartPoint(), dotPath.getStartAngle() + Math.PI, ltail); dotPath.getStartPoint(), dotPath.getStartAngle() + Math.PI, ltail, link.getEntity1().isGroup());
this.extremity1 = getExtremity(linkType.getHat1(), linkType.getDecor1(), pointListIterator, this.extremity1 = getExtremity(linkType.getHat1(), linkType.getDecor1(), pointListIterator,
dotPath.getEndPoint(), dotPath.getEndAngle(), lhead); dotPath.getEndPoint(), dotPath.getEndAngle(), lhead, link.getEntity2().isGroup());
if (this.labelText != null) { if (this.labelText != null) {
final Point2D pos = getXY(svg, this.noteLabelColor, fullHeight); final Point2D pos = getXY(svg, this.noteLabelColor, fullHeight);

View File

@ -35,6 +35,7 @@ package net.sourceforge.plantuml.svek.extremity;
import java.awt.geom.Point2D; import java.awt.geom.Point2D;
import net.sourceforge.plantuml.graphic.HtmlColorUtils;
import net.sourceforge.plantuml.ugraphic.UChangeBackColor; import net.sourceforge.plantuml.ugraphic.UChangeBackColor;
import net.sourceforge.plantuml.ugraphic.UGraphic; import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UPolygon; import net.sourceforge.plantuml.ugraphic.UPolygon;
@ -61,6 +62,8 @@ class ExtremityDiamond extends Extremity {
public void drawU(UGraphic ug) { public void drawU(UGraphic ug) {
if (fill) { if (fill) {
ug = ug.apply(new UChangeBackColor(ug.getParam().getColor())); ug = ug.apply(new UChangeBackColor(ug.getParam().getColor()));
} else {
ug = ug.apply(new UChangeBackColor(HtmlColorUtils.WHITE));
} }
ug.draw(polygon); ug.draw(polygon);
} }

View File

@ -42,9 +42,15 @@ public class ExtremityFactoryDiamond extends AbstractExtremityFactory implements
private final boolean fill; private final boolean fill;
@Override
public UDrawable createUDrawable(Point2D p0, double angle) {
return new ExtremityDiamond(p0, angle - Math.PI / 2, fill);
}
public ExtremityFactoryDiamond(boolean fill) { public ExtremityFactoryDiamond(boolean fill) {
this.fill = fill; this.fill = fill;
} }
public UDrawable createUDrawable(Point2D p0, Point2D p1, Point2D p2) { public UDrawable createUDrawable(Point2D p0, Point2D p1, Point2D p2) {
final double ortho = atan2(p0, p2); final double ortho = atan2(p0, p2);
return new ExtremityDiamond(p1, ortho, fill); return new ExtremityDiamond(p1, ortho, fill);

View File

@ -40,8 +40,9 @@ import net.sourceforge.plantuml.svek.AbstractExtremityFactory;
public class ExtremityFactoryPlus extends AbstractExtremityFactory implements ExtremityFactory { public class ExtremityFactoryPlus extends AbstractExtremityFactory implements ExtremityFactory {
@Override
public UDrawable createUDrawable(Point2D center, double angle) { public UDrawable createUDrawable(Point2D center, double angle) {
return ExtremityPlus.create(center, angle + Math.PI / 2); return ExtremityPlus.create(center, angle - Math.PI / 2);
} }
public UDrawable createUDrawable(Point2D p0, Point2D p1, Point2D p2) { public UDrawable createUDrawable(Point2D p0, Point2D p1, Point2D p2) {

View File

@ -138,6 +138,9 @@ public class EntityImageTips extends AbstractEntityImage {
} else { } else {
x += 4; x += 4;
} }
if (memberPosition == null) {
return;
}
final double y = positionOther.getY() - positionMe.getY() - height + memberPosition.getCenterY(); final double y = positionOther.getY() - positionMe.getY() - height + memberPosition.getCenterY();
final Point2D pp2 = new Point2D.Double(x, y); final Point2D pp2 = new Point2D.Double(x, y);
opale.setOpale(position.reverseDirection(), pp1, pp2); opale.setOpale(position.reverseDirection(), pp1, pp2);

View File

@ -51,8 +51,8 @@ import javax.swing.SwingUtilities;
import javax.swing.Timer; import javax.swing.Timer;
import net.sourceforge.plantuml.Log; import net.sourceforge.plantuml.Log;
import net.sourceforge.plantuml.ugraphic.SpriteGrayLevel; import net.sourceforge.plantuml.ugraphic.sprite.SpriteGrayLevel;
import net.sourceforge.plantuml.ugraphic.SpriteUtils; import net.sourceforge.plantuml.ugraphic.sprite.SpriteUtils;
import net.sourceforge.plantuml.version.PSystemVersion; import net.sourceforge.plantuml.version.PSystemVersion;
public class SpriteWindow extends JFrame { public class SpriteWindow extends JFrame {

View File

@ -78,6 +78,7 @@ public class LanguageDescriptor {
keyword.add("as"); keyword.add("as");
keyword.add("also"); keyword.add("also");
keyword.add("autonumber"); keyword.add("autonumber");
keyword.add("caption");
keyword.add("title"); keyword.add("title");
keyword.add("newpage"); keyword.add("newpage");
keyword.add("box"); keyword.add("box");

View File

@ -0,0 +1,93 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 4041 $
*
*/
package net.sourceforge.plantuml.ugraphic.sprite;
import java.awt.Font;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import net.sourceforge.plantuml.AbstractPSystem;
import net.sourceforge.plantuml.FileFormatOption;
import net.sourceforge.plantuml.core.DiagramDescription;
import net.sourceforge.plantuml.core.DiagramDescriptionImpl;
import net.sourceforge.plantuml.core.ImageData;
import net.sourceforge.plantuml.graphic.GraphicStrings;
import net.sourceforge.plantuml.graphic.HtmlColorUtils;
import net.sourceforge.plantuml.ugraphic.ColorMapperIdentity;
import net.sourceforge.plantuml.ugraphic.ImageBuilder;
import net.sourceforge.plantuml.ugraphic.UAntiAliasing;
import net.sourceforge.plantuml.ugraphic.UFont;
public class PSystemListInternalSprites extends AbstractPSystem {
public ImageData exportDiagram(OutputStream os, int num, FileFormatOption fileFormat) throws IOException {
final GraphicStrings result = getGraphicStrings();
final ImageBuilder imageBuilder = new ImageBuilder(new ColorMapperIdentity(), 1.0, result.getBackcolor(),
getMetadata(), null, 0, 0, null, false);
imageBuilder.addUDrawable(result);
return imageBuilder.writeImageTOBEMOVED(fileFormat, os);
}
private GraphicStrings getGraphicStrings() throws IOException {
final List<String> lines = new ArrayList<String>();
lines.add("<b>List Current Sprits");
lines.add("<i>Credit to");
lines.add("http://www.archimatetool.com");
lines.add(" ");
for (String folder : RessourcesUtils.getJarFile("sprites", true)) {
lines.add("<u>" + folder + "</u> :");
lines.add(" ");
for (String png : RessourcesUtils.getJarFile("sprites/" + folder, false)) {
if (png.endsWith(".png")) {
final String spriteName = png.substring(0, png.length() - 4);
lines.add("<$archimate/" + spriteName + "> " + spriteName);
}
}
}
final UFont font = new UFont("SansSerif", Font.PLAIN, 12);
final GraphicStrings graphicStrings = new GraphicStrings(lines, font, HtmlColorUtils.BLACK,
HtmlColorUtils.WHITE, UAntiAliasing.ANTI_ALIASING_ON);
graphicStrings.setMaxLine(35);
return graphicStrings;
}
public DiagramDescription getDescription() {
return new DiagramDescriptionImpl("(Sprites)", getClass());
}
}

View File

@ -0,0 +1,51 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 3830 $
*
*/
package net.sourceforge.plantuml.ugraphic.sprite;
import net.sourceforge.plantuml.AbstractPSystem;
import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.command.PSystemSingleLineFactory;
public class PSystemListInternalSpritesFactory extends PSystemSingleLineFactory {
@Override
protected AbstractPSystem executeLine(String line) {
final String lineLower = StringUtils.goLowerCase(line);
if (lineLower.startsWith("listsprite")) {
return new PSystemListInternalSprites();
}
return null;
}
}

View File

@ -0,0 +1,117 @@
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2017, Arnaud Roques
*
* Project Info: http://plantuml.sourceforge.net
*
* 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
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* 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.
*
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
* in the United States and other countries.]
*
* Original Author: Arnaud Roques
*
* Revision $Revision: 3837 $
*
*/
package net.sourceforge.plantuml.ugraphic.sprite;
import java.io.File;
import java.io.IOException;
import java.net.URISyntaxException;
import java.net.URL;
import java.net.URLDecoder;
import java.util.Collections;
import java.util.Enumeration;
import java.util.Set;
import java.util.TreeSet;
import java.util.jar.JarEntry;
import java.util.jar.JarFile;
import net.sourceforge.plantuml.version.Version;
public class RessourcesUtils {
public static Set<String> getJarFile(String path, boolean folder) throws IOException {
if (path.startsWith("/") || path.endsWith("/")) {
throw new IllegalArgumentException();
}
final URL resource = Version.class.getClassLoader().getResource("net/sourceforge/plantuml/version/logo.png");
final String protocol = resource.getProtocol();
if ("file".equals(protocol)) {
final URL local = Version.class.getClassLoader().getResource(path);
try {
return listEntry(new File(local.toURI()));
} catch (URISyntaxException e) {
e.printStackTrace();
return null;
}
}
if ("jar".equals(protocol)) {
final String classFile = Version.class.getName().replace(".", "/") + ".class";
final URL versionURL = Version.class.getClassLoader().getResource(classFile);
final String jarPath = versionURL.getPath().substring(5, versionURL.getPath().indexOf("!"));
if (folder) {
return listFolders(new JarFile(URLDecoder.decode(jarPath, "UTF-8")), path + "/");
} else {
return listFiles(new JarFile(URLDecoder.decode(jarPath, "UTF-8")), path + "/");
}
}
return Collections.<String> emptySet();
}
private static Set<String> listFiles(JarFile jarFile, String path) {
final Enumeration<JarEntry> entries = jarFile.entries();
final Set<String> result = new TreeSet<String>();
while (entries.hasMoreElements()) {
final String name = entries.nextElement().getName();
if (name.startsWith(path)) {
result.add(name.substring(path.length()));
}
}
return result;
}
private static Set<String> listFolders(JarFile jarFile, String path) {
final Enumeration<JarEntry> entries = jarFile.entries();
final Set<String> result = new TreeSet<String>();
while (entries.hasMoreElements()) {
final String name = entries.nextElement().getName();
if (name.startsWith(path)) {
final String folder = name.substring(path.length());
final int x = folder.indexOf('/');
if (x != -1) {
result.add(folder.substring(0, x));
}
}
}
return result;
}
private static Set<String> listEntry(File dir) {
final Set<String> result = new TreeSet<String>();
for (String n : dir.list()) {
result.add(n);
}
return result;
}
}

View File

@ -31,7 +31,7 @@
* Revision $Revision: 3837 $ * Revision $Revision: 3837 $
* *
*/ */
package net.sourceforge.plantuml.ugraphic; package net.sourceforge.plantuml.ugraphic.sprite;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.TextBlock; import net.sourceforge.plantuml.graphic.TextBlock;

View File

@ -31,7 +31,7 @@
* Revision $Revision: 3837 $ * Revision $Revision: 3837 $
* *
*/ */
package net.sourceforge.plantuml.ugraphic; package net.sourceforge.plantuml.ugraphic.sprite;
import java.awt.Color; import java.awt.Color;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
@ -43,6 +43,7 @@ import java.util.List;
import net.sourceforge.plantuml.StringUtils; import net.sourceforge.plantuml.StringUtils;
import net.sourceforge.plantuml.code.AsciiEncoder; import net.sourceforge.plantuml.code.AsciiEncoder;
import net.sourceforge.plantuml.code.CompressionZlib; import net.sourceforge.plantuml.code.CompressionZlib;
import net.sourceforge.plantuml.ugraphic.ColorChangerMonochrome;
public enum SpriteGrayLevel { public enum SpriteGrayLevel {

View File

@ -31,7 +31,7 @@
* Revision $Revision: 3837 $ * Revision $Revision: 3837 $
* *
*/ */
package net.sourceforge.plantuml.ugraphic; package net.sourceforge.plantuml.ugraphic.sprite;
import java.awt.geom.Dimension2D; import java.awt.geom.Dimension2D;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
@ -45,6 +45,8 @@ import net.sourceforge.plantuml.graphic.AbstractTextBlock;
import net.sourceforge.plantuml.graphic.HtmlColor; import net.sourceforge.plantuml.graphic.HtmlColor;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.TextBlock; import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UImage;
public class SpriteImage implements Sprite { public class SpriteImage implements Sprite {

View File

@ -31,7 +31,7 @@
* Revision $Revision: 3837 $ * Revision $Revision: 3837 $
* *
*/ */
package net.sourceforge.plantuml.ugraphic; package net.sourceforge.plantuml.ugraphic.sprite;
import java.awt.Color; import java.awt.Color;
import java.awt.geom.Dimension2D; import java.awt.geom.Dimension2D;
@ -44,6 +44,9 @@ import net.sourceforge.plantuml.graphic.HtmlColorGradient;
import net.sourceforge.plantuml.graphic.HtmlColorUtils; import net.sourceforge.plantuml.graphic.HtmlColorUtils;
import net.sourceforge.plantuml.graphic.StringBounder; import net.sourceforge.plantuml.graphic.StringBounder;
import net.sourceforge.plantuml.graphic.TextBlock; import net.sourceforge.plantuml.graphic.TextBlock;
import net.sourceforge.plantuml.ugraphic.ColorMapper;
import net.sourceforge.plantuml.ugraphic.UGraphic;
import net.sourceforge.plantuml.ugraphic.UImage;
public class SpriteMonochrome implements Sprite { public class SpriteMonochrome implements Sprite {

View File

@ -31,13 +31,15 @@
* Revision $Revision: 3837 $ * Revision $Revision: 3837 $
* *
*/ */
package net.sourceforge.plantuml.ugraphic; package net.sourceforge.plantuml.ugraphic.sprite;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
import java.util.List; import java.util.List;
public class SpriteUtils { public class SpriteUtils {
public static final String SPRITE_NAME = "[-\\p{L}0-9_/]+";
private SpriteUtils() { private SpriteUtils() {
} }

View File

@ -212,7 +212,7 @@ public enum License {
text.add(""); text.add("");
text.add("(C) Copyright 2009-2017, Arnaud Roques"); text.add("(C) Copyright 2009-2017, Arnaud Roques");
text.add(""); text.add("");
text.add("Project Info: http://plantuml.sourceforge.net"); text.add("Project Info: http://plantuml.com");
text.add(""); text.add("");
return text; return text;
} }
@ -225,7 +225,7 @@ public enum License {
h.add(" *"); h.add(" *");
h.add(" * (C) Copyright 2009-2017, Arnaud Roques"); h.add(" * (C) Copyright 2009-2017, Arnaud Roques");
h.add(" *"); h.add(" *");
h.add(" * Project Info: http://plantuml.sourceforge.net"); h.add(" * Project Info: http://plantuml.com");
h.add(" * "); h.add(" * ");
h.add(" * This file is part of PlantUML."); h.add(" * This file is part of PlantUML.");
h.add(" *"); h.add(" *");
@ -320,7 +320,8 @@ public enum License {
throw new IllegalStateException(); throw new IllegalStateException();
} }
text.add(""); text.add("");
text.add("Icon provided by OpenIconic : https://useiconic.com/open/"); text.add("Icons provided by OpenIconic : https://useiconic.com/open");
text.add("Archimate sprites provided by Archi : http://www.archimatetool.com");
text.add(""); text.add("");
return text; return text;
} }

View File

@ -28,7 +28,7 @@
* *
* Original Author: Arnaud Roques * Original Author: Arnaud Roques
* *
* Revision $Revision: 18306 $ * Revision $Revision: 18828 $
* *
*/ */
package net.sourceforge.plantuml.version; package net.sourceforge.plantuml.version;
@ -39,7 +39,7 @@ import java.util.Date;
public class Version { public class Version {
public static int version() { public static int version() {
return 8034; return 8035;
} }
public static String versionString() { public static String versionString() {
@ -63,7 +63,7 @@ public class Version {
} }
private static long compileTime() { private static long compileTime() {
return 1452334079157L; return 1454151644150L;
} }
public static String compileTimeString() { public static String compileTimeString() {