mirror of
https://github.com/octoleo/plantuml.git
synced 2025-01-03 07:12:29 +00:00
version 8035
This commit is contained in:
parent
703a77ee1c
commit
94542f7760
@ -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() {
|
||||||
|
50
src/net/sourceforge/plantuml/Annotated.java
Normal file
50
src/net/sourceforge/plantuml/Annotated.java
Normal 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();
|
||||||
|
|
||||||
|
}
|
134
src/net/sourceforge/plantuml/AnnotatedWorker.java
Normal file
134
src/net/sourceforge/plantuml/AnnotatedWorker.java
Normal 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());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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), //
|
||||||
|
@ -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();
|
||||||
|
@ -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();
|
||||||
|
|
||||||
}
|
}
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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));
|
||||||
|
@ -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');
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -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;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
57
src/net/sourceforge/plantuml/command/CommandCaption.java
Normal file
57
src/net/sourceforge/plantuml/command/CommandCaption.java
Normal 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();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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");
|
||||||
|
@ -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");
|
||||||
|
@ -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");
|
||||||
|
@ -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");
|
||||||
|
@ -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> {
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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> {
|
||||||
|
|
||||||
|
@ -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());
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -255,4 +255,5 @@ public class AtomText implements Atom {
|
|||||||
public final String getText() {
|
public final String getText() {
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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("|_");
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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);
|
||||||
|
@ -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;
|
||||||
// }
|
// }
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -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() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
|
||||||
|
@ -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 = "\\[\\[([^\\[\\]]+)\\]\\]";
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -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;
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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())));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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("$"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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) {
|
||||||
|
@ -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);
|
||||||
|
@ -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 {
|
||||||
|
@ -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");
|
||||||
|
@ -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());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -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;
|
@ -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 {
|
||||||
|
|
@ -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 {
|
||||||
|
|
@ -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 {
|
||||||
|
|
@ -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() {
|
||||||
}
|
}
|
||||||
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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() {
|
||||||
|
Loading…
Reference in New Issue
Block a user