mirror of
https://github.com/octoleo/plantuml.git
synced 2025-01-03 07:12:29 +00:00
Style improvement
This commit is contained in:
parent
45e89d12a8
commit
2761d1e922
@ -1,4 +1,8 @@
|
|||||||
root {
|
root {
|
||||||
|
--common-background: #f1f1f1;
|
||||||
|
--note-background: #FEFFDD;
|
||||||
|
--grey-blue: #e2e2f0;
|
||||||
|
|
||||||
FontName SansSerif
|
FontName SansSerif
|
||||||
HyperLinkColor blue
|
HyperLinkColor blue
|
||||||
FontColor black
|
FontColor black
|
||||||
@ -9,8 +13,8 @@ root {
|
|||||||
DiagonalCorner 0
|
DiagonalCorner 0
|
||||||
LineThickness 1.0
|
LineThickness 1.0
|
||||||
LineColor #181818
|
LineColor #181818
|
||||||
BackGroundColor #f8f8f8
|
BackGroundColor: var(--common-background);
|
||||||
Shadowing 0.0
|
Shadowing: 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
document {
|
document {
|
||||||
@ -73,7 +77,13 @@ element {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
element {
|
||||||
|
LineThickness 0.5
|
||||||
|
}
|
||||||
|
|
||||||
group {
|
group {
|
||||||
|
BackGroundColor transparent
|
||||||
|
LineThickness 1.0
|
||||||
package {
|
package {
|
||||||
LineThickness 1.5
|
LineThickness 1.5
|
||||||
LineColor black
|
LineColor black
|
||||||
@ -84,19 +94,16 @@ group {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
group {
|
|
||||||
BackGroundColor transparent
|
|
||||||
}
|
|
||||||
|
|
||||||
sequenceDiagram {
|
sequenceDiagram {
|
||||||
group {
|
group {
|
||||||
LineColor black
|
LineColor black
|
||||||
LineThickness 2.0
|
LineThickness 1.5
|
||||||
FontSize 11
|
FontSize 11
|
||||||
FontStyle bold
|
FontStyle bold
|
||||||
}
|
}
|
||||||
|
|
||||||
groupHeader {
|
groupHeader {
|
||||||
|
LineThickness 1.5
|
||||||
BackGroundColor #e
|
BackGroundColor #e
|
||||||
LineColor black
|
LineColor black
|
||||||
FontSize 13
|
FontSize 13
|
||||||
@ -108,14 +115,11 @@ sequenceDiagram {
|
|||||||
LineStyle 5
|
LineStyle 5
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy {
|
|
||||||
}
|
|
||||||
|
|
||||||
reference {
|
reference {
|
||||||
FontSize 12
|
FontSize 12
|
||||||
LineColor black
|
LineColor black
|
||||||
BackGroundColor transparent
|
BackGroundColor transparent
|
||||||
LineThickness 2.0
|
LineThickness 1.5
|
||||||
HorizontalAlignment center
|
HorizontalAlignment center
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -143,9 +147,20 @@ sequenceDiagram {
|
|||||||
FontSize 13
|
FontSize 13
|
||||||
FontStyle bold
|
FontStyle bold
|
||||||
}
|
}
|
||||||
|
participant {
|
||||||
|
RoundCorner 5
|
||||||
}
|
}
|
||||||
|
|
||||||
classDiagram {
|
participant,actor,boundary,control,entity,queue,database,collections {
|
||||||
|
BackgroundColor: var(--grey-blue);
|
||||||
|
HorizontalAlignment center
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
classDiagram,componentDiagram,objectDiagram {
|
||||||
|
element {
|
||||||
|
RoundCorner 5
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
visibilityIcon {
|
visibilityIcon {
|
||||||
@ -202,6 +217,9 @@ stateDiagram {
|
|||||||
FontStyle plain
|
FontStyle plain
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
group {
|
||||||
|
LineThickness 0.5
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -211,59 +229,24 @@ delay {
|
|||||||
HorizontalAlignment center
|
HorizontalAlignment center
|
||||||
}
|
}
|
||||||
|
|
||||||
participant {
|
|
||||||
LineThickness 1.5
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
actor {
|
|
||||||
LineThickness 2.0
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
boundary {
|
|
||||||
LineThickness 2.0
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
control {
|
|
||||||
LineThickness 2.0
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
entity {
|
|
||||||
LineThickness 2.0
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
queue {
|
|
||||||
LineThickness 2.0
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
database {
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
collections {
|
|
||||||
LineThickness 1.5
|
|
||||||
HorizontalAlignment center
|
|
||||||
}
|
|
||||||
|
|
||||||
swimlane {
|
swimlane {
|
||||||
BackGroundColor none
|
BackGroundColor none
|
||||||
LineColor black
|
LineColor black
|
||||||
LineThickness 2
|
LineThickness 1.5
|
||||||
FontSize 18
|
FontSize 18
|
||||||
}
|
}
|
||||||
|
|
||||||
arrow {
|
arrow {
|
||||||
FontSize 13
|
FontSize 13
|
||||||
|
LineThickness 1.0
|
||||||
}
|
}
|
||||||
|
|
||||||
note {
|
note {
|
||||||
FontSize 13
|
FontSize 13
|
||||||
BackGroundColor #ebebeb
|
BackGroundColor: var(--note-background);
|
||||||
|
LineThickness 0.5
|
||||||
}
|
}
|
||||||
|
|
||||||
partition {
|
partition {
|
||||||
@ -298,7 +281,6 @@ wbsDiagram {
|
|||||||
|
|
||||||
activityDiagram {
|
activityDiagram {
|
||||||
activity {
|
activity {
|
||||||
LineThickness 1.5
|
|
||||||
Padding 10
|
Padding 10
|
||||||
FontSize 12
|
FontSize 12
|
||||||
RoundCorner 25
|
RoundCorner 25
|
||||||
@ -306,12 +288,14 @@ activityDiagram {
|
|||||||
partition {
|
partition {
|
||||||
LineColor black
|
LineColor black
|
||||||
BackgroundColor none
|
BackgroundColor none
|
||||||
|
LineThickness 1.5
|
||||||
}
|
}
|
||||||
diamond {
|
diamond {
|
||||||
FontSize 11
|
FontSize 11
|
||||||
}
|
}
|
||||||
arrow {
|
arrow {
|
||||||
FontSize 11
|
FontSize 11
|
||||||
|
LineThickness 1
|
||||||
}
|
}
|
||||||
circle {
|
circle {
|
||||||
start {
|
start {
|
||||||
@ -362,10 +346,11 @@ ganttDiagram {
|
|||||||
LineColor #C0C0C0
|
LineColor #C0C0C0
|
||||||
}
|
}
|
||||||
closed {
|
closed {
|
||||||
BackGroundColor #E0E0E0
|
BackGroundColor #F1E5E5
|
||||||
FontColor #989898
|
FontColor #989898
|
||||||
}
|
}
|
||||||
task {
|
task {
|
||||||
|
BackGroundColor: var(--grey-blue);
|
||||||
RoundCorner 0
|
RoundCorner 0
|
||||||
Margin 2 2 2 2
|
Margin 2 2 2 2
|
||||||
Padding 0
|
Padding 0
|
||||||
@ -385,7 +370,6 @@ usecase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
yamlDiagram,jsonDiagram {
|
yamlDiagram,jsonDiagram {
|
||||||
BackGroundColor white
|
|
||||||
FontColor black
|
FontColor black
|
||||||
LineColor black
|
LineColor black
|
||||||
arrow {
|
arrow {
|
||||||
@ -412,10 +396,13 @@ timingDiagram {
|
|||||||
LineColor #3
|
LineColor #3
|
||||||
FontColor #3
|
FontColor #3
|
||||||
FontStyle bold
|
FontStyle bold
|
||||||
LineThickness 1.5
|
LineThickness 0.5
|
||||||
timeline {
|
timeline {
|
||||||
FontStyle plain
|
FontStyle plain
|
||||||
FontSize 11
|
FontSize 11
|
||||||
|
}
|
||||||
|
note {
|
||||||
|
LineThickness 0.5
|
||||||
}
|
}
|
||||||
arrow {
|
arrow {
|
||||||
LineColor darkblue
|
LineColor darkblue
|
||||||
@ -430,18 +417,20 @@ timingDiagram {
|
|||||||
}
|
}
|
||||||
clock {
|
clock {
|
||||||
LineColor darkgreen
|
LineColor darkgreen
|
||||||
|
LineThickness 1.5
|
||||||
}
|
}
|
||||||
concise {
|
concise {
|
||||||
FontSize 12
|
FontSize 12
|
||||||
LineColor darkgreen
|
LineColor darkgreen
|
||||||
BackgroundColor #c
|
BackgroundColor: var(--grey-blue);
|
||||||
|
LineThickness 2
|
||||||
}
|
}
|
||||||
robust {
|
robust {
|
||||||
FontStyle plain
|
FontStyle plain
|
||||||
FontSize 12
|
FontSize 12
|
||||||
LineColor darkgreen
|
LineColor darkgreen
|
||||||
LineThickness 2
|
LineThickness 2
|
||||||
BackgroundColor #c
|
BackgroundColor: var(--grey-blue);
|
||||||
}
|
}
|
||||||
highlight {
|
highlight {
|
||||||
BackgroundColor #e
|
BackgroundColor #e
|
||||||
@ -452,6 +441,7 @@ timingDiagram {
|
|||||||
|
|
||||||
nwdiagDiagram {
|
nwdiagDiagram {
|
||||||
network {
|
network {
|
||||||
|
BackgroundColor: var(--grey-blue);
|
||||||
FontSize 12
|
FontSize 12
|
||||||
}
|
}
|
||||||
server {
|
server {
|
||||||
@ -459,7 +449,7 @@ nwdiagDiagram {
|
|||||||
}
|
}
|
||||||
group {
|
group {
|
||||||
FontSize 12
|
FontSize 12
|
||||||
BackGroundColor #d
|
BackGroundColor #e7e7e7
|
||||||
}
|
}
|
||||||
arrow {
|
arrow {
|
||||||
FontSize 11
|
FontSize 11
|
||||||
@ -638,7 +628,6 @@ ganttDiagram {
|
|||||||
|
|
||||||
|
|
||||||
yamlDiagram,jsonDiagram {
|
yamlDiagram,jsonDiagram {
|
||||||
BackGroundColor black
|
|
||||||
FontColor white
|
FontColor white
|
||||||
LineColor white
|
LineColor white
|
||||||
node {
|
node {
|
||||||
|
@ -232,7 +232,7 @@ public final class BitArray {
|
|||||||
private static int[] makeArray(int size) {
|
private static int[] makeArray(int size) {
|
||||||
final int tmp = (size + 31) >> 5;
|
final int tmp = (size + 31) >> 5;
|
||||||
if (tmp > 1000)
|
if (tmp > 1000)
|
||||||
throw new IllegalArgumentException("Memory error");
|
throw new IllegalArgumentException("Not even an issue :-) We just cancel flashcode generation.");
|
||||||
return new int[tmp];
|
return new int[tmp];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,10 +42,12 @@ import java.util.List;
|
|||||||
import net.sourceforge.plantuml.AlignmentParam;
|
import net.sourceforge.plantuml.AlignmentParam;
|
||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.LineParam;
|
import net.sourceforge.plantuml.LineParam;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.LinkRendering;
|
import net.sourceforge.plantuml.activitydiagram3.LinkRendering;
|
||||||
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.MinMax;
|
import net.sourceforge.plantuml.ugraphic.MinMax;
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
@ -86,7 +88,10 @@ public abstract class AbstractFtile extends AbstractTextBlock implements Ftile {
|
|||||||
throw new UnsupportedOperationException("" + getClass());
|
throw new UnsupportedOperationException("" + getClass());
|
||||||
}
|
}
|
||||||
|
|
||||||
public final UStroke getThickness() {
|
public final UStroke getThickness(Style style) {
|
||||||
|
if (UseStyle.useBetaStyle())
|
||||||
|
return style.getStroke();
|
||||||
|
|
||||||
UStroke thickness = skinParam.getThickness(LineParam.activityBorder, null);
|
UStroke thickness = skinParam.getThickness(LineParam.activityBorder, null);
|
||||||
if (thickness == null) {
|
if (thickness == null) {
|
||||||
thickness = new UStroke(1.5);
|
thickness = new UStroke(1.5);
|
||||||
|
@ -43,12 +43,13 @@ import net.sourceforge.plantuml.activitydiagram3.LinkRendering;
|
|||||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||||
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.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
|
|
||||||
public interface Ftile extends Swimable, TextBlock {
|
public interface Ftile extends Swimable, TextBlock {
|
||||||
|
|
||||||
public UStroke getThickness();
|
public UStroke getThickness(Style style);
|
||||||
|
|
||||||
public ISkinParam skinParam();
|
public ISkinParam skinParam();
|
||||||
|
|
||||||
|
@ -51,6 +51,7 @@ import net.sourceforge.plantuml.activitydiagram3.LinkRendering;
|
|||||||
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
@ -146,6 +147,7 @@ public class FtileAssemblySimple extends AbstractTextBlock implements Ftile {
|
|||||||
return Collections.emptyList();
|
return Collections.emptyList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Set<Swimlane> getSwimlanes() {
|
public Set<Swimlane> getSwimlanes() {
|
||||||
final Set<Swimlane> result = new HashSet<>();
|
final Set<Swimlane> result = new HashSet<>();
|
||||||
result.addAll(tile1.getSwimlanes());
|
result.addAll(tile1.getSwimlanes());
|
||||||
@ -153,14 +155,17 @@ public class FtileAssemblySimple extends AbstractTextBlock implements Ftile {
|
|||||||
return Collections.unmodifiableSet(result);
|
return Collections.unmodifiableSet(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public ISkinParam skinParam() {
|
public ISkinParam skinParam() {
|
||||||
return tile1.skinParam();
|
return tile1.skinParam();
|
||||||
}
|
}
|
||||||
|
|
||||||
public UStroke getThickness() {
|
@Override
|
||||||
return tile1.getThickness();
|
public UStroke getThickness(Style style) {
|
||||||
|
return tile1.getThickness(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public List<WeldingPoint> getWeldingPoints() {
|
public List<WeldingPoint> getWeldingPoints() {
|
||||||
final List<WeldingPoint> result = new ArrayList<>(tile1.getWeldingPoints());
|
final List<WeldingPoint> result = new ArrayList<>(tile1.getWeldingPoints());
|
||||||
result.addAll(tile2.getWeldingPoints());
|
result.addAll(tile2.getWeldingPoints());
|
||||||
@ -171,6 +176,7 @@ public class FtileAssemblySimple extends AbstractTextBlock implements Ftile {
|
|||||||
return Arrays.asList(tile1, tile2);
|
return Arrays.asList(tile1, tile2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public HorizontalAlignment arrowHorizontalAlignment() {
|
public HorizontalAlignment arrowHorizontalAlignment() {
|
||||||
return tile1.arrowHorizontalAlignment();
|
return tile1.arrowHorizontalAlignment();
|
||||||
}
|
}
|
||||||
|
@ -44,6 +44,7 @@ import java.util.List;
|
|||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.Direction;
|
import net.sourceforge.plantuml.Direction;
|
||||||
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||||
import net.sourceforge.plantuml.graphic.HtmlColorAndStyle;
|
import net.sourceforge.plantuml.graphic.HtmlColorAndStyle;
|
||||||
import net.sourceforge.plantuml.graphic.Rainbow;
|
import net.sourceforge.plantuml.graphic.Rainbow;
|
||||||
@ -51,6 +52,8 @@ import net.sourceforge.plantuml.graphic.StringBounder;
|
|||||||
import net.sourceforge.plantuml.graphic.TextBlock;
|
import net.sourceforge.plantuml.graphic.TextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
import net.sourceforge.plantuml.graphic.VerticalAlignment;
|
import net.sourceforge.plantuml.graphic.VerticalAlignment;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
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.UPolygon;
|
import net.sourceforge.plantuml.ugraphic.UPolygon;
|
||||||
@ -85,6 +88,7 @@ public class Snake implements UShape {
|
|||||||
private final List<Text> texts;
|
private final List<Text> texts;
|
||||||
private final MergeStrategy mergeable;
|
private final MergeStrategy mergeable;
|
||||||
private final Direction emphasizeDirection;
|
private final Direction emphasizeDirection;
|
||||||
|
private final ISkinParam skinParam;
|
||||||
|
|
||||||
public Snake transformX(PiecewiseAffineTransform compressionTransform) {
|
public Snake transformX(PiecewiseAffineTransform compressionTransform) {
|
||||||
final Snake result = cloneEmpty();
|
final Snake result = cloneEmpty();
|
||||||
@ -98,15 +102,15 @@ public class Snake implements UShape {
|
|||||||
|
|
||||||
public Snake move(double dx, double dy) {
|
public Snake move(double dx, double dy) {
|
||||||
final Snake result = cloneEmpty();
|
final Snake result = cloneEmpty();
|
||||||
for (Point2D pt : worm) {
|
for (Point2D pt : worm)
|
||||||
result.addPoint(pt.getX() + dx, pt.getY() + dy);
|
result.addPoint(pt.getX() + dx, pt.getY() + dy);
|
||||||
}
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Snake cloneEmpty() {
|
private Snake cloneEmpty() {
|
||||||
return new Snake(startDecoration, color, endDecoration, worm.cloneEmpty(), mergeable, emphasizeDirection,
|
return new Snake(skinParam, startDecoration, color, endDecoration, worm.cloneEmpty(), mergeable,
|
||||||
texts);
|
emphasizeDirection, texts);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final Snake ignoreForCompression() {
|
public final Snake ignoreForCompression() {
|
||||||
@ -115,53 +119,59 @@ public class Snake implements UShape {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Snake emphasizeDirection(Direction emphasizeDirection) {
|
public Snake emphasizeDirection(Direction emphasizeDirection) {
|
||||||
return new Snake(startDecoration, color, endDecoration, worm, mergeable, emphasizeDirection, texts);
|
return new Snake(skinParam, startDecoration, color, endDecoration, worm, mergeable, emphasizeDirection, texts);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Snake withoutEndDecoration() {
|
public Snake withoutEndDecoration() {
|
||||||
return new Snake(startDecoration, color, null, worm, mergeable, emphasizeDirection, texts);
|
return new Snake(skinParam, startDecoration, color, null, worm, mergeable, emphasizeDirection, texts);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Snake withMerge(MergeStrategy mergeable) {
|
public Snake withMerge(MergeStrategy mergeable) {
|
||||||
return new Snake(startDecoration, color, endDecoration, worm, mergeable, emphasizeDirection, texts);
|
return new Snake(skinParam, startDecoration, color, endDecoration, worm, mergeable, emphasizeDirection, texts);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Snake withLabel(TextBlock textBlock, HorizontalAlignment horizontalAlignment) {
|
public Snake withLabel(TextBlock textBlock, HorizontalAlignment horizontalAlignment) {
|
||||||
if (textBlock != null) {
|
if (textBlock != null)
|
||||||
this.texts.add(new Text(textBlock, null, horizontalAlignment));
|
this.texts.add(new Text(textBlock, null, horizontalAlignment));
|
||||||
}
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Snake withLabel(TextBlock textBlock, VerticalAlignment verticalAlignment) {
|
public Snake withLabel(TextBlock textBlock, VerticalAlignment verticalAlignment) {
|
||||||
if (textBlock != null && textBlock != TextBlockUtils.EMPTY_TEXT_BLOCK) {
|
if (textBlock != null && textBlock != TextBlockUtils.EMPTY_TEXT_BLOCK)
|
||||||
this.texts.add(new Text(textBlock, verticalAlignment, null));
|
this.texts.add(new Text(textBlock, verticalAlignment, null));
|
||||||
}
|
|
||||||
if (verticalAlignment != VerticalAlignment.CENTER) {
|
if (verticalAlignment != VerticalAlignment.CENTER)
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Snake create(Rainbow color) {
|
public static Snake create(ISkinParam skinParam, Rainbow color) {
|
||||||
return new Snake(null, color, null, new Worm(), MergeStrategy.FULL, null, new ArrayList<Text>());
|
final Style style = StyleSignature.activityArrow().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
}
|
return new Snake(skinParam, null, color, null, new Worm(style), MergeStrategy.FULL, null,
|
||||||
|
|
||||||
public static Snake create(Rainbow color, UPolygon endDecoration) {
|
|
||||||
return new Snake(null, color, endDecoration, new Worm(), MergeStrategy.FULL, null, new ArrayList<Text>());
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Snake create(UPolygon startDecoration, Rainbow color, UPolygon endDecoration) {
|
|
||||||
return new Snake(startDecoration, color, endDecoration, new Worm(), MergeStrategy.FULL, null,
|
|
||||||
new ArrayList<Text>());
|
new ArrayList<Text>());
|
||||||
}
|
}
|
||||||
|
|
||||||
private Snake(UPolygon startDecoration, Rainbow color, UPolygon endDecoration, Worm worm, MergeStrategy mergeable,
|
public static Snake create(ISkinParam skinParam, Rainbow color, UPolygon endDecoration) {
|
||||||
Direction emphasizeDirection, List<Text> texts) {
|
final Style style = StyleSignature.activityArrow().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
|
return new Snake(skinParam, null, color, endDecoration, new Worm(style), MergeStrategy.FULL, null,
|
||||||
if (Objects.requireNonNull(color).size() == 0) {
|
new ArrayList<Text>());
|
||||||
throw new IllegalArgumentException();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Snake create(ISkinParam skinParam, UPolygon startDecoration, Rainbow color, UPolygon endDecoration) {
|
||||||
|
final Style style = StyleSignature.activityArrow().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
|
return new Snake(skinParam, startDecoration, color, endDecoration, new Worm(style), MergeStrategy.FULL, null,
|
||||||
|
new ArrayList<Text>());
|
||||||
|
}
|
||||||
|
|
||||||
|
private Snake(ISkinParam skinParam, UPolygon startDecoration, Rainbow color, UPolygon endDecoration, Worm worm,
|
||||||
|
MergeStrategy mergeable, Direction emphasizeDirection, List<Text> texts) {
|
||||||
|
|
||||||
|
if (Objects.requireNonNull(color).size() == 0)
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
|
||||||
|
this.skinParam = skinParam;
|
||||||
this.worm = worm;
|
this.worm = worm;
|
||||||
this.texts = Objects.requireNonNull(texts);
|
this.texts = Objects.requireNonNull(texts);
|
||||||
this.emphasizeDirection = emphasizeDirection;
|
this.emphasizeDirection = emphasizeDirection;
|
||||||
@ -210,14 +220,14 @@ public class Snake implements UShape {
|
|||||||
}
|
}
|
||||||
final double globalMove = -1.0 * (colors.size() - 1) / 2.0;
|
final double globalMove = -1.0 * (colors.size() - 1) / 2.0;
|
||||||
Worm current = worm.moveFirstPoint(mutation.getFirst().multiplyBy(globalMove));
|
Worm current = worm.moveFirstPoint(mutation.getFirst().multiplyBy(globalMove));
|
||||||
if (mutation.size() > 2) {
|
if (mutation.size() > 2)
|
||||||
current = current.moveLastPoint(mutation.getLast().multiplyBy(globalMove));
|
current = current.moveLastPoint(mutation.getLast().multiplyBy(globalMove));
|
||||||
}
|
|
||||||
for (int i = 0; i < colors.size(); i++) {
|
for (int i = 0; i < colors.size(); i++) {
|
||||||
double stroke = 1.5;
|
double stroke = 1.5;
|
||||||
if (colorArrowSeparationSpace == 0) {
|
if (colorArrowSeparationSpace == 0)
|
||||||
stroke = i == colors.size() - 1 ? 2.0 : 3.0;
|
stroke = i == colors.size() - 1 ? 2.0 : 3.0;
|
||||||
}
|
|
||||||
current.drawInternalOneColor(startDecoration, ug, colors.get(i), stroke, emphasizeDirection, endDecoration);
|
current.drawInternalOneColor(startDecoration, ug, colors.get(i), stroke, emphasizeDirection, endDecoration);
|
||||||
current = mutation.mute(current);
|
current = mutation.mute(current);
|
||||||
}
|
}
|
||||||
@ -235,9 +245,9 @@ public class Snake implements UShape {
|
|||||||
|
|
||||||
public double getMaxX(StringBounder stringBounder) {
|
public double getMaxX(StringBounder stringBounder) {
|
||||||
double result = -Double.MAX_VALUE;
|
double result = -Double.MAX_VALUE;
|
||||||
for (Point2D pt : worm) {
|
for (Point2D pt : worm)
|
||||||
result = Math.max(result, pt.getX());
|
result = Math.max(result, pt.getX());
|
||||||
}
|
|
||||||
for (Text text : texts) {
|
for (Text text : texts) {
|
||||||
final Point2D position = getTextBlockPosition(stringBounder, text);
|
final Point2D position = getTextBlockPosition(stringBounder, text);
|
||||||
final Dimension2D dim = text.textBlock.calculateDimension(stringBounder);
|
final Dimension2D dim = text.textBlock.calculateDimension(stringBounder);
|
||||||
@ -302,14 +312,13 @@ public class Snake implements UShape {
|
|||||||
|
|
||||||
public Snake merge(Snake other, StringBounder stringBounder) {
|
public Snake merge(Snake other, StringBounder stringBounder) {
|
||||||
final MergeStrategy strategy = this.mergeable.max(other.mergeable);
|
final MergeStrategy strategy = this.mergeable.max(other.mergeable);
|
||||||
if (strategy == MergeStrategy.NONE) {
|
if (strategy == MergeStrategy.NONE)
|
||||||
return null;
|
return null;
|
||||||
}
|
|
||||||
for (Text text : other.texts) {
|
for (Text text : other.texts)
|
||||||
if (text.hasText(stringBounder)) {
|
if (text.hasText(stringBounder))
|
||||||
return null;
|
return null;
|
||||||
}
|
|
||||||
}
|
|
||||||
if (same(this.getLast(), other.getFirst())) {
|
if (same(this.getLast(), other.getFirst())) {
|
||||||
final UPolygon oneOf = other.endDecoration == null ? endDecoration : other.endDecoration;
|
final UPolygon oneOf = other.endDecoration == null ? endDecoration : other.endDecoration;
|
||||||
if (this.startDecoration != null || other.startDecoration != null) {
|
if (this.startDecoration != null || other.startDecoration != null) {
|
||||||
@ -317,23 +326,23 @@ public class Snake implements UShape {
|
|||||||
}
|
}
|
||||||
final ArrayList<Text> mergeTexts = new ArrayList<Text>(this.texts);
|
final ArrayList<Text> mergeTexts = new ArrayList<Text>(this.texts);
|
||||||
mergeTexts.addAll(other.texts);
|
mergeTexts.addAll(other.texts);
|
||||||
final Snake result = new Snake(null, color, oneOf, this.worm.merge(other.worm, strategy), strategy,
|
final Snake result = new Snake(skinParam, null, color, oneOf, this.worm.merge(other.worm, strategy),
|
||||||
emphasizeDirection == null ? other.emphasizeDirection : emphasizeDirection, mergeTexts);
|
strategy, emphasizeDirection == null ? other.emphasizeDirection : emphasizeDirection, mergeTexts);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
if (same(this.getFirst(), other.getLast())) {
|
if (same(this.getFirst(), other.getLast()))
|
||||||
return other.merge(this, stringBounder);
|
return other.merge(this, stringBounder);
|
||||||
}
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean touches(Snake other) {
|
public boolean touches(Snake other) {
|
||||||
if (other.mergeable != MergeStrategy.FULL) {
|
if (other.mergeable != MergeStrategy.FULL)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
if (other.worm.isPureHorizontal()) {
|
if (other.worm.isPureHorizontal())
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
return same(this.getLast(), other.getFirst());
|
return same(this.getLast(), other.getFirst());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ public class Swimlanes extends AbstractTextBlock implements TextBlock, Styleable
|
|||||||
return Collections.unmodifiableList(swimlanesSpecial);
|
return Collections.unmodifiableList(swimlanesSpecial);
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.swimlane);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.swimlane);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,7 +131,7 @@ public class Swimlanes extends AbstractTextBlock implements TextBlock, Styleable
|
|||||||
|
|
||||||
protected Style getStyle() {
|
protected Style getStyle() {
|
||||||
if (style == null) {
|
if (style == null) {
|
||||||
this.style = getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
this.style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
}
|
}
|
||||||
return style;
|
return style;
|
||||||
}
|
}
|
||||||
|
@ -45,8 +45,12 @@ import java.util.List;
|
|||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.Direction;
|
import net.sourceforge.plantuml.Direction;
|
||||||
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.cucadiagram.LinkStyle;
|
import net.sourceforge.plantuml.cucadiagram.LinkStyle;
|
||||||
import net.sourceforge.plantuml.graphic.HtmlColorAndStyle;
|
import net.sourceforge.plantuml.graphic.HtmlColorAndStyle;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
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.ULine;
|
import net.sourceforge.plantuml.ugraphic.ULine;
|
||||||
@ -59,6 +63,11 @@ import net.sourceforge.plantuml.ugraphic.comp.CompressionMode;
|
|||||||
public class Worm implements Iterable<Point2D.Double> {
|
public class Worm implements Iterable<Point2D.Double> {
|
||||||
|
|
||||||
private final List<Point2D.Double> points = new ArrayList<Point2D.Double>();
|
private final List<Point2D.Double> points = new ArrayList<Point2D.Double>();
|
||||||
|
private final Style style;
|
||||||
|
|
||||||
|
public Worm(Style style) {
|
||||||
|
this.style = style;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isPureHorizontal() {
|
public boolean isPureHorizontal() {
|
||||||
return points.size() == 2 && points.get(0).getY() == points.get(1).getY();
|
return points.size() == 2 && points.get(0).getY() == points.get(1).getY();
|
||||||
@ -67,32 +76,37 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
private boolean ignoreForCompression;
|
private boolean ignoreForCompression;
|
||||||
|
|
||||||
public Worm cloneEmpty() {
|
public Worm cloneEmpty() {
|
||||||
final Worm result = new Worm();
|
final Worm result = new Worm(style);
|
||||||
result.ignoreForCompression = this.ignoreForCompression;
|
result.ignoreForCompression = this.ignoreForCompression;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public final void setIgnoreForCompression() {
|
public final void setIgnoreForCompression() {
|
||||||
if (points.size() > 0) {
|
if (points.size() > 0)
|
||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
}
|
|
||||||
this.ignoreForCompression = true;
|
this.ignoreForCompression = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void drawInternalOneColor(UPolygon startDecoration, UGraphic ug, HtmlColorAndStyle colorAndStyle,
|
public void drawInternalOneColor(UPolygon startDecoration, UGraphic ug, HtmlColorAndStyle colorAndStyle,
|
||||||
double stroke, Direction emphasizeDirection, UPolygon endDecoration) {
|
double strokeValue, Direction emphasizeDirection, UPolygon endDecoration) {
|
||||||
final HColor arrowColor = Objects.requireNonNull(colorAndStyle.getArrowColor());
|
final HColor arrowColor = Objects.requireNonNull(colorAndStyle.getArrowColor());
|
||||||
final LinkStyle style = colorAndStyle.getStyle();
|
final LinkStyle linkStyle = colorAndStyle.getStyle();
|
||||||
if (style.isInvisible()) {
|
if (linkStyle.isInvisible())
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
ug = ug.apply(arrowColor);
|
ug = ug.apply(arrowColor);
|
||||||
ug = ug.apply(arrowColor.bg());
|
ug = ug.apply(arrowColor.bg());
|
||||||
if (style.isNormal()) {
|
if (linkStyle.isNormal()) {
|
||||||
ug = ug.apply(new UStroke(stroke));
|
UStroke stroke = new UStroke(strokeValue);
|
||||||
} else {
|
if (UseStyle.useBetaStyle()) {
|
||||||
ug = ug.apply(style.goThickness(stroke).getStroke3());
|
stroke = style.getStroke();
|
||||||
}
|
}
|
||||||
|
ug = ug.apply(stroke);
|
||||||
|
} else {
|
||||||
|
ug = ug.apply(linkStyle.goThickness(strokeValue).getStroke3());
|
||||||
|
}
|
||||||
|
|
||||||
boolean drawn = false;
|
boolean drawn = false;
|
||||||
for (int i = 0; i < points.size() - 1; i++) {
|
for (int i = 0; i < points.size() - 1; i++) {
|
||||||
final java.awt.geom.Point2D.Double p1 = points.get(i);
|
final java.awt.geom.Point2D.Double p1 = points.get(i);
|
||||||
@ -107,9 +121,9 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
final HColor arrowHeadColor = colorAndStyle.getArrowHeadColor();
|
final HColor arrowHeadColor = colorAndStyle.getArrowHeadColor();
|
||||||
if (arrowHeadColor == null) {
|
if (arrowHeadColor == null)
|
||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
}
|
|
||||||
// if (arrowHeadColor == null || arrowHeadColor.equals(HColorUtils.transparent())) {
|
// if (arrowHeadColor == null || arrowHeadColor.equals(HColorUtils.transparent())) {
|
||||||
// return;
|
// return;
|
||||||
// }
|
// }
|
||||||
@ -119,17 +133,17 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
if (startDecoration != null) {
|
if (startDecoration != null) {
|
||||||
ug = ug.apply(new UStroke(1.5));
|
ug = ug.apply(new UStroke(1.5));
|
||||||
final Point2D start = points.get(0);
|
final Point2D start = points.get(0);
|
||||||
if (ignoreForCompression) {
|
if (ignoreForCompression)
|
||||||
startDecoration.setCompressionMode(CompressionMode.ON_X);
|
startDecoration.setCompressionMode(CompressionMode.ON_X);
|
||||||
}
|
|
||||||
ug.apply(new UTranslate(start)).apply(new UStroke()).draw(startDecoration);
|
ug.apply(new UTranslate(start)).apply(new UStroke()).draw(startDecoration);
|
||||||
}
|
}
|
||||||
if (endDecoration != null) {
|
if (endDecoration != null) {
|
||||||
ug = ug.apply(new UStroke(1.5));
|
ug = ug.apply(new UStroke(1.5));
|
||||||
final Point2D end = points.get(points.size() - 1);
|
final Point2D end = points.get(points.size() - 1);
|
||||||
if (ignoreForCompression) {
|
if (ignoreForCompression)
|
||||||
endDecoration.setCompressionMode(CompressionMode.ON_X);
|
endDecoration.setCompressionMode(CompressionMode.ON_X);
|
||||||
}
|
|
||||||
ug.apply(new UTranslate(end)).apply(new UStroke()).draw(endDecoration);
|
ug.apply(new UTranslate(end)).apply(new UStroke()).draw(endDecoration);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -140,73 +154,73 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
|
|
||||||
private void drawLine(UGraphic ug, double x1, double y1, double x2, double y2, Direction direction) {
|
private void drawLine(UGraphic ug, double x1, double y1, double x2, double y2, Direction direction) {
|
||||||
ug = ug.apply(new UTranslate(x1, y1));
|
ug = ug.apply(new UTranslate(x1, y1));
|
||||||
if (direction != null) {
|
if (direction != null)
|
||||||
ug.apply(new UTranslate((x2 - x1) / 2, (y2 - y1) / 2)).draw(Arrows.asTo(direction));
|
ug.apply(new UTranslate((x2 - x1) / 2, (y2 - y1) / 2)).draw(Arrows.asTo(direction));
|
||||||
}
|
|
||||||
ug.draw(new ULine(x2 - x1, y2 - y1));
|
ug.draw(new ULine(x2 - x1, y2 - y1));
|
||||||
}
|
}
|
||||||
|
|
||||||
public Worm move(double dx, double dy) {
|
public Worm move(double dx, double dy) {
|
||||||
final Worm result = new Worm();
|
final Worm result = new Worm(style);
|
||||||
for (Point2D pt : points) {
|
for (Point2D pt : points)
|
||||||
result.addPoint(pt.getX() + dx, pt.getY() + dy);
|
result.addPoint(pt.getX() + dx, pt.getY() + dy);
|
||||||
}
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Worm moveFirstPoint(UTranslate move) {
|
public Worm moveFirstPoint(UTranslate move) {
|
||||||
final double dx = move.getDx();
|
final double dx = move.getDx();
|
||||||
final double dy = move.getDy();
|
final double dy = move.getDy();
|
||||||
if (dx != 0 && dy != 0) {
|
if (dx != 0 && dy != 0)
|
||||||
throw new IllegalArgumentException("move=" + move);
|
throw new IllegalArgumentException("move=" + move);
|
||||||
}
|
|
||||||
final Worm result = new Worm();
|
final Worm result = new Worm(style);
|
||||||
double x0 = this.points.get(0).getX();
|
double x0 = this.points.get(0).getX();
|
||||||
double y0 = this.points.get(0).getY();
|
double y0 = this.points.get(0).getY();
|
||||||
double x1 = this.points.get(1).getX();
|
double x1 = this.points.get(1).getX();
|
||||||
double y1 = this.points.get(1).getY();
|
double y1 = this.points.get(1).getY();
|
||||||
|
|
||||||
if (dx != 0 && x0 == x1) {
|
if (dx != 0 && x0 == x1)
|
||||||
x1 += dx;
|
x1 += dx;
|
||||||
}
|
|
||||||
if (dy != 0 && y0 == y1) {
|
if (dy != 0 && y0 == y1)
|
||||||
y1 += dy;
|
y1 += dy;
|
||||||
}
|
|
||||||
x0 += dx;
|
x0 += dx;
|
||||||
y0 += dy;
|
y0 += dy;
|
||||||
|
|
||||||
result.addPoint(x0, y0);
|
result.addPoint(x0, y0);
|
||||||
result.addPoint(x1, y1);
|
result.addPoint(x1, y1);
|
||||||
for (int i = 2; i < this.points.size(); i++) {
|
for (int i = 2; i < this.points.size(); i++)
|
||||||
result.addPoint(this.points.get(i));
|
result.addPoint(this.points.get(i));
|
||||||
}
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Worm moveLastPoint(UTranslate move) {
|
public Worm moveLastPoint(UTranslate move) {
|
||||||
final double dx = move.getDx();
|
final double dx = move.getDx();
|
||||||
final double dy = move.getDy();
|
final double dy = move.getDy();
|
||||||
if (dx != 0 && dy != 0) {
|
if (dx != 0 && dy != 0)
|
||||||
throw new IllegalArgumentException("move=" + move);
|
throw new IllegalArgumentException("move=" + move);
|
||||||
}
|
|
||||||
final Worm result = new Worm();
|
final Worm result = new Worm(style);
|
||||||
double x8 = this.points.get(this.points.size() - 2).getX();
|
double x8 = this.points.get(this.points.size() - 2).getX();
|
||||||
double y8 = this.points.get(this.points.size() - 2).getY();
|
double y8 = this.points.get(this.points.size() - 2).getY();
|
||||||
double x9 = this.points.get(this.points.size() - 1).getX();
|
double x9 = this.points.get(this.points.size() - 1).getX();
|
||||||
double y9 = this.points.get(this.points.size() - 1).getY();
|
double y9 = this.points.get(this.points.size() - 1).getY();
|
||||||
|
|
||||||
if (dx != 0 && x8 == x9) {
|
if (dx != 0 && x8 == x9)
|
||||||
x8 += dx;
|
x8 += dx;
|
||||||
}
|
|
||||||
if (dy != 0 && y8 == y9) {
|
if (dy != 0 && y8 == y9)
|
||||||
y8 += dy;
|
y8 += dy;
|
||||||
}
|
|
||||||
x9 += dx;
|
x9 += dx;
|
||||||
y9 += dy;
|
y9 += dy;
|
||||||
|
|
||||||
for (int i = 0; i < this.points.size() - 2; i++) {
|
for (int i = 0; i < this.points.size() - 2; i++)
|
||||||
result.addPoint(this.points.get(i));
|
result.addPoint(this.points.get(i));
|
||||||
}
|
|
||||||
result.addPoint(x8, y8);
|
result.addPoint(x8, y8);
|
||||||
result.addPoint(x9, y9);
|
result.addPoint(x9, y9);
|
||||||
return result;
|
return result;
|
||||||
@ -215,24 +229,24 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
final StringBuilder result = new StringBuilder();
|
final StringBuilder result = new StringBuilder();
|
||||||
for (int i = 0; i < points.size() - 1; i++) {
|
for (int i = 0; i < points.size() - 1; i++)
|
||||||
result.append(getDirectionAtPoint(i) + " ");
|
result.append(getDirectionAtPoint(i) + " ");
|
||||||
}
|
|
||||||
return result + points.toString();
|
return result + points.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addPoint(double x, double y) {
|
public void addPoint(double x, double y) {
|
||||||
if (Double.isNaN(x)) {
|
if (Double.isNaN(x))
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
if (Double.isNaN(y)) {
|
if (Double.isNaN(y))
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
if (points.size() > 0) {
|
if (points.size() > 0) {
|
||||||
final Point2D last = getLast();
|
final Point2D last = getLast();
|
||||||
if (last.getX() == x && last.getY() == y) {
|
if (last.getX() == x && last.getY() == y)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
this.points.add(new Point2D.Double(x, y));
|
this.points.add(new Point2D.Double(x, y));
|
||||||
}
|
}
|
||||||
@ -246,9 +260,9 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
SnakeDirection getDirection() {
|
SnakeDirection getDirection() {
|
||||||
if (points.size() < 2) {
|
if (points.size() < 2)
|
||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
}
|
|
||||||
return SnakeDirection.getDirection(points.get(0), points.get(1));
|
return SnakeDirection.getDirection(points.get(0), points.get(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -282,9 +296,9 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
for (int i = 0; i < points.size() - 1; i++) {
|
for (int i = 0; i < points.size() - 1; i++) {
|
||||||
final Point2D.Double pt1 = get(i);
|
final Point2D.Double pt1 = get(i);
|
||||||
final Point2D.Double pt2 = get(i + 1);
|
final Point2D.Double pt2 = get(i + 1);
|
||||||
if (pt1.getY() == pt2.getY() && area.doesHorizontalCross(pt1, pt2)) {
|
if (pt1.getY() == pt2.getY() && area.doesHorizontalCross(pt1, pt2))
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -325,10 +339,10 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Worm merge(Worm other, MergeStrategy merge) {
|
public Worm merge(Worm other, MergeStrategy merge) {
|
||||||
if (Snake.same(this.getLast(), other.getFirst()) == false) {
|
if (Snake.same(this.getLast(), other.getFirst()) == false)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
final Worm result = new Worm();
|
final Worm result = new Worm(style);
|
||||||
result.points.addAll(this.points);
|
result.points.addAll(this.points);
|
||||||
result.points.addAll(other.points);
|
result.points.addAll(other.points);
|
||||||
result.mergeMe(merge);
|
result.mergeMe(merge);
|
||||||
@ -348,9 +362,9 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
change = change || removePattern5();
|
change = change || removePattern5();
|
||||||
change = change || removePattern6();
|
change = change || removePattern6();
|
||||||
change = change || removePattern7();
|
change = change || removePattern7();
|
||||||
if (merge == MergeStrategy.FULL) {
|
if (merge == MergeStrategy.FULL)
|
||||||
change = change || removePattern8();
|
change = change || removePattern8();
|
||||||
}
|
|
||||||
} while (change);
|
} while (change);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -510,4 +524,8 @@ public class Worm implements Iterable<Point2D.Double> {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Style getStyle() {
|
||||||
|
return style;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -188,7 +188,7 @@ public class WormMutation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Worm mute(Worm original) {
|
public Worm mute(Worm original) {
|
||||||
final Worm result = new Worm();
|
final Worm result = new Worm(original.getStyle());
|
||||||
for (int i = 0; i < original.size(); i++) {
|
for (int i = 0; i < original.size(); i++) {
|
||||||
result.addPoint(translations.get(i).getTranslated(original.get(i)));
|
result.addPoint(translations.get(i).getTranslated(original.get(i)));
|
||||||
}
|
}
|
||||||
|
@ -44,6 +44,7 @@ import net.sourceforge.plantuml.graphic.HtmlColorAndStyle;
|
|||||||
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.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UPolygon;
|
import net.sourceforge.plantuml.ugraphic.UPolygon;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
@ -53,8 +54,8 @@ public class WormTexted implements Iterable<Point2D.Double> {
|
|||||||
private final Worm worm;
|
private final Worm worm;
|
||||||
private TextBlock textBlock;
|
private TextBlock textBlock;
|
||||||
|
|
||||||
public WormTexted() {
|
private WormTexted(Style style) {
|
||||||
this(new Worm());
|
this(new Worm(style));
|
||||||
}
|
}
|
||||||
|
|
||||||
private WormTexted(Worm worm) {
|
private WormTexted(Worm worm) {
|
||||||
|
@ -67,11 +67,11 @@ public abstract class AbstractParallelFtilesBuilder {
|
|||||||
private final StringBounder stringBounder;
|
private final StringBounder stringBounder;
|
||||||
protected final List<Ftile> list99 = new ArrayList<>();
|
protected final List<Ftile> list99 = new ArrayList<>();
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity);
|
||||||
}
|
}
|
||||||
|
|
||||||
final public StyleSignature getDefaultStyleDefinitionArrow() {
|
final public StyleSignature getStyleSignatureArrow() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -136,7 +136,7 @@ public abstract class AbstractParallelFtilesBuilder {
|
|||||||
}
|
}
|
||||||
final FontConfiguration fontConfiguration;
|
final FontConfiguration fontConfiguration;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
final Style style = getDefaultStyleDefinitionArrow().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
final Style style = getStyleSignatureArrow().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
fontConfiguration = style.getFontConfiguration(skinParam().getThemeStyle(), skinParam().getIHtmlColorSet());
|
fontConfiguration = style.getFontConfiguration(skinParam().getThemeStyle(), skinParam().getIHtmlColorSet());
|
||||||
} else {
|
} else {
|
||||||
fontConfiguration = new FontConfiguration(skinParam(), FontParam.ARROW, null);
|
fontConfiguration = new FontConfiguration(skinParam(), FontParam.ARROW, null);
|
||||||
|
@ -76,7 +76,8 @@ public class ConnectionVerticalDown extends AbstractConnection implements Connec
|
|||||||
}
|
}
|
||||||
|
|
||||||
private Snake getSimpleSnake() {
|
private Snake getSimpleSnake() {
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown()).withLabel(textBlock, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(getFtile1().skinParam(), color, Arrows.asToDown()).withLabel(textBlock,
|
||||||
|
arrowHorizontalAlignment());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
return snake;
|
return snake;
|
||||||
@ -84,7 +85,8 @@ public class ConnectionVerticalDown extends AbstractConnection implements Connec
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown()).withLabel(textBlock, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(getFtile1().skinParam(), color, Arrows.asToDown()).withLabel(textBlock,
|
||||||
|
arrowHorizontalAlignment());
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
|
@ -55,7 +55,10 @@ import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
|||||||
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.skin.rose.Rose;
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
|
import net.sourceforge.plantuml.style.SName;
|
||||||
import net.sourceforge.plantuml.style.Style;
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
import net.sourceforge.plantuml.svek.image.Opale;
|
import net.sourceforge.plantuml.svek.image.Opale;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
@ -65,33 +68,40 @@ public class FloatingNote extends AbstractTextBlock implements Stencil, TextBloc
|
|||||||
|
|
||||||
private final Opale opale;
|
private final Opale opale;
|
||||||
|
|
||||||
public FloatingNote(Display note, ISkinParam skinParam, Style style) {
|
public FloatingNote(Display note, ISkinParam skinParam) {
|
||||||
|
|
||||||
final Rose rose = new Rose();
|
final Rose rose = new Rose();
|
||||||
|
|
||||||
final HColor noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
UStroke stroke = new UStroke();
|
||||||
final HColor borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
final HColor noteBackgroundColor;
|
||||||
|
final HColor borderColor;
|
||||||
final FontConfiguration fc = new FontConfiguration(skinParam, FontParam.NOTE, null);
|
final FontConfiguration fc;
|
||||||
|
|
||||||
final LineBreakStrategy wrapWidth;
|
final LineBreakStrategy wrapWidth;
|
||||||
|
final double shadowing;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
|
final Style style = StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note)
|
||||||
|
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
wrapWidth = style.wrapWidth();
|
wrapWidth = style.wrapWidth();
|
||||||
|
fc = new FontConfiguration(skinParam, style);
|
||||||
|
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
|
skinParam.getIHtmlColorSet());
|
||||||
|
borderColor = style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
|
||||||
|
stroke = style.getStroke();
|
||||||
|
shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
} else {
|
} else {
|
||||||
|
shadowing = skinParam.shadowing(null) ? 4 : 0;
|
||||||
|
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
||||||
|
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
||||||
|
fc = new FontConfiguration(skinParam, FontParam.NOTE, null);
|
||||||
wrapWidth = skinParam.wrapWidth();
|
wrapWidth = skinParam.wrapWidth();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
final Sheet sheet = Parser
|
final Sheet sheet = Parser
|
||||||
.build(fc, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT), skinParam, CreoleMode.FULL)
|
.build(fc, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT), skinParam, CreoleMode.FULL)
|
||||||
.createSheet(note);
|
.createSheet(note);
|
||||||
final SheetBlock2 sheetBlock2 = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this,
|
final SheetBlock2 sheetBlock2 = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this,
|
||||||
new UStroke(1));
|
stroke);
|
||||||
final double shadowing;
|
this.opale = new Opale(shadowing, borderColor, noteBackgroundColor, sheetBlock2, false, stroke);
|
||||||
shadowing = skinParam.shadowing(null) ? 4 : 0;
|
|
||||||
this.opale = new Opale(shadowing, borderColor, noteBackgroundColor, sheetBlock2, false);
|
|
||||||
|
|
||||||
// this.text = sheetBlock2;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,7 +136,7 @@ public class FtileFactoryDelegatorRepeat extends FtileFactoryDelegator {
|
|||||||
final UTranslate tr2 = genealogy.getTranslate(diamondBreak, ug.getStringBounder());
|
final UTranslate tr2 = genealogy.getTranslate(diamondBreak, ug.getStringBounder());
|
||||||
final Dimension2D dimDiamond = diamondBreak.calculateDimension(ug.getStringBounder());
|
final Dimension2D dimDiamond = diamondBreak.calculateDimension(ug.getStringBounder());
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToRight());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToRight());
|
||||||
snake.addPoint(tr1.getDx(), tr1.getDy());
|
snake.addPoint(tr1.getDx(), tr1.getDy());
|
||||||
snake.addPoint(0, tr1.getDy());
|
snake.addPoint(0, tr1.getDy());
|
||||||
snake.addPoint(0, tr2.getDy() + dimDiamond.getHeight() / 2);
|
snake.addPoint(0, tr2.getDy() + dimDiamond.getHeight() / 2);
|
||||||
|
@ -122,7 +122,7 @@ public class FtileFactoryDelegatorWhile extends FtileFactoryDelegator {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final UTranslate tr1 = genealogy.getTranslate(ftileBreak, ug.getStringBounder());
|
final UTranslate tr1 = genealogy.getTranslate(ftileBreak, ug.getStringBounder());
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToLeft());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToLeft());
|
||||||
snake.addPoint(tr1.getDx(), tr1.getDy());
|
snake.addPoint(tr1.getDx(), tr1.getDy());
|
||||||
snake.addPoint(Hexagon.hexagonHalfSize, tr1.getDy());
|
snake.addPoint(Hexagon.hexagonHalfSize, tr1.getDy());
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
|
@ -87,7 +87,7 @@ public class FtileGroup extends AbstractFtile {
|
|||||||
private final USymbol type;
|
private final USymbol type;
|
||||||
private final double roundCorner;
|
private final double roundCorner;
|
||||||
|
|
||||||
final public StyleSignature getDefaultStyleDefinitionPartition() {
|
final public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.partition);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.partition);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -100,8 +100,9 @@ public class FtileGroup extends AbstractFtile {
|
|||||||
|
|
||||||
final FontConfiguration fc;
|
final FontConfiguration fc;
|
||||||
final Style style;
|
final Style style;
|
||||||
|
final UStroke thickness;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
style = getDefaultStyleDefinitionPartition().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
this.shadowing = style.value(PName.Shadowing).asDouble();
|
this.shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
this.backColor = backColor == null
|
this.backColor = backColor == null
|
||||||
@ -110,6 +111,7 @@ public class FtileGroup extends AbstractFtile {
|
|||||||
this.borderColor = borderColor == null
|
this.borderColor = borderColor == null
|
||||||
? style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet())
|
? style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet())
|
||||||
: borderColor;
|
: borderColor;
|
||||||
|
thickness = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
this.backColor = backColor == null ? HColorUtils.WHITE : backColor;
|
this.backColor = backColor == null ? HColorUtils.WHITE : backColor;
|
||||||
this.borderColor = borderColor == null ? HColorUtils.BLACK : borderColor;
|
this.borderColor = borderColor == null ? HColorUtils.BLACK : borderColor;
|
||||||
@ -119,6 +121,7 @@ public class FtileGroup extends AbstractFtile {
|
|||||||
fc = new FontConfiguration(font, fontColor, skinParam.getHyperlinkColor(),
|
fc = new FontConfiguration(font, fontColor, skinParam.getHyperlinkColor(),
|
||||||
skinParam.useUnderlineForHyperlink(), skinParam.getTabSize());
|
skinParam.useUnderlineForHyperlink(), skinParam.getTabSize());
|
||||||
this.shadowing = skinParam().shadowing(null) ? 3 : 0;
|
this.shadowing = skinParam().shadowing(null) ? 3 : 0;
|
||||||
|
thickness = skinParam.getThickness(LineParam.partitionBorder, null);
|
||||||
}
|
}
|
||||||
if (title == null)
|
if (title == null)
|
||||||
this.name = TextBlockUtils.empty(0, 0);
|
this.name = TextBlockUtils.empty(0, 0);
|
||||||
@ -128,9 +131,8 @@ public class FtileGroup extends AbstractFtile {
|
|||||||
if (Display.isNull(displayNote))
|
if (Display.isNull(displayNote))
|
||||||
this.headerNote = TextBlockUtils.empty(0, 0);
|
this.headerNote = TextBlockUtils.empty(0, 0);
|
||||||
else
|
else
|
||||||
this.headerNote = new FloatingNote(displayNote, skinParam, style);
|
this.headerNote = new FloatingNote(displayNote, skinParam);
|
||||||
|
|
||||||
final UStroke thickness = skinParam.getThickness(LineParam.partitionBorder, null);
|
|
||||||
this.stroke = thickness == null ? new UStroke(2) : thickness;
|
this.stroke = thickness == null ? new UStroke(2) : thickness;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,16 +46,17 @@ import java.util.Set;
|
|||||||
import net.sourceforge.plantuml.FontParam;
|
import net.sourceforge.plantuml.FontParam;
|
||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.LineBreakStrategy;
|
import net.sourceforge.plantuml.LineBreakStrategy;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.Branch;
|
import net.sourceforge.plantuml.activitydiagram3.Branch;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractConnection;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractConnection;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
||||||
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDiamond;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDiamond;
|
||||||
@ -71,8 +72,11 @@ import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
|||||||
import net.sourceforge.plantuml.graphic.Rainbow;
|
import net.sourceforge.plantuml.graphic.Rainbow;
|
||||||
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.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
import net.sourceforge.plantuml.svek.ConditionStyle;
|
import net.sourceforge.plantuml.svek.ConditionStyle;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
||||||
|
|
||||||
@ -115,75 +119,44 @@ class FtileIfAndStop extends AbstractFtile {
|
|||||||
FtileFactory ftileFactory, ConditionStyle conditionStyle, Branch nonStop, ISkinParam skinParam,
|
FtileFactory ftileFactory, ConditionStyle conditionStyle, Branch nonStop, ISkinParam skinParam,
|
||||||
StringBounder stringBounder, Display labelTest) {
|
StringBounder stringBounder, Display labelTest) {
|
||||||
|
|
||||||
// backColor = HtmlColorUtils.BLUE;
|
|
||||||
|
|
||||||
// final Ftile tileNonStop = new FtileMinWidth(nonStop.getFtile(), 30);
|
|
||||||
final Ftile tileNonStop = nonStop.getFtile();
|
final Ftile tileNonStop = nonStop.getFtile();
|
||||||
|
|
||||||
final FontConfiguration fcTest = new FontConfiguration(skinParam, FontParam.ACTIVITY_DIAMOND, null);
|
|
||||||
|
|
||||||
final Ftile stopFtile = ftileFactory.stop(swimlane);
|
final Ftile stopFtile = ftileFactory.stop(swimlane);
|
||||||
|
|
||||||
// final TextBlock tb1 = Display.create(branch1.getLabelPositive(), fcArrow,
|
final UStroke thickness;
|
||||||
// HorizontalAlignment.LEFT,
|
final FontConfiguration fcTest;
|
||||||
// ftileFactory);
|
if (UseStyle.useBetaStyle()) {
|
||||||
// final TextBlock tb2 = Display.create(branch2.getLabelPositive(), fcArrow,
|
final Style style = StyleSignature.activityDiamond().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
// HorizontalAlignment.LEFT,
|
thickness = tileNonStop.getThickness(style);
|
||||||
// ftileFactory);
|
fcTest = new FontConfiguration(skinParam, style);
|
||||||
|
|
||||||
final Sheet sheet = Parser.build(fcTest, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT), skinParam, CreoleMode.FULL)
|
|
||||||
.createSheet(labelTest);
|
|
||||||
final SheetBlock1 sheetBlock1 = new SheetBlock1(sheet, LineBreakStrategy.NONE, skinParam.getPadding());
|
|
||||||
final TextBlock tbTest = new SheetBlock2(sheetBlock1, Hexagon.asStencil(sheetBlock1),
|
|
||||||
tileNonStop.getThickness());
|
|
||||||
|
|
||||||
final Ftile diamond1;
|
|
||||||
if (conditionStyle == ConditionStyle.INSIDE_HEXAGON) {
|
|
||||||
diamond1 = new FtileDiamondInside(tbTest, tileNonStop.skinParam(), backColor, borderColor, swimlane);
|
|
||||||
// .withWest(tb1).withEast(tb2);
|
|
||||||
} else if (conditionStyle == ConditionStyle.EMPTY_DIAMOND) {
|
|
||||||
diamond1 = new FtileDiamond(tileNonStop.skinParam(), backColor, borderColor, swimlane).withNorth(tbTest);
|
|
||||||
// .withWest(tb1).withEast(tb2).withNorth(tbTest);
|
|
||||||
} else {
|
} else {
|
||||||
throw new IllegalStateException();
|
thickness = tileNonStop.getThickness(null);
|
||||||
|
fcTest = new FontConfiguration(skinParam, FontParam.ACTIVITY_DIAMOND, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
// final Ftile diamond2;
|
final Sheet sheet = Parser
|
||||||
// if (tile1.calculateDimension(stringBounder).hasPointOut()
|
.build(fcTest, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT), skinParam, CreoleMode.FULL)
|
||||||
// && tile2.calculateDimension(stringBounder).hasPointOut()) {
|
.createSheet(labelTest);
|
||||||
// diamond2 = new FtileDiamond(tile1.shadowing(), backColor, borderColor,
|
final SheetBlock1 sheetBlock1 = new SheetBlock1(sheet, LineBreakStrategy.NONE, skinParam.getPadding());
|
||||||
// swimlane);
|
|
||||||
// } else {
|
final TextBlock tbTest = new SheetBlock2(sheetBlock1, Hexagon.asStencil(sheetBlock1), thickness);
|
||||||
// diamond2 = new FtileEmpty(tile1.shadowing(), Diamond.diamondHalfSize * 2,
|
|
||||||
// Diamond.diamondHalfSize * 2,
|
final Ftile diamond1;
|
||||||
// swimlane, swimlane);
|
if (conditionStyle == ConditionStyle.INSIDE_HEXAGON)
|
||||||
// }
|
diamond1 = new FtileDiamondInside(tbTest, tileNonStop.skinParam(), backColor, borderColor, swimlane);
|
||||||
|
else if (conditionStyle == ConditionStyle.EMPTY_DIAMOND)
|
||||||
|
diamond1 = new FtileDiamond(tileNonStop.skinParam(), backColor, borderColor, swimlane).withNorth(tbTest);
|
||||||
|
else
|
||||||
|
throw new IllegalStateException();
|
||||||
|
|
||||||
final FtileIfAndStop result = new FtileIfAndStop(diamond1, tileNonStop, arrowColor, stopFtile);
|
final FtileIfAndStop result = new FtileIfAndStop(diamond1, tileNonStop, arrowColor, stopFtile);
|
||||||
|
|
||||||
final List<Connection> conns = new ArrayList<>();
|
final List<Connection> conns = new ArrayList<>();
|
||||||
conns.add(result.new ConnectionHorizontal(arrowColor));
|
conns.add(result.new ConnectionHorizontal(arrowColor));
|
||||||
// conns.add(result.new ConnectionHorizontalThenVertical(tile2));
|
|
||||||
// if (tile1.calculateDimension(stringBounder).hasPointOut()
|
|
||||||
// && tile2.calculateDimension(stringBounder).hasPointOut()) {
|
|
||||||
// conns.add(result.new ConnectionVerticalThenHorizontal(tile1,
|
|
||||||
// branch1.getInlinkRenderingColor()));
|
|
||||||
// conns.add(result.new ConnectionVerticalThenHorizontal(tile2,
|
|
||||||
// branch2.getInlinkRenderingColor()));
|
|
||||||
// } else if (tile1.calculateDimension(stringBounder).hasPointOut()
|
|
||||||
// && tile2.calculateDimension(stringBounder).hasPointOut() == false) {
|
|
||||||
// conns.add(result.new ConnectionVerticalThenHorizontalDirect(tile1,
|
|
||||||
// branch1.getInlinkRenderingColor()));
|
|
||||||
// } else if (tile1.calculateDimension(stringBounder).hasPointOut() == false
|
|
||||||
// && tile2.calculateDimension(stringBounder).hasPointOut()) {
|
|
||||||
// conns.add(result.new ConnectionVerticalThenHorizontalDirect(tile2,
|
|
||||||
// branch2.getInlinkRenderingColor()));
|
|
||||||
// }
|
|
||||||
return FtileUtils.addConnection(result, conns);
|
return FtileUtils.addConnection(result, conns);
|
||||||
// return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private UTranslate getTranslate1(StringBounder stringBounder) {
|
private UTranslate getTranslate1(StringBounder stringBounder) {
|
||||||
// final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
|
||||||
final FtileGeometry dimTotal = calculateDimension(stringBounder);
|
final FtileGeometry dimTotal = calculateDimension(stringBounder);
|
||||||
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
||||||
final FtileGeometry dim1 = tile1.calculateDimension(stringBounder);
|
final FtileGeometry dim1 = tile1.calculateDimension(stringBounder);
|
||||||
@ -233,7 +206,7 @@ class FtileIfAndStop extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToRight());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToRight());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -256,18 +229,10 @@ class FtileIfAndStop extends AbstractFtile {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UTranslate getTranslateFor(Ftile child, StringBounder stringBounder) {
|
public UTranslate getTranslateFor(Ftile child, StringBounder stringBounder) {
|
||||||
if (child == diamond1) {
|
if (child == diamond1)
|
||||||
return getTranslateDiamond1(stringBounder);
|
return getTranslateDiamond1(stringBounder);
|
||||||
}
|
if (child == tile1)
|
||||||
if (child == tile1) {
|
|
||||||
return getTranslate1(stringBounder);
|
return getTranslate1(stringBounder);
|
||||||
}
|
|
||||||
// if (child == tile2) {
|
|
||||||
// return getTranslate2(stringBounder);
|
|
||||||
// }
|
|
||||||
// if (child == diamond2) {
|
|
||||||
// return getTranslateDiamond2(stringBounder);
|
|
||||||
// }
|
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,45 +252,6 @@ class FtileIfAndStop extends AbstractFtile {
|
|||||||
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
||||||
return dimDiamond1.appendBottom(dim1).addDim(0, getSuppHeight());
|
return dimDiamond1.appendBottom(dim1).addDim(0, getSuppHeight());
|
||||||
|
|
||||||
// final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
|
||||||
// if (tile1.calculateDimension(stringBounder).hasPointOut()) {
|
|
||||||
// return new FtileGeometry(dimTotal, getLeft(stringBounder), 0,
|
|
||||||
// dimTotal.getHeight());
|
|
||||||
// }
|
|
||||||
// return new FtileGeometry(dimTotal, getLeft(stringBounder), 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// private Dimension2D calculateDimensionInternal;
|
|
||||||
//
|
|
||||||
// private Dimension2D calculateDimensionInternal(StringBounder stringBounder) {
|
|
||||||
// if (calculateDimensionInternal == null) {
|
|
||||||
// calculateDimensionInternal = calculateDimensionInternalSlow(stringBounder);
|
|
||||||
// }
|
|
||||||
// return calculateDimensionInternal;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// private Dimension2D calculateDimensionInternalSlow(StringBounder
|
|
||||||
// stringBounder) {
|
|
||||||
// final Dimension2D dim1 = tile1.calculateDimension(stringBounder);
|
|
||||||
// final Dimension2D dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
|
||||||
// final Dimension2D dimStop2 = stop2.calculateDimension(stringBounder);
|
|
||||||
// final double width = Math.max(dim1.getWidth(),
|
|
||||||
// dimDiamond1.getWidth() + getDiamondStopDistance() + dimStop2.getWidth());
|
|
||||||
// return new Dimension2DDouble(width + 30, dim1.getHeight() +
|
|
||||||
// dimDiamond1.getHeight() + 40);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// private double getLeft(StringBounder stringBounder) {
|
|
||||||
// // return calculateDimension(stringBounder).getLeft();
|
|
||||||
// return
|
|
||||||
// tile1.calculateDimension(stringBounder).translate(getTranslate1(stringBounder)).getLeft();
|
|
||||||
// // final double left1 =
|
|
||||||
// tile1.calculateDimension(stringBounder).translate(getTranslate1(stringBounder)).getLeft();
|
|
||||||
// // // final double left2 =
|
|
||||||
// // //
|
|
||||||
// tile2.calculateDimension(stringBounder).translate(getTranslate2(stringBounder)).getLeft();
|
|
||||||
// // // return (left1 + left2) / 2;
|
|
||||||
// // return left1;
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -50,12 +50,12 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
|||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileEmpty;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileEmpty;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
||||||
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.MergeStrategy;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.MergeStrategy;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
||||||
@ -155,7 +155,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
// p2 = new Point2D.Double(p2.getX(), p1.getY());
|
// p2 = new Point2D.Double(p2.getX(), p1.getY());
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToRight());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToRight());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -198,7 +198,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
snake.addPoint(getP1(stringBounder));
|
snake.addPoint(getP1(stringBounder));
|
||||||
snake.addPoint(getP2(stringBounder));
|
snake.addPoint(getP2(stringBounder));
|
||||||
|
|
||||||
@ -210,7 +210,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
@ -255,7 +255,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
snake.addPoint(getP1(stringBounder));
|
snake.addPoint(getP1(stringBounder));
|
||||||
|
|
||||||
if (conditionEndStyle == ConditionEndStyle.DIAMOND) {
|
if (conditionEndStyle == ConditionEndStyle.DIAMOND) {
|
||||||
@ -277,7 +277,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
@ -331,7 +331,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
final double xmax = Math.max(x1 + Hexagon.hexagonHalfSize,
|
final double xmax = Math.max(x1 + Hexagon.hexagonHalfSize,
|
||||||
getTranslateForThen(stringBounder).getDx() + thenGeom.getWidth());
|
getTranslateForThen(stringBounder).getDx() + thenGeom.getWidth());
|
||||||
|
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToLeft()).emphasizeDirection(Direction.DOWN);
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToLeft()).emphasizeDirection(Direction.DOWN);
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(xmax, y1);
|
snake.addPoint(xmax, y1);
|
||||||
snake.addPoint(xmax, y2);
|
snake.addPoint(xmax, y2);
|
||||||
@ -378,7 +378,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
* ug.apply(new UTranslate(x2, y2 - Diamond.diamondHalfSize)).draw(new UEmpty(5,
|
* ug.apply(new UTranslate(x2, y2 - Diamond.diamondHalfSize)).draw(new UEmpty(5,
|
||||||
* Diamond.diamondHalfSize)); ug.draw(snake); }
|
* Diamond.diamondHalfSize)); ug.draw(snake); }
|
||||||
*/
|
*/
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToDown());
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(xmax, y1);
|
snake.addPoint(xmax, y1);
|
||||||
snake.addPoint(xmax, y2);
|
snake.addPoint(xmax, y2);
|
||||||
@ -461,7 +461,7 @@ public class FtileIfDown extends AbstractFtile {
|
|||||||
final double xmax = Math.max(x1 + Hexagon.hexagonHalfSize,
|
final double xmax = Math.max(x1 + Hexagon.hexagonHalfSize,
|
||||||
getTranslateForThen(stringBounder).getDx() + thenGeom.getWidth());
|
getTranslateForThen(stringBounder).getDx() + thenGeom.getWidth());
|
||||||
|
|
||||||
final Snake snake = Snake.create(endInlinkColor).withMerge(MergeStrategy.NONE);
|
final Snake snake = Snake.create(skinParam(), endInlinkColor).withMerge(MergeStrategy.NONE);
|
||||||
snake.addPoint(xmax, y2);
|
snake.addPoint(xmax, y2);
|
||||||
// ug.apply(new UTranslate(xmax, y2 - Diamond.diamondHalfSize)).draw(new
|
// ug.apply(new UTranslate(xmax, y2 - Diamond.diamondHalfSize)).draw(new
|
||||||
// UEmpty(5,
|
// UEmpty(5,
|
||||||
|
@ -258,7 +258,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToRight());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToRight());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -296,7 +296,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final UTranslate tr = getTranslateDiamond1(getFtile2(), ug.getStringBounder());
|
final UTranslate tr = getTranslateDiamond1(getFtile2(), ug.getStringBounder());
|
||||||
final Point2D p2 = tr.getTranslated(getFtile2().calculateDimension(ug.getStringBounder()).getPointIn());
|
final Point2D p2 = tr.getTranslated(getFtile2().calculateDimension(ug.getStringBounder()).getPointIn());
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
final Point2D p1 = calculateDimensionInternal(ug.getStringBounder()).getPointIn();
|
final Point2D p1 = calculateDimensionInternal(ug.getStringBounder()).getPointIn();
|
||||||
|
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -320,7 +320,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(ug.getStringBounder());
|
final Point2D p1 = getP1(ug.getStringBounder());
|
||||||
final UTranslate tr2 = getTranslate2(ug.getStringBounder());
|
final UTranslate tr2 = getTranslate2(ug.getStringBounder());
|
||||||
final Point2D p2 = tr2.getTranslated(getFtile2().calculateDimension(ug.getStringBounder()).getPointIn());
|
final Point2D p2 = tr2.getTranslated(getFtile2().calculateDimension(ug.getStringBounder()).getPointIn());
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2.getX(), p1.getY());
|
snake.addPoint(p2.getX(), p1.getY());
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
@ -361,7 +361,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
final double totalHeight = full.getHeight();
|
final double totalHeight = full.getHeight();
|
||||||
final Point2D p2 = new Point2D.Double(p1.getX(), totalHeight);
|
final Point2D p2 = new Point2D.Double(p1.getX(), totalHeight);
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown()).withLabel(out2, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).withLabel(out2, arrowHorizontalAlignment());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
if (nbOut == 0) {
|
if (nbOut == 0) {
|
||||||
@ -386,7 +386,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToDown());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -407,7 +407,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(ug.getStringBounder());
|
final Point2D p1 = getP1(ug.getStringBounder());
|
||||||
final Point2D p2 = getP2(ug.getStringBounder());
|
final Point2D p2 = getP2(ug.getStringBounder());
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToDown());
|
||||||
|
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
@ -441,7 +441,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
}
|
}
|
||||||
final Point2D p2 = new Point2D.Double(p1.getX(), totalHeight);
|
final Point2D p2 = new Point2D.Double(p1.getX(), totalHeight);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown()).withLabel(out2, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToDown()).withLabel(out2, arrowHorizontalAlignment());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -490,7 +490,7 @@ class FtileIfLongHorizontal extends AbstractFtile {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Snake s = Snake.create(arrowColor).withMerge(MergeStrategy.NONE);
|
final Snake s = Snake.create(skinParam(), arrowColor).withMerge(MergeStrategy.NONE);
|
||||||
s.addPoint(minX, totalDim.getHeight());
|
s.addPoint(minX, totalDim.getHeight());
|
||||||
s.addPoint(maxX, totalDim.getHeight());
|
s.addPoint(maxX, totalDim.getHeight());
|
||||||
ug.draw(s);
|
ug.draw(s);
|
||||||
|
@ -211,7 +211,7 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final UTranslate tr = getTranslateDiamond(getFtile2(), ug.getStringBounder());
|
final UTranslate tr = getTranslateDiamond(getFtile2(), ug.getStringBounder());
|
||||||
final Point2D p2 = tr.getTranslated(getFtile2().calculateDimension(ug.getStringBounder()).getPointIn());
|
final Point2D p2 = tr.getTranslated(getFtile2().calculateDimension(ug.getStringBounder()).getPointIn());
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
final Point2D p1 = calculateDimensionInternal(ug.getStringBounder()).getPointIn();
|
final Point2D p1 = calculateDimensionInternal(ug.getStringBounder()).getPointIn();
|
||||||
|
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -237,7 +237,7 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToDown());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2.getX(), p1.getY());
|
snake.addPoint(p2.getX(), p1.getY());
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
@ -274,7 +274,8 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown()).withLabel(label, VerticalAlignment.CENTER);
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToDown()).withLabel(label,
|
||||||
|
VerticalAlignment.CENTER);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -312,7 +313,8 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
final Point2D p2 = getTranslate2(stringBounder)
|
final Point2D p2 = getTranslate2(stringBounder)
|
||||||
.getTranslated(getFtile2().calculateDimension(stringBounder).getPointIn());
|
.getTranslated(getFtile2().calculateDimension(stringBounder).getPointIn());
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown()).withLabel(label, VerticalAlignment.CENTER);
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).withLabel(label,
|
||||||
|
VerticalAlignment.CENTER);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p1.getX(), p2.getY() - 15);
|
snake.addPoint(p1.getX(), p2.getY() - 15);
|
||||||
snake.addPoint(p2.getX(), p2.getY() - 15);
|
snake.addPoint(p2.getX(), p2.getY() - 15);
|
||||||
@ -341,7 +343,7 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
final Point2D p2 = getTranslateLastDiamond(stringBounder)
|
final Point2D p2 = getTranslateLastDiamond(stringBounder)
|
||||||
.getTranslated(getFtile2().calculateDimension(stringBounder).getPointIn());
|
.getTranslated(getFtile2().calculateDimension(stringBounder).getPointIn());
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p1.getX(), p2.getY() - 15);
|
snake.addPoint(p1.getX(), p2.getY() - 15);
|
||||||
snake.addPoint(p2.getX(), p2.getY() - 15);
|
snake.addPoint(p2.getX(), p2.getY() - 15);
|
||||||
@ -375,7 +377,7 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
|
|
||||||
final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToLeft());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToLeft());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p1.getX(), p1.getY() + 15);
|
snake.addPoint(p1.getX(), p1.getY() + 15);
|
||||||
snake.addPoint(dimTotal.getWidth(), p1.getY() + 15);
|
snake.addPoint(dimTotal.getWidth(), p1.getY() + 15);
|
||||||
@ -406,7 +408,7 @@ class FtileIfLongVertical extends AbstractFtile {
|
|||||||
|
|
||||||
final Point2D p2 = new Point2D.Double(dimTotal.getWidth(), p1.getY() + 15);
|
final Point2D p2 = new Point2D.Double(dimTotal.getWidth(), p1.getY() + 15);
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToRight());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToRight());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p1.getX(), p2.getY());
|
snake.addPoint(p1.getX(), p2.getY());
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
|
@ -77,7 +77,7 @@ public class FtileNoteAlone extends AbstractFtile implements Stencil, Styleable
|
|||||||
private final boolean withOutPoint;
|
private final boolean withOutPoint;
|
||||||
private final Swimlane swimlane;
|
private final Swimlane swimlane;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,13 +111,15 @@ public class FtileNoteAlone extends AbstractFtile implements Stencil, Styleable
|
|||||||
final HColor borderColor;
|
final HColor borderColor;
|
||||||
final double shadowing;
|
final double shadowing;
|
||||||
final LineBreakStrategy wrapWidth;
|
final LineBreakStrategy wrapWidth;
|
||||||
|
UStroke stroke = new UStroke();
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
final Style style = getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
final Style style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
getIHtmlColorSet());
|
getIHtmlColorSet());
|
||||||
borderColor = style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet());
|
borderColor = style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
shadowing = style.value(PName.Shadowing).asDouble();
|
shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
wrapWidth = style.wrapWidth();
|
wrapWidth = style.wrapWidth();
|
||||||
|
stroke = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
||||||
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
||||||
@ -130,9 +132,8 @@ public class FtileNoteAlone extends AbstractFtile implements Stencil, Styleable
|
|||||||
final Sheet sheet = Parser
|
final Sheet sheet = Parser
|
||||||
.build(fc, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT), skinParam, CreoleMode.FULL)
|
.build(fc, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT), skinParam, CreoleMode.FULL)
|
||||||
.createSheet(note);
|
.createSheet(note);
|
||||||
final TextBlock text = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this,
|
final TextBlock text = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this, stroke);
|
||||||
new UStroke(1));
|
opale = new Opale(shadowing, borderColor, noteBackgroundColor, text, false, stroke);
|
||||||
opale = new Opale(shadowing, borderColor, noteBackgroundColor, text, false);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,11 +54,11 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
|||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileEmpty;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileEmpty;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
||||||
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDiamond;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDiamond;
|
||||||
@ -74,7 +74,6 @@ import net.sourceforge.plantuml.graphic.TextBlock;
|
|||||||
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
import net.sourceforge.plantuml.svek.ConditionStyle;
|
import net.sourceforge.plantuml.svek.ConditionStyle;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UPolygon;
|
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
||||||
|
|
||||||
@ -219,7 +218,8 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown()).withLabel(tbin, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).withLabel(tbin,
|
||||||
|
arrowHorizontalAlignment());
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -259,7 +259,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
if (getFtile1().calculateDimension(stringBounder).hasPointOut() == false)
|
if (getFtile1().calculateDimension(stringBounder).hasPointOut() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown()).withLabel(tbout,
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).withLabel(tbout,
|
||||||
arrowHorizontalAlignment());
|
arrowHorizontalAlignment());
|
||||||
snake.addPoint(getP1(stringBounder));
|
snake.addPoint(getP1(stringBounder));
|
||||||
snake.addPoint(getP2(stringBounder));
|
snake.addPoint(getP2(stringBounder));
|
||||||
@ -273,7 +273,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
if (getFtile1().calculateDimension(stringBounder).hasPointOut() == false)
|
if (getFtile1().calculateDimension(stringBounder).hasPointOut() == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor);
|
final Snake snake = Snake.create(skinParam(), arrowColor);
|
||||||
final Point2D mp1a = translate1.getTranslated(getP1(stringBounder));
|
final Point2D mp1a = translate1.getTranslated(getP1(stringBounder));
|
||||||
final Point2D mp2b = translate2.getTranslated(getP2(stringBounder));
|
final Point2D mp2b = translate2.getTranslated(getP2(stringBounder));
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
@ -282,7 +282,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
snake.addPoint(mp2b.getX(), middle);
|
snake.addPoint(mp2b.getX(), middle);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
|
|
||||||
final Snake small = Snake.create(arrowColor, Arrows.asToDown()).withLabel(tbout,
|
final Snake small = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).withLabel(tbout,
|
||||||
arrowHorizontalAlignment());
|
arrowHorizontalAlignment());
|
||||||
small.addPoint(mp2b.getX(), middle);
|
small.addPoint(mp2b.getX(), middle);
|
||||||
small.addPoint(mp2b);
|
small.addPoint(mp2b);
|
||||||
@ -333,7 +333,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
|
|
||||||
final Snake snake;
|
final Snake snake;
|
||||||
if (x2 < x1_a) {
|
if (x2 < x1_a) {
|
||||||
snake = Snake.create(arrowColor, Arrows.asToLeft()).emphasizeDirection(Direction.UP);
|
snake = Snake.create(skinParam(), arrowColor, Arrows.asToLeft()).emphasizeDirection(Direction.UP);
|
||||||
snake.addPoint(x1_a, y1);
|
snake.addPoint(x1_a, y1);
|
||||||
if (x1_a < x1_b) {
|
if (x1_a < x1_b) {
|
||||||
snake.addPoint(x1_b, y1);
|
snake.addPoint(x1_b, y1);
|
||||||
@ -344,7 +344,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
x2 = p2.getX();
|
x2 = p2.getX();
|
||||||
snake = Snake.create(arrowColor, Arrows.asToRight()).emphasizeDirection(Direction.UP);
|
snake = Snake.create(skinParam(), arrowColor, Arrows.asToRight()).emphasizeDirection(Direction.UP);
|
||||||
snake.addPoint(x1_a, y1);
|
snake.addPoint(x1_a, y1);
|
||||||
final double middle = x1_a / 4 + x2 * 3 / 4;
|
final double middle = x1_a / 4 + x2 * 3 / 4;
|
||||||
snake.addPoint(middle, y1);
|
snake.addPoint(middle, y1);
|
||||||
@ -386,7 +386,8 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToUp()).withLabel(tbback, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToUp()).withLabel(tbback,
|
||||||
|
arrowHorizontalAlignment());
|
||||||
|
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x2, y1);
|
snake.addPoint(x2, y1);
|
||||||
@ -410,7 +411,8 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToUp()).withLabel(tbback, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToUp()).withLabel(tbback,
|
||||||
|
arrowHorizontalAlignment());
|
||||||
|
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x2, y1);
|
snake.addPoint(x2, y1);
|
||||||
@ -458,7 +460,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
x2 += dimDiamond1.getWidth();
|
x2 += dimDiamond1.getWidth();
|
||||||
final double y2 = p2.getY() + dimDiamond1.getHeight() / 2;
|
final double y2 = p2.getY() + dimDiamond1.getHeight() / 2;
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, x2 < x1 ? Arrows.asToLeft() : Arrows.asToRight());
|
Snake snake = Snake.create(skinParam(), arrowColor, x2 < x1 ? Arrows.asToLeft() : Arrows.asToRight());
|
||||||
if (label != null) {
|
if (label != null) {
|
||||||
snake = snake.withLabel(label, arrowHorizontalAlignment());
|
snake = snake.withLabel(label, arrowHorizontalAlignment());
|
||||||
}
|
}
|
||||||
@ -474,7 +476,7 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToLeft());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToLeft());
|
||||||
if (label != null) {
|
if (label != null) {
|
||||||
snake = snake.withLabel(label, arrowHorizontalAlignment());
|
snake = snake.withLabel(label, arrowHorizontalAlignment());
|
||||||
}
|
}
|
||||||
@ -516,8 +518,8 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToLeft()).emphasizeDirection(Direction.UP)
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToLeft())
|
||||||
.withLabel(tbback, arrowHorizontalAlignment());
|
.emphasizeDirection(Direction.UP).withLabel(tbback, arrowHorizontalAlignment());
|
||||||
final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
@ -540,8 +542,8 @@ class FtileRepeat extends AbstractFtile {
|
|||||||
@Override
|
@Override
|
||||||
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToLeft()).emphasizeDirection(Direction.UP)
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToLeft())
|
||||||
.withLabel(tbback, arrowHorizontalAlignment());
|
.emphasizeDirection(Direction.UP).withLabel(tbback, arrowHorizontalAlignment());
|
||||||
final Dimension2D dimRepeat = repeat.calculateDimension(stringBounder);
|
final Dimension2D dimRepeat = repeat.calculateDimension(stringBounder);
|
||||||
|
|
||||||
Point2D p1 = getP1(stringBounder);
|
Point2D p1 = getP1(stringBounder);
|
||||||
|
@ -52,11 +52,11 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
|||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileFactory;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
||||||
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.MergeStrategy;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.MergeStrategy;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
||||||
@ -189,7 +189,7 @@ class FtileWhile extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
snake.addPoint(getP1(stringBounder));
|
snake.addPoint(getP1(stringBounder));
|
||||||
snake.addPoint(getP2(stringBounder));
|
snake.addPoint(getP2(stringBounder));
|
||||||
|
|
||||||
@ -201,7 +201,8 @@ class FtileWhile extends AbstractFtile {
|
|||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
final Snake snake = Snake.create(arrowColor, Arrows.asToDown()).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown())
|
||||||
|
.withMerge(MergeStrategy.LIMITED);
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
@ -257,8 +258,8 @@ class FtileWhile extends AbstractFtile {
|
|||||||
final double half = (dimDiamond1.getOutY() - dimDiamond1.getInY()) / 2;
|
final double half = (dimDiamond1.getOutY() - dimDiamond1.getInY()) / 2;
|
||||||
final double y2 = p2.getY() + dimDiamond1.getInY() + half;
|
final double y2 = p2.getY() + dimDiamond1.getInY() + half;
|
||||||
|
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToLeft()).emphasizeDirection(Direction.UP)
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToLeft())
|
||||||
.withLabel(back, arrowHorizontalAlignment());
|
.emphasizeDirection(Direction.UP).withLabel(back, arrowHorizontalAlignment());
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
final double y1bis = Math.max(y1, getBottom(stringBounder)) + Hexagon.hexagonHalfSize;
|
final double y1bis = Math.max(y1, getBottom(stringBounder)) + Hexagon.hexagonHalfSize;
|
||||||
snake.addPoint(x1, y1bis);
|
snake.addPoint(x1, y1bis);
|
||||||
@ -275,7 +276,8 @@ class FtileWhile extends AbstractFtile {
|
|||||||
@Override
|
@Override
|
||||||
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToLeft()).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToLeft())
|
||||||
|
.withMerge(MergeStrategy.LIMITED);
|
||||||
final Dimension2D dimTotal = calculateDimension(stringBounder);
|
final Dimension2D dimTotal = calculateDimension(stringBounder);
|
||||||
final Point2D ap1 = getP1(stringBounder);
|
final Point2D ap1 = getP1(stringBounder);
|
||||||
final Point2D ap2 = getP2(stringBounder);
|
final Point2D ap2 = getP2(stringBounder);
|
||||||
@ -349,7 +351,7 @@ class FtileWhile extends AbstractFtile {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToUp()).withLabel(back,
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToUp()).withLabel(back,
|
||||||
arrowHorizontalAlignment());
|
arrowHorizontalAlignment());
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
final double y1bis = Math.max(y1, getBottom(stringBounder)) + Hexagon.hexagonHalfSize;
|
final double y1bis = Math.max(y1, getBottom(stringBounder)) + Hexagon.hexagonHalfSize;
|
||||||
@ -384,7 +386,7 @@ class FtileWhile extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToLeft()).withLabel(back,
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToLeft()).withLabel(back,
|
||||||
arrowHorizontalAlignment());
|
arrowHorizontalAlignment());
|
||||||
|
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
@ -430,7 +432,8 @@ class FtileWhile extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(endInlinkColor, Arrows.asToLeft()).emphasizeDirection(Direction.UP);
|
final Snake snake = Snake.create(skinParam(), endInlinkColor, Arrows.asToLeft())
|
||||||
|
.emphasizeDirection(Direction.UP);
|
||||||
final Dimension2D dimTotal = calculateDimension(stringBounder);
|
final Dimension2D dimTotal = calculateDimension(stringBounder);
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
final Point2D p2 = getP2(stringBounder);
|
final Point2D p2 = getP2(stringBounder);
|
||||||
@ -479,7 +482,7 @@ class FtileWhile extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(afterEndwhileColor).withMerge(MergeStrategy.LIMITED)
|
final Snake snake = Snake.create(skinParam(), afterEndwhileColor).withMerge(MergeStrategy.LIMITED)
|
||||||
.emphasizeDirection(Direction.DOWN);
|
.emphasizeDirection(Direction.DOWN);
|
||||||
|
|
||||||
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
||||||
@ -498,7 +501,7 @@ class FtileWhile extends AbstractFtile {
|
|||||||
|
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
|
|
||||||
final Snake snake2 = Snake.create(afterEndwhileColor);
|
final Snake snake2 = Snake.create(skinParam(), afterEndwhileColor);
|
||||||
snake2.addPoint(Hexagon.hexagonHalfSize, y2);
|
snake2.addPoint(Hexagon.hexagonHalfSize, y2);
|
||||||
snake2.addPoint(x2, y2);
|
snake2.addPoint(x2, y2);
|
||||||
// snake2.goUnmergeable(MergeStrategy.LIMITED);
|
// snake2.goUnmergeable(MergeStrategy.LIMITED);
|
||||||
@ -527,7 +530,7 @@ class FtileWhile extends AbstractFtile {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
|
||||||
final Snake snake = Snake.create(afterEndwhileColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), afterEndwhileColor, Arrows.asToDown());
|
||||||
|
|
||||||
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
final FtileGeometry dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
||||||
final Point2D p1 = getP1(stringBounder);
|
final Point2D p1 = getP1(stringBounder);
|
||||||
|
@ -88,7 +88,7 @@ public class FtileWithNoteOpale extends AbstractFtile implements Stencil, Stylea
|
|||||||
private final double suppSpace = 20;
|
private final double suppSpace = 20;
|
||||||
private final Swimlane swimlaneNote;
|
private final Swimlane swimlaneNote;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,11 +141,12 @@ public class FtileWithNoteOpale extends AbstractFtile implements Stencil, Stylea
|
|||||||
final HColor noteBackgroundColor;
|
final HColor noteBackgroundColor;
|
||||||
final HColor borderColor;
|
final HColor borderColor;
|
||||||
final FontConfiguration fc;
|
final FontConfiguration fc;
|
||||||
|
UStroke stroke = new UStroke();
|
||||||
|
|
||||||
final double shadowing;
|
final double shadowing;
|
||||||
final LineBreakStrategy wrapWidth;
|
final LineBreakStrategy wrapWidth;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
final Style style = getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder())
|
final Style style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder())
|
||||||
.eventuallyOverride(note.getColors());
|
.eventuallyOverride(note.getColors());
|
||||||
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
getIHtmlColorSet());
|
getIHtmlColorSet());
|
||||||
@ -153,6 +154,7 @@ public class FtileWithNoteOpale extends AbstractFtile implements Stencil, Stylea
|
|||||||
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
shadowing = style.value(PName.Shadowing).asDouble();
|
shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
wrapWidth = style.wrapWidth();
|
wrapWidth = style.wrapWidth();
|
||||||
|
stroke = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
||||||
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
||||||
@ -164,9 +166,8 @@ public class FtileWithNoteOpale extends AbstractFtile implements Stencil, Stylea
|
|||||||
final HorizontalAlignment align = skinParam.getHorizontalAlignment(AlignmentParam.noteTextAlignment, null,
|
final HorizontalAlignment align = skinParam.getHorizontalAlignment(AlignmentParam.noteTextAlignment, null,
|
||||||
false, null);
|
false, null);
|
||||||
final Sheet sheet = Parser.build(fc, align, skinParam, CreoleMode.FULL).createSheet(note.getDisplay());
|
final Sheet sheet = Parser.build(fc, align, skinParam, CreoleMode.FULL).createSheet(note.getDisplay());
|
||||||
final TextBlock text = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this,
|
final TextBlock text = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this, stroke);
|
||||||
new UStroke(1));
|
opale = new Opale(shadowing, borderColor, noteBackgroundColor, text, withLink, stroke);
|
||||||
opale = new Opale(shadowing, borderColor, noteBackgroundColor, text, withLink);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ public class FtileWithNotes extends AbstractFtile {
|
|||||||
|
|
||||||
private final double suppSpace = 20;
|
private final double suppSpace = 20;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -107,17 +107,18 @@ public class FtileWithNotes extends AbstractFtile {
|
|||||||
|
|
||||||
for (PositionedNote note : notes) {
|
for (PositionedNote note : notes) {
|
||||||
ISkinParam skinParam2 = skinParam;
|
ISkinParam skinParam2 = skinParam;
|
||||||
if (note.getColors() != null) {
|
if (note.getColors() != null)
|
||||||
skinParam2 = note.getColors().mute(skinParam2);
|
skinParam2 = note.getColors().mute(skinParam2);
|
||||||
}
|
|
||||||
final HColor noteBackgroundColor;
|
final HColor noteBackgroundColor;
|
||||||
final HColor borderColor;
|
final HColor borderColor;
|
||||||
final FontConfiguration fc;
|
final FontConfiguration fc;
|
||||||
final double shadowing;
|
final double shadowing;
|
||||||
|
UStroke stroke = new UStroke();
|
||||||
|
|
||||||
final LineBreakStrategy wrapWidth;
|
final LineBreakStrategy wrapWidth;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
final Style style = getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder())
|
final Style style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder())
|
||||||
.eventuallyOverride(note.getColors());
|
.eventuallyOverride(note.getColors());
|
||||||
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
getIHtmlColorSet());
|
getIHtmlColorSet());
|
||||||
@ -125,6 +126,7 @@ public class FtileWithNotes extends AbstractFtile {
|
|||||||
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
shadowing = style.value(PName.Shadowing).asDouble();
|
shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
wrapWidth = style.wrapWidth();
|
wrapWidth = style.wrapWidth();
|
||||||
|
stroke = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
noteBackgroundColor = rose.getHtmlColor(skinParam2, ColorParam.noteBackground);
|
noteBackgroundColor = rose.getHtmlColor(skinParam2, ColorParam.noteBackground);
|
||||||
borderColor = rose.getHtmlColor(skinParam2, ColorParam.noteBorder);
|
borderColor = rose.getHtmlColor(skinParam2, ColorParam.noteBorder);
|
||||||
@ -148,7 +150,7 @@ public class FtileWithNotes extends AbstractFtile {
|
|||||||
}
|
}
|
||||||
}, new UStroke());
|
}, new UStroke());
|
||||||
|
|
||||||
final Opale opale = new Opale(shadowing, borderColor, noteBackgroundColor, sheet2, false);
|
final Opale opale = new Opale(shadowing, borderColor, noteBackgroundColor, sheet2, false, stroke);
|
||||||
final TextBlock opaleMarged = TextBlockUtils.withMargin(opale, 10, 10);
|
final TextBlock opaleMarged = TextBlockUtils.withMargin(opale, 10, 10);
|
||||||
if (note.getNotePosition() == NotePosition.LEFT) {
|
if (note.getNotePosition() == NotePosition.LEFT) {
|
||||||
if (left == null) {
|
if (left == null) {
|
||||||
|
@ -63,6 +63,7 @@ import net.sourceforge.plantuml.graphic.TextBlock;
|
|||||||
import net.sourceforge.plantuml.style.Style;
|
import net.sourceforge.plantuml.style.Style;
|
||||||
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.color.HColor;
|
||||||
|
|
||||||
public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
||||||
|
|
||||||
@ -108,15 +109,15 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
|
|
||||||
private double getXSuppForDisplay(Ftile ftile, Display label) {
|
private double getXSuppForDisplay(Ftile ftile, Display label) {
|
||||||
final TextBlock text = getTextBlock(label);
|
final TextBlock text = getTextBlock(label);
|
||||||
if (text == null) {
|
if (text == null)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
final double textWidth = text.calculateDimension(getStringBounder()).getWidth();
|
final double textWidth = text.calculateDimension(getStringBounder()).getWidth();
|
||||||
final FtileGeometry ftileDim = ftile.calculateDimension(getStringBounder());
|
final FtileGeometry ftileDim = ftile.calculateDimension(getStringBounder());
|
||||||
final double pos2 = ftileDim.getLeft() + textWidth;
|
final double pos2 = ftileDim.getLeft() + textWidth;
|
||||||
if (pos2 > ftileDim.getWidth()) {
|
if (pos2 > ftileDim.getWidth())
|
||||||
return pos2 - ftileDim.getWidth();
|
return pos2 - ftileDim.getWidth();
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -130,18 +131,17 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
Ftile result = middle;
|
Ftile result = middle;
|
||||||
final List<Connection> conns = new ArrayList<>();
|
final List<Connection> conns = new ArrayList<>();
|
||||||
final Swimlane swimlaneBlack = in;
|
final Swimlane swimlaneBlack = in;
|
||||||
final Ftile black = new FtileBlackBlock(skinParam(),
|
final Style style = getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
getRose().getHtmlColor(skinParam(), ColorParam.activityBar), swimlaneBlack);
|
final Ftile black = new FtileBlackBlock(skinParam(), barColor(), swimlaneBlack);
|
||||||
double x = 0;
|
double x = 0;
|
||||||
for (Ftile tmp : list99) {
|
for (Ftile tmp : list99) {
|
||||||
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
||||||
final Rainbow def;
|
final Rainbow def;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
||||||
} else {
|
else
|
||||||
def = Rainbow.build(skinParam());
|
def = Rainbow.build(skinParam());
|
||||||
}
|
|
||||||
final Rainbow rainbow = tmp.getInLinkRendering().getRainbow(def);
|
final Rainbow rainbow = tmp.getInLinkRendering().getRainbow(def);
|
||||||
conns.add(new ConnectionIn(black, tmp, x, rainbow));
|
conns.add(new ConnectionIn(black, tmp, x, rainbow));
|
||||||
x += dim.getWidth();
|
x += dim.getWidth();
|
||||||
@ -158,9 +158,9 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
double result = 0;
|
double result = 0;
|
||||||
for (Ftile child : all) {
|
for (Ftile child : all) {
|
||||||
final TextBlock text = getTextBlock(child.getInLinkRendering().getDisplay());
|
final TextBlock text = getTextBlock(child.getInLinkRendering().getDisplay());
|
||||||
if (text == null) {
|
if (text == null)
|
||||||
continue;
|
continue;
|
||||||
}
|
|
||||||
final Dimension2D dim = text.calculateDimension(stringBounder);
|
final Dimension2D dim = text.calculateDimension(stringBounder);
|
||||||
result = Math.max(result, dim.getHeight());
|
result = Math.max(result, dim.getHeight());
|
||||||
|
|
||||||
@ -172,9 +172,9 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
double result = 0;
|
double result = 0;
|
||||||
for (Ftile child : all) {
|
for (Ftile child : all) {
|
||||||
final TextBlock text = getTextBlock(child.getOutLinkRendering().getDisplay());
|
final TextBlock text = getTextBlock(child.getOutLinkRendering().getDisplay());
|
||||||
if (text == null) {
|
if (text == null)
|
||||||
continue;
|
continue;
|
||||||
}
|
|
||||||
final Dimension2D dim = text.calculateDimension(stringBounder);
|
final Dimension2D dim = text.calculateDimension(stringBounder);
|
||||||
result = Math.max(result, dim.getHeight());
|
result = Math.max(result, dim.getHeight());
|
||||||
}
|
}
|
||||||
@ -188,35 +188,38 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
@Override
|
@Override
|
||||||
protected Ftile doStep2(Ftile middle, Ftile result) {
|
protected Ftile doStep2(Ftile middle, Ftile result) {
|
||||||
final Swimlane swimlaneBlack = out;
|
final Swimlane swimlaneBlack = out;
|
||||||
final Ftile out = new FtileBlackBlock(skinParam(), getRose().getHtmlColor(skinParam(), ColorParam.activityBar),
|
final Ftile out = new FtileBlackBlock(skinParam(), barColor(), swimlaneBlack);
|
||||||
swimlaneBlack);
|
|
||||||
((FtileBlackBlock) out).setBlackBlockDimension(result.calculateDimension(getStringBounder()).getWidth(),
|
((FtileBlackBlock) out).setBlackBlockDimension(result.calculateDimension(getStringBounder()).getWidth(),
|
||||||
barHeight);
|
barHeight);
|
||||||
if (label != null) {
|
if (label != null)
|
||||||
((FtileBlackBlock) out).setLabel(getTextBlock(Display.getWithNewlines(label)));
|
((FtileBlackBlock) out).setLabel(getTextBlock(Display.getWithNewlines(label)));
|
||||||
}
|
|
||||||
result = new FtileAssemblySimple(result, out);
|
result = new FtileAssemblySimple(result, out);
|
||||||
final List<Connection> conns = new ArrayList<>();
|
final List<Connection> conns = new ArrayList<>();
|
||||||
|
final Style style = getStyleSignatureArrow().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
double x = 0;
|
double x = 0;
|
||||||
for (Ftile tmp : list99) {
|
for (Ftile tmp : list99) {
|
||||||
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
||||||
final Rainbow def;
|
final Rainbow def;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinitionArrow().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
||||||
} else {
|
else
|
||||||
def = Rainbow.build(skinParam());
|
def = Rainbow.build(skinParam());
|
||||||
}
|
|
||||||
final Rainbow rainbow = tmp.getOutLinkRendering().getRainbow(def);
|
final Rainbow rainbow = tmp.getOutLinkRendering().getRainbow(def);
|
||||||
if (tmp.calculateDimension(getStringBounder()).hasPointOut()) {
|
if (tmp.calculateDimension(getStringBounder()).hasPointOut())
|
||||||
conns.add(new ConnectionOut(tmp, out, x, rainbow, getJustBeforeBar2(middle, getStringBounder())));
|
conns.add(new ConnectionOut(tmp, out, x, rainbow, getJustBeforeBar2(middle, getStringBounder())));
|
||||||
}
|
|
||||||
x += dim.getWidth();
|
x += dim.getWidth();
|
||||||
}
|
}
|
||||||
result = FtileUtils.addConnection(result, conns);
|
result = FtileUtils.addConnection(result, conns);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private HColor barColor() {
|
||||||
|
return getRose().getHtmlColor(skinParam(), ColorParam.activityBar);
|
||||||
|
}
|
||||||
|
|
||||||
class ConnectionIn extends AbstractConnection implements ConnectionTranslatable {
|
class ConnectionIn extends AbstractConnection implements ConnectionTranslatable {
|
||||||
|
|
||||||
private final double x;
|
private final double x;
|
||||||
@ -233,10 +236,10 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo2 = getFtile2().calculateDimension(getStringBounder());
|
final FtileGeometry geo2 = getFtile2().calculateDimension(getStringBounder());
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D p1 = new Point2D.Double(geo2.getLeft(), 0);
|
final Point2D p1 = new Point2D.Double(geo2.getLeft(), 0);
|
||||||
final Point2D p2 = new Point2D.Double(geo2.getLeft(), geo2.getInY());
|
final Point2D p2 = new Point2D.Double(geo2.getLeft(), geo2.getInY());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -251,10 +254,10 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
final Point2D p1 = new Point2D.Double(geo2.getLeft(), 0);
|
final Point2D p1 = new Point2D.Double(geo2.getLeft(), 0);
|
||||||
final Point2D p2 = new Point2D.Double(geo2.getLeft(), geo2.getInY());
|
final Point2D p2 = new Point2D.Double(geo2.getLeft(), geo2.getInY());
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown()).ignoreForCompression();
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).ignoreForCompression();
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = mp1a.getY() + 4;
|
final double middle = mp1a.getY() + 4;
|
||||||
@ -284,13 +287,13 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo1 = getFtile1().calculateDimension(getStringBounder());
|
final FtileGeometry geo1 = getFtile1().calculateDimension(getStringBounder());
|
||||||
if (geo1.hasPointOut() == false) {
|
if (geo1.hasPointOut() == false)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D p1 = new Point2D.Double(geo1.getLeft(), barHeight + geo1.getOutY());
|
final Point2D p1 = new Point2D.Double(geo1.getLeft(), barHeight + geo1.getOutY());
|
||||||
final Point2D p2 = new Point2D.Double(geo1.getLeft(), justBeforeBar2);
|
final Point2D p2 = new Point2D.Double(geo1.getLeft(), justBeforeBar2);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -302,16 +305,16 @@ public class ParallelBuilderFork extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo = getFtile1().calculateDimension(getStringBounder());
|
final FtileGeometry geo = getFtile1().calculateDimension(getStringBounder());
|
||||||
if (geo.hasPointOut() == false) {
|
if (geo.hasPointOut() == false)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
final Point2D p1 = new Point2D.Double(geo.getLeft(), barHeight + geo.getOutY());
|
final Point2D p1 = new Point2D.Double(geo.getLeft(), barHeight + geo.getOutY());
|
||||||
final Point2D p2 = new Point2D.Double(geo.getLeft(), justBeforeBar2);
|
final Point2D p2 = new Point2D.Double(geo.getLeft(), justBeforeBar2);
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown()).ignoreForCompression();
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).ignoreForCompression();
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = mp2b.getY() - 14;
|
final double middle = mp2b.getY() - 14;
|
||||||
|
@ -57,6 +57,7 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.vertical.FtileDiamond;
|
|||||||
import net.sourceforge.plantuml.cucadiagram.Display;
|
import net.sourceforge.plantuml.cucadiagram.Display;
|
||||||
import net.sourceforge.plantuml.graphic.Rainbow;
|
import net.sourceforge.plantuml.graphic.Rainbow;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
import net.sourceforge.plantuml.style.Style;
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UPolygon;
|
import net.sourceforge.plantuml.ugraphic.UPolygon;
|
||||||
@ -81,7 +82,7 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
||||||
final Rainbow def;
|
final Rainbow def;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
Style style = getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
||||||
} else {
|
} else {
|
||||||
def = Rainbow.build(skinParam());
|
def = Rainbow.build(skinParam());
|
||||||
@ -100,8 +101,20 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Ftile doStep2(Ftile inner, Ftile result) {
|
protected Ftile doStep2(Ftile inner, Ftile result) {
|
||||||
final HColor borderColor = getRose().getHtmlColor(skinParam(), ColorParam.activityDiamondBorder);
|
final Style style = getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
final HColor backColor = getRose().getHtmlColor(skinParam(), ColorParam.activityDiamondBackground);
|
final HColor borderColor;
|
||||||
|
final HColor backColor;
|
||||||
|
|
||||||
|
if (UseStyle.useBetaStyle()) {
|
||||||
|
borderColor = style.value(PName.LineColor).asColor(skinParam().getThemeStyle(),
|
||||||
|
skinParam().getIHtmlColorSet());
|
||||||
|
backColor = style.value(PName.BackGroundColor).asColor(skinParam().getThemeStyle(),
|
||||||
|
skinParam().getIHtmlColorSet());
|
||||||
|
} else {
|
||||||
|
borderColor = getRose().getHtmlColor(skinParam(), ColorParam.activityDiamondBorder);
|
||||||
|
backColor = getRose().getHtmlColor(skinParam(), ColorParam.activityDiamondBackground);
|
||||||
|
|
||||||
|
}
|
||||||
final Ftile out = new FtileDiamond(skinParam(), backColor, borderColor, swimlaneOutForStep2());
|
final Ftile out = new FtileDiamond(skinParam(), backColor, borderColor, swimlaneOutForStep2());
|
||||||
result = new FtileAssemblySimple(result, out);
|
result = new FtileAssemblySimple(result, out);
|
||||||
final List<Connection> conns = new ArrayList<>();
|
final List<Connection> conns = new ArrayList<>();
|
||||||
@ -112,16 +125,15 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
final Dimension2D dim = tmp.calculateDimension(getStringBounder());
|
||||||
final UTranslate translate0 = new UTranslate(x, barHeight);
|
final UTranslate translate0 = new UTranslate(x, barHeight);
|
||||||
final Rainbow def;
|
final Rainbow def;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
def = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
||||||
} else {
|
else
|
||||||
def = Rainbow.build(skinParam());
|
def = Rainbow.build(skinParam());
|
||||||
}
|
|
||||||
final Rainbow rainbow = tmp.getOutLinkRendering().getRainbow(def);
|
final Rainbow rainbow = tmp.getOutLinkRendering().getRainbow(def);
|
||||||
if (tmp.calculateDimension(getStringBounder()).hasPointOut()) {
|
if (tmp.calculateDimension(getStringBounder()).hasPointOut())
|
||||||
conns.add(new ConnectionHorizontalThenVertical(tmp, out, rainbow, translate0, diamondTranslate));
|
conns.add(new ConnectionHorizontalThenVertical(tmp, out, rainbow, translate0, diamondTranslate));
|
||||||
}
|
|
||||||
x += dim.getWidth();
|
x += dim.getWidth();
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -153,14 +165,14 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
|
|
||||||
final UTranslate arrival = arrivalOnDiamond(stringBounder, p1.getX());
|
final UTranslate arrival = arrivalOnDiamond(stringBounder, p1.getX());
|
||||||
final UPolygon endDecoration;
|
final UPolygon endDecoration;
|
||||||
if (arrival.getDx() < 0) {
|
if (arrival.getDx() < 0)
|
||||||
endDecoration = Arrows.asToRight();
|
endDecoration = Arrows.asToRight();
|
||||||
} else if (arrival.getDx() > 0) {
|
else if (arrival.getDx() > 0)
|
||||||
endDecoration = Arrows.asToLeft();
|
endDecoration = Arrows.asToLeft();
|
||||||
} else {
|
else
|
||||||
endDecoration = Arrows.asToDown();
|
endDecoration = Arrows.asToDown();
|
||||||
}
|
|
||||||
final Snake snake = Snake.create(arrowColor, endDecoration);
|
final Snake snake = Snake.create(skinParam(), arrowColor, endDecoration);
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x1, y2);
|
snake.addPoint(x1, y2);
|
||||||
snake.addPoint(x2, y2);
|
snake.addPoint(x2, y2);
|
||||||
@ -188,13 +200,13 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
final double b = result.getX() + dim.getWidth() / 2;
|
final double b = result.getX() + dim.getWidth() / 2;
|
||||||
|
|
||||||
final UTranslate arrival;
|
final UTranslate arrival;
|
||||||
if (startX < a) {
|
if (startX < a)
|
||||||
arrival = new UTranslate(-dim.getWidth() / 2, -dim.getHeight() / 2);
|
arrival = new UTranslate(-dim.getWidth() / 2, -dim.getHeight() / 2);
|
||||||
} else if (startX > b) {
|
else if (startX > b)
|
||||||
arrival = new UTranslate(dim.getWidth() / 2, -dim.getHeight() / 2);
|
arrival = new UTranslate(dim.getWidth() / 2, -dim.getHeight() / 2);
|
||||||
} else {
|
else
|
||||||
arrival = new UTranslate(0, -dim.getHeight());
|
arrival = new UTranslate(0, -dim.getHeight());
|
||||||
}
|
|
||||||
return arrival;
|
return arrival;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -216,10 +228,10 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo = getFtile2().calculateDimension(getStringBounder());
|
final FtileGeometry geo = getFtile2().calculateDimension(getStringBounder());
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
snake.addPoint(geo.getLeft(), 0);
|
snake.addPoint(geo.getLeft(), 0);
|
||||||
snake.addPoint(geo.getLeft(), geo.getInY());
|
snake.addPoint(geo.getLeft(), geo.getInY());
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -232,10 +244,10 @@ public class ParallelBuilderMerge extends AbstractParallelFtilesBuilder {
|
|||||||
final Point2D p1 = new Point2D.Double(geo.getLeft(), 0);
|
final Point2D p1 = new Point2D.Double(geo.getLeft(), 0);
|
||||||
final Point2D p2 = new Point2D.Double(geo.getLeft(), geo.getInY());
|
final Point2D p2 = new Point2D.Double(geo.getLeft(), geo.getInY());
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = mp1a.getY() + 4;
|
final double middle = mp1a.getY() + 4;
|
||||||
|
@ -70,7 +70,7 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -79,32 +79,30 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
Ftile result = inner;
|
Ftile result = inner;
|
||||||
final List<Connection> conns = new ArrayList<>();
|
final List<Connection> conns = new ArrayList<>();
|
||||||
final Rainbow thinColor;
|
final Rainbow thinColor;
|
||||||
if (UseStyle.useBetaStyle()) {
|
final Style style = getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
if (UseStyle.useBetaStyle())
|
||||||
thinColor = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
thinColor = Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle());
|
||||||
} else {
|
else
|
||||||
thinColor = result.getInLinkRendering().getRainbow(Rainbow.build(skinParam()));
|
thinColor = result.getInLinkRendering().getRainbow(Rainbow.build(skinParam()));
|
||||||
}
|
|
||||||
final Ftile thin = new FtileThinSplit(skinParam(), getThin1Color(thinColor), list99.get(0).getSwimlaneIn());
|
final Ftile thin = new FtileThinSplit(skinParam(), getThin1Color(thinColor), list99.get(0).getSwimlaneIn());
|
||||||
double x = 0;
|
double x = 0;
|
||||||
double first = 0;
|
double first = 0;
|
||||||
double last = 0;
|
double last = 0;
|
||||||
for (Ftile tmp : list99) {
|
for (Ftile tmp : list99) {
|
||||||
final FtileGeometry dim = tmp.calculateDimension(getStringBounder());
|
final FtileGeometry dim = tmp.calculateDimension(getStringBounder());
|
||||||
if (first == 0) {
|
if (first == 0)
|
||||||
first = x + dim.getLeft();
|
first = x + dim.getLeft();
|
||||||
}
|
|
||||||
last = x + dim.getLeft();
|
last = x + dim.getLeft();
|
||||||
|
|
||||||
final LinkRendering inLinkRendering = tmp.getInLinkRendering();
|
final LinkRendering inLinkRendering = tmp.getInLinkRendering();
|
||||||
final Rainbow rainbow;
|
final Rainbow rainbow;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
rainbow = inLinkRendering
|
rainbow = inLinkRendering
|
||||||
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
||||||
} else {
|
else
|
||||||
rainbow = inLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
rainbow = inLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
||||||
}
|
|
||||||
|
|
||||||
conns.add(new ConnectionIn(thin, tmp, x, rainbow));
|
conns.add(new ConnectionIn(thin, tmp, x, rainbow));
|
||||||
x += dim.getWidth();
|
x += dim.getWidth();
|
||||||
@ -112,42 +110,40 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
|
|
||||||
result = FtileUtils.addConnection(result, conns);
|
result = FtileUtils.addConnection(result, conns);
|
||||||
final FtileGeometry geom = result.calculateDimension(getStringBounder());
|
final FtileGeometry geom = result.calculateDimension(getStringBounder());
|
||||||
if (last < geom.getLeft()) {
|
if (last < geom.getLeft())
|
||||||
last = geom.getLeft();
|
last = geom.getLeft();
|
||||||
}
|
|
||||||
if (first > geom.getLeft()) {
|
if (first > geom.getLeft())
|
||||||
first = geom.getLeft();
|
first = geom.getLeft();
|
||||||
}
|
|
||||||
((FtileThinSplit) thin).setGeom(first, last, result.calculateDimension(getStringBounder()).getWidth());
|
((FtileThinSplit) thin).setGeom(first, last, result.calculateDimension(getStringBounder()).getWidth());
|
||||||
|
|
||||||
return new FtileAssemblySimple(thin, result);
|
return new FtileAssemblySimple(thin, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
private HColor getThin1Color(final Rainbow thinColor) {
|
private HColor getThin1Color(final Rainbow thinColor) {
|
||||||
|
final Style style = getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
for (Ftile tmp : list99) {
|
for (Ftile tmp : list99) {
|
||||||
final Rainbow rainbow;
|
final Rainbow rainbow;
|
||||||
final LinkRendering inLinkRendering = tmp.getInLinkRendering();
|
final LinkRendering inLinkRendering = tmp.getInLinkRendering();
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
rainbow = inLinkRendering
|
rainbow = inLinkRendering
|
||||||
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
||||||
} else {
|
else
|
||||||
rainbow = inLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
rainbow = inLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
||||||
}
|
|
||||||
if (rainbow.isInvisible() == false) {
|
if (rainbow.isInvisible() == false)
|
||||||
return thinColor.getColor();
|
return thinColor.getColor();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean hasOut() {
|
private boolean hasOut() {
|
||||||
for (Ftile tmp : list99) {
|
for (Ftile tmp : list99)
|
||||||
final boolean hasOutTmp = tmp.calculateDimension(getStringBounder()).hasPointOut();
|
if (tmp.calculateDimension(getStringBounder()).hasPointOut())
|
||||||
if (hasOutTmp) {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,19 +151,17 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
protected Ftile doStep2(Ftile inner, Ftile result) {
|
protected Ftile doStep2(Ftile inner, Ftile result) {
|
||||||
|
|
||||||
final FtileGeometry geom = result.calculateDimension(getStringBounder());
|
final FtileGeometry geom = result.calculateDimension(getStringBounder());
|
||||||
if (hasOut() == false) {
|
if (hasOut() == false)
|
||||||
return new FtileKilled(result);
|
return new FtileKilled(result);
|
||||||
}
|
|
||||||
|
|
||||||
|
final Style style = getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
final Rainbow thinColor;
|
final Rainbow thinColor;
|
||||||
final LinkRendering inLinkRendering = result.getInLinkRendering();
|
final LinkRendering inLinkRendering = result.getInLinkRendering();
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
thinColor = inLinkRendering
|
thinColor = inLinkRendering
|
||||||
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
||||||
} else {
|
else
|
||||||
thinColor = inLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
thinColor = inLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
||||||
}
|
|
||||||
|
|
||||||
final Ftile out = new FtileThinSplit(skinParam(), thinColor.getColor(), swimlaneOutForStep2());
|
final Ftile out = new FtileThinSplit(skinParam(), thinColor.getColor(), swimlaneOutForStep2());
|
||||||
result = new FtileAssemblySimple(result, out);
|
result = new FtileAssemblySimple(result, out);
|
||||||
@ -179,33 +173,31 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
final UTranslate translate0 = UTranslate.dy(1.5);
|
final UTranslate translate0 = UTranslate.dy(1.5);
|
||||||
final FtileGeometry dim = tmp.calculateDimension(getStringBounder());
|
final FtileGeometry dim = tmp.calculateDimension(getStringBounder());
|
||||||
if (dim.hasPointOut()) {
|
if (dim.hasPointOut()) {
|
||||||
if (first == 0) {
|
if (first == 0)
|
||||||
first = x + dim.getLeft();
|
first = x + dim.getLeft();
|
||||||
}
|
|
||||||
last = x + dim.getLeft();
|
last = x + dim.getLeft();
|
||||||
}
|
}
|
||||||
|
|
||||||
final Rainbow rainbow;
|
final Rainbow rainbow;
|
||||||
final LinkRendering outLinkRendering = tmp.getOutLinkRendering();
|
final LinkRendering outLinkRendering = tmp.getOutLinkRendering();
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle())
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
|
||||||
rainbow = outLinkRendering
|
rainbow = outLinkRendering
|
||||||
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
.getRainbow(Rainbow.build(style, skinParam().getIHtmlColorSet(), skinParam().getThemeStyle()));
|
||||||
} else {
|
else
|
||||||
rainbow = outLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
rainbow = outLinkRendering.getRainbow(Rainbow.build(skinParam()));
|
||||||
}
|
|
||||||
|
|
||||||
if (tmp.calculateDimension(getStringBounder()).hasPointOut()) {
|
if (tmp.calculateDimension(getStringBounder()).hasPointOut())
|
||||||
conns.add(new ConnectionOut(translate0, tmp, out, x, rainbow, getHeightOfMiddle(inner)));
|
conns.add(new ConnectionOut(translate0, tmp, out, x, rainbow, getHeightOfMiddle(inner)));
|
||||||
}
|
|
||||||
x += dim.getWidth();
|
x += dim.getWidth();
|
||||||
}
|
}
|
||||||
if (last < geom.getLeft()) {
|
if (last < geom.getLeft())
|
||||||
last = geom.getLeft();
|
last = geom.getLeft();
|
||||||
}
|
|
||||||
if (first > geom.getLeft()) {
|
if (first > geom.getLeft())
|
||||||
first = geom.getLeft();
|
first = geom.getLeft();
|
||||||
}
|
|
||||||
((FtileThinSplit) out).setGeom(first, last, geom.getWidth());
|
((FtileThinSplit) out).setGeom(first, last, geom.getWidth());
|
||||||
result = FtileUtils.addConnection(result, conns);
|
result = FtileUtils.addConnection(result, conns);
|
||||||
return result;
|
return result;
|
||||||
@ -227,10 +219,10 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo = getFtile2().calculateDimension(getStringBounder());
|
final FtileGeometry geo = getFtile2().calculateDimension(getStringBounder());
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
snake.addPoint(geo.getLeft(), 0);
|
snake.addPoint(geo.getLeft(), 0);
|
||||||
snake.addPoint(geo.getLeft(), geo.getInY());
|
snake.addPoint(geo.getLeft(), geo.getInY());
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -243,10 +235,10 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
final Point2D p1 = new Point2D.Double(geo.getLeft(), 0);
|
final Point2D p1 = new Point2D.Double(geo.getLeft(), 0);
|
||||||
final Point2D p2 = new Point2D.Double(geo.getLeft(), geo.getInY());
|
final Point2D p2 = new Point2D.Double(geo.getLeft(), geo.getInY());
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = mp1a.getY() + 4;
|
final double middle = mp1a.getY() + 4;
|
||||||
@ -279,13 +271,13 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo = getFtile1().calculateDimension(getStringBounder());
|
final FtileGeometry geo = getFtile1().calculateDimension(getStringBounder());
|
||||||
if (geo.hasPointOut() == false) {
|
if (geo.hasPointOut() == false)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D p1 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), geo.getOutY()));
|
final Point2D p1 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), geo.getOutY()));
|
||||||
final Point2D p2 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), height));
|
final Point2D p2 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), height));
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -297,16 +289,16 @@ public class ParallelBuilderSplit extends AbstractParallelFtilesBuilder {
|
|||||||
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
||||||
ug = ug.apply(UTranslate.dx(x));
|
ug = ug.apply(UTranslate.dx(x));
|
||||||
final FtileGeometry geo = getFtile1().calculateDimension(getStringBounder());
|
final FtileGeometry geo = getFtile1().calculateDimension(getStringBounder());
|
||||||
if (geo.hasPointOut() == false) {
|
if (geo.hasPointOut() == false)
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
final Point2D p1 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), geo.getOutY()));
|
final Point2D p1 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), geo.getOutY()));
|
||||||
final Point2D p2 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), height));
|
final Point2D p2 = translate0.getTranslated(new Point2D.Double(geo.getLeft(), height));
|
||||||
|
|
||||||
Snake snake = Snake.create(arrowColor, Arrows.asToDown());
|
Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
if (Display.isNull(label) == false) {
|
if (Display.isNull(label) == false)
|
||||||
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
snake = snake.withLabel(getTextBlock(label), arrowHorizontalAlignment());
|
||||||
}
|
|
||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
final double middle = mp2b.getY() - 14;
|
final double middle = mp2b.getY() - 14;
|
||||||
|
@ -102,6 +102,10 @@ public class VCompactFactory implements FtileFactory {
|
|||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.circle, SName.stop);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.circle, SName.stop);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private StyleSignature getSignatureCircleSpot() {
|
||||||
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.circle, SName.spot);
|
||||||
|
}
|
||||||
|
|
||||||
private StyleSignature getSignatureCircleStart() {
|
private StyleSignature getSignatureCircleStart() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.circle, SName.start);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.circle, SName.start);
|
||||||
}
|
}
|
||||||
@ -135,7 +139,11 @@ public class VCompactFactory implements FtileFactory {
|
|||||||
|
|
||||||
public Ftile spot(Swimlane swimlane, String spot, HColor color) {
|
public Ftile spot(Swimlane swimlane, String spot, HColor color) {
|
||||||
final UFont font = skinParam.getFont(null, false, FontParam.ACTIVITY);
|
final UFont font = skinParam.getFont(null, false, FontParam.ACTIVITY);
|
||||||
return new FtileCircleSpot(skinParam(), swimlane, spot, font, color);
|
Style style = null;
|
||||||
|
if (UseStyle.useBetaStyle()) {
|
||||||
|
style = getSignatureCircleSpot().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
|
}
|
||||||
|
return new FtileCircleSpot(skinParam(), swimlane, spot, font, color, style);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Ftile end(Swimlane swimlane) {
|
public Ftile end(Swimlane swimlane) {
|
||||||
|
@ -71,6 +71,7 @@ import net.sourceforge.plantuml.style.Style;
|
|||||||
import net.sourceforge.plantuml.style.StyleSignature;
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
import net.sourceforge.plantuml.svek.ConditionEndStyle;
|
import net.sourceforge.plantuml.svek.ConditionEndStyle;
|
||||||
import net.sourceforge.plantuml.svek.ConditionStyle;
|
import net.sourceforge.plantuml.svek.ConditionStyle;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
||||||
|
|
||||||
public class ConditionalBuilder {
|
public class ConditionalBuilder {
|
||||||
@ -95,11 +96,11 @@ public class ConditionalBuilder {
|
|||||||
private final Ftile tile2;
|
private final Ftile tile2;
|
||||||
private final Url url;
|
private final Url url;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinitionDiamond() {
|
private StyleSignature getStyleSignatureDiamond() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity, SName.diamond);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity, SName.diamond);
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinitionArrow() {
|
private StyleSignature getStyleSignatureArrow() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -114,19 +115,24 @@ public class ConditionalBuilder {
|
|||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
if (arrowColor == null)
|
if (arrowColor == null)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
final Style styleArrow = getDefaultStyleDefinitionArrow()
|
final Style styleArrow = getStyleSignatureArrow().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
final Style styleDiamond = getStyleSignatureDiamond().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
final Style styleDiamond = getDefaultStyleDefinitionDiamond()
|
|
||||||
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
|
||||||
this.diamondLineBreak = styleDiamond.wrapWidth();
|
this.diamondLineBreak = styleDiamond.wrapWidth();
|
||||||
this.labelLineBreak = styleArrow.wrapWidth();
|
this.labelLineBreak = styleArrow.wrapWidth();
|
||||||
this.borderColor = borderColor; /*styleDiamond.value(PName.LineColor).asColor(skinParam.getThemeStyle(),
|
this.borderColor = borderColor; /*
|
||||||
skinParam.getIHtmlColorSet());*/
|
* styleDiamond.value(PName.LineColor).asColor(skinParam.getThemeStyle(),
|
||||||
this.backColor = backColor;/*styleDiamond.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
* skinParam.getIHtmlColorSet());
|
||||||
skinParam.getIHtmlColorSet())*/;
|
*/
|
||||||
this.arrowColor = arrowColor;/* Rainbow.fromColor(
|
this.backColor = backColor;
|
||||||
styleArrow.value(PName.LineColor).asColor(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet()),
|
/*
|
||||||
null);*/
|
* styleDiamond.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
|
* skinParam.getIHtmlColorSet())
|
||||||
|
*/;
|
||||||
|
this.arrowColor = arrowColor;/*
|
||||||
|
* Rainbow.fromColor(
|
||||||
|
* styleArrow.value(PName.LineColor).asColor(skinParam.getThemeStyle(),
|
||||||
|
* skinParam.getIHtmlColorSet()), null);
|
||||||
|
*/
|
||||||
this.fontTest = styleDiamond.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
|
this.fontTest = styleDiamond.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
|
||||||
this.fontArrow = styleArrow.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
|
this.fontArrow = styleArrow.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
|
||||||
} else {
|
} else {
|
||||||
@ -255,7 +261,10 @@ public class ConditionalBuilder {
|
|||||||
final Sheet sheet = Parser.build(fontTest, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT),
|
final Sheet sheet = Parser.build(fontTest, skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT),
|
||||||
skinParam, CreoleMode.FULL).createSheet(labelTest);
|
skinParam, CreoleMode.FULL).createSheet(labelTest);
|
||||||
final SheetBlock1 sheetBlock1 = new SheetBlock1(sheet, diamondLineBreak, skinParam.getPadding());
|
final SheetBlock1 sheetBlock1 = new SheetBlock1(sheet, diamondLineBreak, skinParam.getPadding());
|
||||||
final TextBlock tbTest = new SheetBlock2(sheetBlock1, Hexagon.asStencil(sheetBlock1), tile1.getThickness());
|
|
||||||
|
final UStroke thickness = tile1
|
||||||
|
.getThickness(getStyleSignatureDiamond().getMergedStyle(skinParam.getCurrentStyleBuilder()));
|
||||||
|
final TextBlock tbTest = new SheetBlock2(sheetBlock1, Hexagon.asStencil(sheetBlock1), thickness);
|
||||||
|
|
||||||
final Ftile shape1;
|
final Ftile shape1;
|
||||||
if (conditionStyle == ConditionStyle.INSIDE_HEXAGON) {
|
if (conditionStyle == ConditionStyle.INSIDE_HEXAGON) {
|
||||||
|
@ -46,10 +46,10 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractConnection;
|
|||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Arrows;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Connection;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.ConnectionTranslatable;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileUtils;
|
||||||
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Hexagon;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.MergeStrategy;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.MergeStrategy;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Snake;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
||||||
@ -100,7 +100,7 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, usingArrow);
|
final Snake snake = Snake.create(skinParam(), color, usingArrow);
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x2, y1);
|
snake.addPoint(x2, y1);
|
||||||
snake.addPoint(x2, y2);
|
snake.addPoint(x2, y2);
|
||||||
@ -147,14 +147,14 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
if (originalDirection != newDirection) {
|
if (originalDirection != newDirection) {
|
||||||
final double delta = (originalDirection == Direction.RIGHT ? -1 : 1) * Hexagon.hexagonHalfSize;
|
final double delta = (originalDirection == Direction.RIGHT ? -1 : 1) * Hexagon.hexagonHalfSize;
|
||||||
final Dimension2D dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
final Dimension2D dimDiamond1 = diamond1.calculateDimension(stringBounder);
|
||||||
final Snake small = Snake.create(color);
|
final Snake small = Snake.create(skinParam(), color);
|
||||||
small.addPoint(p1);
|
small.addPoint(p1);
|
||||||
small.addPoint(p1.getX() + delta, p1.getY());
|
small.addPoint(p1.getX() + delta, p1.getY());
|
||||||
small.addPoint(p1.getX() + delta, p1.getY() + dimDiamond1.getHeight() * .75);
|
small.addPoint(p1.getX() + delta, p1.getY() + dimDiamond1.getHeight() * .75);
|
||||||
ug.draw(small);
|
ug.draw(small);
|
||||||
p1 = small.getLast();
|
p1 = small.getLast();
|
||||||
}
|
}
|
||||||
final Snake snake = Snake.create(color, usingArrow).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), color, usingArrow).withMerge(MergeStrategy.LIMITED);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2.getX(), p1.getY());
|
snake.addPoint(p2.getX(), p1.getY());
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
@ -190,7 +190,7 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final UPolygon arrow = x2 > x1 ? Arrows.asToRight() : Arrows.asToLeft();
|
final UPolygon arrow = x2 > x1 ? Arrows.asToRight() : Arrows.asToLeft();
|
||||||
Snake snake = Snake.create(myArrowColor, arrow);
|
Snake snake = Snake.create(skinParam(), myArrowColor, arrow);
|
||||||
if (branchEmpty) {
|
if (branchEmpty) {
|
||||||
snake = snake.emphasizeDirection(Direction.DOWN);
|
snake = snake.emphasizeDirection(Direction.DOWN);
|
||||||
}
|
}
|
||||||
@ -244,14 +244,14 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
if (originalDirection == newDirection) {
|
if (originalDirection == newDirection) {
|
||||||
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
||||||
final Point2D mp2bc = new Point2D.Double(mp2b.getX() + delta, mp2b.getY());
|
final Point2D mp2bc = new Point2D.Double(mp2b.getX() + delta, mp2b.getY());
|
||||||
final Snake snake = Snake.create(myArrowColor).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), myArrowColor).withMerge(MergeStrategy.LIMITED);
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
snake.addPoint(mp1a);
|
snake.addPoint(mp1a);
|
||||||
snake.addPoint(mp1a.getX(), middle);
|
snake.addPoint(mp1a.getX(), middle);
|
||||||
snake.addPoint(mp2bc.getX(), middle);
|
snake.addPoint(mp2bc.getX(), middle);
|
||||||
snake.addPoint(mp2bc);
|
snake.addPoint(mp2bc);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
final Snake small = Snake.create(myArrowColor, arrow).withMerge(MergeStrategy.LIMITED);
|
final Snake small = Snake.create(skinParam(), myArrowColor, arrow).withMerge(MergeStrategy.LIMITED);
|
||||||
small.addPoint(mp2bc);
|
small.addPoint(mp2bc);
|
||||||
small.addPoint(mp2bc.getX(), mp2b.getY());
|
small.addPoint(mp2bc.getX(), mp2b.getY());
|
||||||
small.addPoint(mp2b);
|
small.addPoint(mp2b);
|
||||||
@ -260,12 +260,12 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
||||||
final Point2D mp2bb = new Point2D.Double(mp2b.getX() + delta,
|
final Point2D mp2bb = new Point2D.Double(mp2b.getX() + delta,
|
||||||
mp2b.getY() - 1.5 * Hexagon.hexagonHalfSize);
|
mp2b.getY() - 1.5 * Hexagon.hexagonHalfSize);
|
||||||
final Snake snake = Snake.create(myArrowColor).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), myArrowColor).withMerge(MergeStrategy.LIMITED);
|
||||||
snake.addPoint(mp1a);
|
snake.addPoint(mp1a);
|
||||||
snake.addPoint(mp1a.getX(), mp2bb.getY());
|
snake.addPoint(mp1a.getX(), mp2bb.getY());
|
||||||
snake.addPoint(mp2bb);
|
snake.addPoint(mp2bb);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
final Snake small = Snake.create(myArrowColor, arrow).withMerge(MergeStrategy.LIMITED);
|
final Snake small = Snake.create(skinParam(), myArrowColor, arrow).withMerge(MergeStrategy.LIMITED);
|
||||||
small.addPoint(mp2bb);
|
small.addPoint(mp2bb);
|
||||||
small.addPoint(mp2bb.getX(), mp2b.getY());
|
small.addPoint(mp2bb.getX(), mp2b.getY());
|
||||||
small.addPoint(mp2b);
|
small.addPoint(mp2b);
|
||||||
@ -303,7 +303,7 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
Snake snake = Snake.create(myArrowColor);
|
Snake snake = Snake.create(skinParam(), myArrowColor);
|
||||||
if (branchEmpty) {
|
if (branchEmpty) {
|
||||||
snake = snake.emphasizeDirection(Direction.DOWN);
|
snake = snake.emphasizeDirection(Direction.DOWN);
|
||||||
}
|
}
|
||||||
@ -330,7 +330,7 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
final Point2D mp1a = translate1.getTranslated(p1);
|
final Point2D mp1a = translate1.getTranslated(p1);
|
||||||
final Point2D mp2b = translate2.getTranslated(p2);
|
final Point2D mp2b = translate2.getTranslated(p2);
|
||||||
|
|
||||||
final Snake snake = Snake.create(myArrowColor).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), myArrowColor).withMerge(MergeStrategy.LIMITED);
|
||||||
// snake.emphasizeDirection(Direction.DOWN);
|
// snake.emphasizeDirection(Direction.DOWN);
|
||||||
|
|
||||||
final double x1 = mp1a.getX();
|
final double x1 = mp1a.getX();
|
||||||
@ -386,7 +386,8 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
}
|
}
|
||||||
final Point2D p2 = new Point2D.Double(p1.getX(), totalHeight);
|
final Point2D p2 = new Point2D.Double(p1.getX(), totalHeight);
|
||||||
|
|
||||||
final Snake snake = Snake.create(color, Arrows.asToDown()).withLabel(out2, arrowHorizontalAlignment());
|
final Snake snake = Snake.create(skinParam(), color, Arrows.asToDown()).withLabel(out2,
|
||||||
|
arrowHorizontalAlignment());
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2);
|
snake.addPoint(p2);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
@ -444,7 +445,7 @@ public class FtileIfWithLinks extends FtileIfWithDiamonds {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final Snake s = Snake.create(arrowColor).withMerge(MergeStrategy.NONE);
|
final Snake s = Snake.create(skinParam(), arrowColor).withMerge(MergeStrategy.NONE);
|
||||||
s.addPoint(minX, totalDim.getHeight());
|
s.addPoint(minX, totalDim.getHeight());
|
||||||
s.addPoint(maxX, totalDim.getHeight());
|
s.addPoint(maxX, totalDim.getHeight());
|
||||||
ug.draw(s);
|
ug.draw(s);
|
||||||
|
@ -86,7 +86,7 @@ public class FtileSwitchWithManyLinks extends FtileSwitchWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(null, arrowColor, Arrows.asToDown())
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown())
|
||||||
.withLabel(branch.getTextBlockPositive(), arrowHorizontalAlignment());
|
.withLabel(branch.getTextBlockPositive(), arrowHorizontalAlignment());
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x2, y1);
|
snake.addPoint(x2, y1);
|
||||||
@ -158,7 +158,8 @@ public class FtileSwitchWithManyLinks extends FtileSwitchWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(arrowColor, arrow).withLabel(outLabel, VerticalAlignment.CENTER);
|
final Snake snake = Snake.create(skinParam(), arrowColor, arrow).withLabel(outLabel,
|
||||||
|
VerticalAlignment.CENTER);
|
||||||
snake.addPoint(x1, y1);
|
snake.addPoint(x1, y1);
|
||||||
if (direction == Direction.LEFT && x2 > x1 - 10) {
|
if (direction == Direction.LEFT && x2 > x1 - 10) {
|
||||||
snake.addPoint(x1, y2 - 8);
|
snake.addPoint(x1, y2 - 8);
|
||||||
@ -199,7 +200,7 @@ public class FtileSwitchWithManyLinks extends FtileSwitchWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(null, arrowColor, Arrows.asToDown())
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown())
|
||||||
.withLabel(branch.getTextBlockPositive(), VerticalAlignment.CENTER);
|
.withLabel(branch.getTextBlockPositive(), VerticalAlignment.CENTER);
|
||||||
if (x2 < p1d.getX() - margin || x2 > p1b.getX() + margin) {
|
if (x2 < p1d.getX() - margin || x2 > p1b.getX() + margin) {
|
||||||
snake.addPoint(x2, p1d.getY());
|
snake.addPoint(x2, p1d.getY());
|
||||||
@ -255,7 +256,7 @@ public class FtileSwitchWithManyLinks extends FtileSwitchWithDiamonds {
|
|||||||
|
|
||||||
final double ym = (y1 + y2) / 2;
|
final double ym = (y1 + y2) / 2;
|
||||||
|
|
||||||
final Snake snake = Snake.create(null, arrowColor, Arrows.asToDown()).withLabel(outLabel,
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown()).withLabel(outLabel,
|
||||||
VerticalAlignment.CENTER);
|
VerticalAlignment.CENTER);
|
||||||
|
|
||||||
if (x1 < p1d.getX() - margin || x1 > p1b.getX() + margin) {
|
if (x1 < p1d.getX() - margin || x1 > p1b.getX() + margin) {
|
||||||
|
@ -80,7 +80,7 @@ public class FtileSwitchWithOneLink extends FtileSwitchWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(null, arrowColor, Arrows.asToDown())
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown())
|
||||||
.withLabel(branch.getTextBlockPositive(), arrowHorizontalAlignment());
|
.withLabel(branch.getTextBlockPositive(), arrowHorizontalAlignment());
|
||||||
// snake.addPoint(x1, y1);
|
// snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x2, y1);
|
snake.addPoint(x2, y1);
|
||||||
@ -115,7 +115,7 @@ public class FtileSwitchWithOneLink extends FtileSwitchWithDiamonds {
|
|||||||
final double x2 = p2.getX();
|
final double x2 = p2.getX();
|
||||||
final double y2 = p2.getY();
|
final double y2 = p2.getY();
|
||||||
|
|
||||||
final Snake snake = Snake.create(null, arrowColor, Arrows.asToDown());
|
final Snake snake = Snake.create(skinParam(), arrowColor, Arrows.asToDown());
|
||||||
// snake.addPoint(x1, y1);
|
// snake.addPoint(x1, y1);
|
||||||
snake.addPoint(x2, y1);
|
snake.addPoint(x2, y1);
|
||||||
snake.addPoint(x2, y2);
|
snake.addPoint(x2, y2);
|
||||||
|
@ -99,11 +99,11 @@ public class FtileBox extends AbstractFtile {
|
|||||||
private final HColor backColor;
|
private final HColor backColor;
|
||||||
private final Style style;
|
private final Style style;
|
||||||
|
|
||||||
static public StyleSignature getDefaultStyleDefinitionActivity() {
|
static public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity);
|
||||||
}
|
}
|
||||||
|
|
||||||
static public StyleSignature getDefaultStyleDefinitionArrow() {
|
static public StyleSignature getStyleSignatureArrow() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,9 +144,9 @@ public class FtileBox extends AbstractFtile {
|
|||||||
Style style = null;
|
Style style = null;
|
||||||
Style styleArrow = null;
|
Style styleArrow = null;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
style = getDefaultStyleDefinitionActivity().with(stereotype)
|
style = getStyleSignature().with(stereotype)
|
||||||
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
styleArrow = getDefaultStyleDefinitionArrow().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
styleArrow = getStyleSignatureArrow().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
}
|
}
|
||||||
return new FtileBox(skinParam, label, swimlane, boxStyle, style, styleArrow);
|
return new FtileBox(skinParam, label, swimlane, boxStyle, style, styleArrow);
|
||||||
}
|
}
|
||||||
@ -215,7 +215,7 @@ public class FtileBox extends AbstractFtile {
|
|||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
thickness = style.getStroke();
|
thickness = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
thickness = getThickness();
|
thickness = getThickness(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (borderColor == null) {
|
if (borderColor == null) {
|
||||||
|
@ -219,7 +219,7 @@ public class FtileBox2 extends AbstractFtile {
|
|||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
thickness = style.getStroke();
|
thickness = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
thickness = getThickness();
|
thickness = getThickness(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (borderColor == null) {
|
if (borderColor == null) {
|
||||||
|
@ -239,7 +239,7 @@ public class FtileBoxOld extends AbstractFtile {
|
|||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
thickness = style.getStroke();
|
thickness = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
thickness = getThickness();
|
thickness = getThickness(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (borderColor == null) {
|
if (borderColor == null) {
|
||||||
|
@ -43,12 +43,15 @@ import net.sourceforge.plantuml.ColorParam;
|
|||||||
import net.sourceforge.plantuml.FontParam;
|
import net.sourceforge.plantuml.FontParam;
|
||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.SkinParamUtils;
|
import net.sourceforge.plantuml.SkinParamUtils;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.AbstractFtile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Ftile;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.FtileGeometry;
|
||||||
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
import net.sourceforge.plantuml.activitydiagram3.ftile.Swimlane;
|
||||||
import net.sourceforge.plantuml.graphic.FontConfiguration;
|
import net.sourceforge.plantuml.graphic.FontConfiguration;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UCenteredCharacter;
|
import net.sourceforge.plantuml.ugraphic.UCenteredCharacter;
|
||||||
import net.sourceforge.plantuml.ugraphic.UEllipse;
|
import net.sourceforge.plantuml.ugraphic.UEllipse;
|
||||||
import net.sourceforge.plantuml.ugraphic.UFont;
|
import net.sourceforge.plantuml.ugraphic.UFont;
|
||||||
@ -64,13 +67,19 @@ public class FtileCircleSpot extends AbstractFtile {
|
|||||||
private final String spot;
|
private final String spot;
|
||||||
private final FontConfiguration fc;
|
private final FontConfiguration fc;
|
||||||
private final HColor backColor;
|
private final HColor backColor;
|
||||||
|
private final Style style;
|
||||||
|
|
||||||
public FtileCircleSpot(ISkinParam skinParam, Swimlane swimlane, String spot, UFont font, HColor backColor) {
|
public FtileCircleSpot(ISkinParam skinParam, Swimlane swimlane, String spot, UFont font, HColor backColor,
|
||||||
|
Style style) {
|
||||||
super(skinParam);
|
super(skinParam);
|
||||||
|
this.style = style;
|
||||||
this.spot = spot;
|
this.spot = spot;
|
||||||
this.swimlane = swimlane;
|
this.swimlane = swimlane;
|
||||||
this.backColor = backColor;
|
this.backColor = backColor;
|
||||||
|
if (UseStyle.useBetaStyle())
|
||||||
this.fc = new FontConfiguration(skinParam, FontParam.ACTIVITY, null);
|
this.fc = new FontConfiguration(skinParam, FontParam.ACTIVITY, null);
|
||||||
|
else
|
||||||
|
this.fc = new FontConfiguration(skinParam, style);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -94,17 +103,30 @@ public class FtileCircleSpot extends AbstractFtile {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
|
|
||||||
final HColor borderColor = SkinParamUtils.getColor(skinParam(), null, ColorParam.activityBorder);
|
|
||||||
final HColor backColor = this.backColor == null ? SkinParamUtils.getColor(skinParam(), null,
|
|
||||||
ColorParam.activityBackground) : this.backColor;
|
|
||||||
|
|
||||||
final UEllipse circle = new UEllipse(SIZE, SIZE);
|
final UEllipse circle = new UEllipse(SIZE, SIZE);
|
||||||
if (skinParam().shadowing(null)) {
|
|
||||||
circle.setDeltaShadow(3);
|
final HColor borderColor;
|
||||||
|
final HColor backColor;
|
||||||
|
double shadow = 0;
|
||||||
|
|
||||||
|
if (UseStyle.useBetaStyle()) {
|
||||||
|
backColor = this.backColor == null
|
||||||
|
? style.value(PName.BackGroundColor).asColor(skinParam().getThemeStyle(), getIHtmlColorSet())
|
||||||
|
: this.backColor;
|
||||||
|
borderColor = style.value(PName.LineColor).asColor(skinParam().getThemeStyle(), getIHtmlColorSet());
|
||||||
|
shadow = style.value(PName.Shadowing).asDouble();
|
||||||
|
} else {
|
||||||
|
borderColor = SkinParamUtils.getColor(skinParam(), null, ColorParam.activityBorder);
|
||||||
|
backColor = this.backColor == null
|
||||||
|
? SkinParamUtils.getColor(skinParam(), null, ColorParam.activityBackground)
|
||||||
|
: this.backColor;
|
||||||
|
|
||||||
|
if (skinParam().shadowing(null))
|
||||||
|
shadow = 3;
|
||||||
}
|
}
|
||||||
ug.apply(borderColor).apply(backColor.bg()).apply(getThickness())
|
|
||||||
.draw(circle);
|
circle.setDeltaShadow(shadow);
|
||||||
|
ug.apply(borderColor).apply(backColor.bg()).apply(getThickness(style)).draw(circle);
|
||||||
|
|
||||||
ug.apply(fc.getColor()).apply(new UTranslate(SIZE / 2, SIZE / 2))
|
ug.apply(fc.getColor()).apply(new UTranslate(SIZE / 2, SIZE / 2))
|
||||||
.draw(new UCenteredCharacter(spot.charAt(0), fc.getFont()));
|
.draw(new UCenteredCharacter(spot.charAt(0), fc.getFont()));
|
||||||
|
@ -50,6 +50,7 @@ import net.sourceforge.plantuml.activitydiagram3.ftile.WeldingPoint;
|
|||||||
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
@ -67,71 +68,84 @@ public abstract class FtileDecorate extends AbstractTextBlock implements Ftile {
|
|||||||
return "" + getClass() + " " + ftile;
|
return "" + getClass() + " " + ftile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public LinkRendering getOutLinkRendering() {
|
public LinkRendering getOutLinkRendering() {
|
||||||
return ftile.getOutLinkRendering();
|
return ftile.getOutLinkRendering();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public LinkRendering getInLinkRendering() {
|
public LinkRendering getInLinkRendering() {
|
||||||
return ftile.getInLinkRendering();
|
return ftile.getInLinkRendering();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
ftile.drawU(ug);
|
ftile.drawU(ug);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public FtileGeometry calculateDimension(StringBounder stringBounder) {
|
public FtileGeometry calculateDimension(StringBounder stringBounder) {
|
||||||
return ftile.calculateDimension(stringBounder);
|
return ftile.calculateDimension(stringBounder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Collection<Connection> getInnerConnections() {
|
public Collection<Connection> getInnerConnections() {
|
||||||
return ftile.getInnerConnections();
|
return ftile.getInnerConnections();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Set<Swimlane> getSwimlanes() {
|
public Set<Swimlane> getSwimlanes() {
|
||||||
return ftile.getSwimlanes();
|
return ftile.getSwimlanes();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Swimlane getSwimlaneIn() {
|
public Swimlane getSwimlaneIn() {
|
||||||
return ftile.getSwimlaneIn();
|
return ftile.getSwimlaneIn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Swimlane getSwimlaneOut() {
|
public Swimlane getSwimlaneOut() {
|
||||||
return ftile.getSwimlaneOut();
|
return ftile.getSwimlaneOut();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public ISkinParam skinParam() {
|
public ISkinParam skinParam() {
|
||||||
return ftile.skinParam();
|
return ftile.skinParam();
|
||||||
}
|
}
|
||||||
|
|
||||||
public UStroke getThickness() {
|
@Override
|
||||||
return ftile.getThickness();
|
public UStroke getThickness(Style style) {
|
||||||
|
return ftile.getThickness(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected final Ftile getFtileDelegated() {
|
protected final Ftile getFtileDelegated() {
|
||||||
return ftile;
|
return ftile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public List<WeldingPoint> getWeldingPoints() {
|
public List<WeldingPoint> getWeldingPoints() {
|
||||||
return ftile.getWeldingPoints();
|
return ftile.getWeldingPoints();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public UTranslate getTranslateFor(Ftile child, StringBounder stringBounder) {
|
public UTranslate getTranslateFor(Ftile child, StringBounder stringBounder) {
|
||||||
if (child == ftile) {
|
if (child == ftile)
|
||||||
return new UTranslate();
|
return new UTranslate();
|
||||||
}
|
|
||||||
return ftile.getTranslateFor(child, stringBounder);
|
return ftile.getTranslateFor(child, stringBounder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public Collection<Ftile> getMyChildren() {
|
public Collection<Ftile> getMyChildren() {
|
||||||
if (this == ftile) {
|
if (this == ftile)
|
||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
}
|
|
||||||
return Collections.singleton(ftile);
|
return Collections.singleton(ftile);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public HorizontalAlignment arrowHorizontalAlignment() {
|
public HorizontalAlignment arrowHorizontalAlignment() {
|
||||||
return ftile.arrowHorizontalAlignment();
|
return ftile.arrowHorizontalAlignment();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -88,7 +88,7 @@ public class FtileDiamond extends FtileDiamondWIP {
|
|||||||
|
|
||||||
final double suppY1 = north.calculateDimension(ug.getStringBounder()).getHeight();
|
final double suppY1 = north.calculateDimension(ug.getStringBounder()).getHeight();
|
||||||
ug = ug.apply(UTranslate.dy(suppY1));
|
ug = ug.apply(UTranslate.dy(suppY1));
|
||||||
ug.apply(borderColor).apply(getThickness()).apply(backColor.bg()).draw(Hexagon.asPolygon(shadowing));
|
ug.apply(borderColor).apply(getThickness(getStyle())).apply(backColor.bg()).draw(Hexagon.asPolygon(shadowing));
|
||||||
// final Dimension2D dimNorth = north.calculateDimension(ug.getStringBounder());
|
// final Dimension2D dimNorth = north.calculateDimension(ug.getStringBounder());
|
||||||
north.drawU(ug.apply(new UTranslate(Hexagon.hexagonHalfSize * 1.5, -suppY1)));
|
north.drawU(ug.apply(new UTranslate(Hexagon.hexagonHalfSize * 1.5, -suppY1)));
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ public class FtileDiamondInside extends FtileDiamondWIP {
|
|||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Dimension2D dimLabel = label.calculateDimension(stringBounder);
|
final Dimension2D dimLabel = label.calculateDimension(stringBounder);
|
||||||
final Dimension2D dimTotal = calculateDimensionAlone(stringBounder);
|
final Dimension2D dimTotal = calculateDimensionAlone(stringBounder);
|
||||||
ug = ug.apply(borderColor).apply(getThickness()).apply(backColor.bg());
|
ug = ug.apply(borderColor).apply(getThickness(getStyle())).apply(backColor.bg());
|
||||||
ug.draw(Hexagon.asPolygon(shadowing, dimTotal.getWidth(), dimTotal.getHeight()));
|
ug.draw(Hexagon.asPolygon(shadowing, dimTotal.getWidth(), dimTotal.getHeight()));
|
||||||
|
|
||||||
north.drawU(ug.apply(new UTranslate(4 + dimTotal.getWidth() / 2, dimTotal.getHeight())));
|
north.drawU(ug.apply(new UTranslate(4 + dimTotal.getWidth() / 2, dimTotal.getHeight())));
|
||||||
|
@ -82,7 +82,7 @@ public class FtileDiamondInside2 extends FtileDiamondWIP {
|
|||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Dimension2D dimLabel = label.calculateDimension(stringBounder);
|
final Dimension2D dimLabel = label.calculateDimension(stringBounder);
|
||||||
final Dimension2D dimTotal = calculateDimensionAlone(stringBounder);
|
final Dimension2D dimTotal = calculateDimensionAlone(stringBounder);
|
||||||
ug = ug.apply(borderColor).apply(getThickness()).apply(backColor.bg());
|
ug = ug.apply(borderColor).apply(getThickness(getStyle())).apply(backColor.bg());
|
||||||
ug.draw(Hexagon.asPolygon(shadowing, dimTotal.getWidth(), dimTotal.getHeight()));
|
ug.draw(Hexagon.asPolygon(shadowing, dimTotal.getWidth(), dimTotal.getHeight()));
|
||||||
|
|
||||||
north.drawU(ug.apply(new UTranslate(4 + dimTotal.getWidth() / 2, dimTotal.getHeight())));
|
north.drawU(ug.apply(new UTranslate(4 + dimTotal.getWidth() / 2, dimTotal.getHeight())));
|
||||||
|
@ -87,7 +87,7 @@ public class FtileDiamondSquare extends FtileDiamondWIP {
|
|||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Dimension2D dimLabel = label.calculateDimension(stringBounder);
|
final Dimension2D dimLabel = label.calculateDimension(stringBounder);
|
||||||
final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
final Dimension2D dimTotal = calculateDimensionInternal(stringBounder);
|
||||||
ug = ug.apply(borderColor).apply(getThickness()).apply(backColor.bg());
|
ug = ug.apply(borderColor).apply(getThickness(getStyle())).apply(backColor.bg());
|
||||||
|
|
||||||
ug.draw(Hexagon.asPolygonSquare(shadowing, dimTotal.getWidth(), dimTotal.getHeight()));
|
ug.draw(Hexagon.asPolygonSquare(shadowing, dimTotal.getWidth(), dimTotal.getHeight()));
|
||||||
|
|
||||||
|
@ -67,10 +67,14 @@ abstract class FtileDiamondWIP extends AbstractFtile implements Styleable {
|
|||||||
|
|
||||||
protected final double shadowing;
|
protected final double shadowing;
|
||||||
|
|
||||||
final public StyleSignature getDefaultStyleDefinition() {
|
final public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity, SName.diamond);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity, SName.diamond);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final public Style getStyle() {
|
||||||
|
return getStyleSignature().getMergedStyle(skinParam().getCurrentStyleBuilder());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
final public Collection<Ftile> getMyChildren() {
|
final public Collection<Ftile> getMyChildren() {
|
||||||
return Collections.emptyList();
|
return Collections.emptyList();
|
||||||
@ -80,7 +84,7 @@ abstract class FtileDiamondWIP extends AbstractFtile implements Styleable {
|
|||||||
Swimlane swimlane, TextBlock north, TextBlock south, TextBlock east, TextBlock west) {
|
Swimlane swimlane, TextBlock north, TextBlock south, TextBlock east, TextBlock west) {
|
||||||
super(skinParam);
|
super(skinParam);
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
Style style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
this.borderColor = borderColor; //style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet());
|
this.borderColor = borderColor; //style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
this.backColor = backColor; //style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet());
|
this.backColor = backColor; //style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
this.shadowing = style.value(PName.Shadowing).asDouble();
|
this.shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
|
@ -91,6 +91,10 @@ public abstract class GAbstractConnection implements GConnection {
|
|||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.arrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected ISkinParam skinParam() {
|
||||||
|
throw new UnsupportedOperationException("wip");
|
||||||
|
}
|
||||||
|
|
||||||
// DUPLICATE 4561
|
// DUPLICATE 4561
|
||||||
final protected Rainbow getInLinkRenderingColor() {
|
final protected Rainbow getInLinkRenderingColor() {
|
||||||
Rainbow color;
|
Rainbow color;
|
||||||
|
@ -84,7 +84,7 @@ public class GConnectionHorizontalThenVerticalDown extends GAbstractConnection {
|
|||||||
// final Dimension2D dimDiamond1 =
|
// final Dimension2D dimDiamond1 =
|
||||||
// diamond1.calculateDimension(ug.getStringBounder());
|
// diamond1.calculateDimension(ug.getStringBounder());
|
||||||
final Dimension2D dimDiamond1 = new Dimension2DDouble(0, 0);
|
final Dimension2D dimDiamond1 = new Dimension2DDouble(0, 0);
|
||||||
final Snake small = Snake.create(getInLinkRenderingColor()).withLabel(textBlock, HorizontalAlignment.LEFT);
|
final Snake small = Snake.create(skinParam(), getInLinkRenderingColor()).withLabel(textBlock, HorizontalAlignment.LEFT);
|
||||||
small.addPoint(p1);
|
small.addPoint(p1);
|
||||||
small.addPoint(p1.getX() + delta, p1.getY());
|
small.addPoint(p1.getX() + delta, p1.getY());
|
||||||
small.addPoint(p1.getX() + delta, p1.getY() + dimDiamond1.getHeight() * .75);
|
small.addPoint(p1.getX() + delta, p1.getY() + dimDiamond1.getHeight() * .75);
|
||||||
@ -93,7 +93,7 @@ public class GConnectionHorizontalThenVerticalDown extends GAbstractConnection {
|
|||||||
}
|
}
|
||||||
UPolygon usingArrow = /* branch.isEmpty() ? null : */ Arrows.asToDown();
|
UPolygon usingArrow = /* branch.isEmpty() ? null : */ Arrows.asToDown();
|
||||||
|
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), usingArrow)
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), usingArrow)
|
||||||
.withLabel(textBlock, HorizontalAlignment.LEFT).withMerge(MergeStrategy.LIMITED);
|
.withLabel(textBlock, HorizontalAlignment.LEFT).withMerge(MergeStrategy.LIMITED);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(p2.getX(), p1.getY());
|
snake.addPoint(p2.getX(), p1.getY());
|
||||||
@ -104,7 +104,7 @@ public class GConnectionHorizontalThenVerticalDown extends GAbstractConnection {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), Arrows.asToDown()).withLabel(textBlock,
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), Arrows.asToDown()).withLabel(textBlock,
|
||||||
HorizontalAlignment.LEFT);
|
HorizontalAlignment.LEFT);
|
||||||
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
||||||
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
||||||
|
@ -76,7 +76,7 @@ public class GConnectionSideThenVerticalThenSide extends GAbstractConnection {
|
|||||||
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
||||||
final Direction direction = p1.getY() < p2.getY() ? Direction.DOWN : Direction.UP;
|
final Direction direction = p1.getY() < p2.getY() ? Direction.DOWN : Direction.UP;
|
||||||
final UPolygon tmp = p1.getX() < p2.getX() ? Arrows.asToRight() : Arrows.asToLeft();
|
final UPolygon tmp = p1.getX() < p2.getX() ? Arrows.asToRight() : Arrows.asToLeft();
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), tmp).emphasizeDirection(direction)
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), tmp).emphasizeDirection(direction)
|
||||||
.withLabel(textBlock, HorizontalAlignment.LEFT);
|
.withLabel(textBlock, HorizontalAlignment.LEFT);
|
||||||
// final double maxX = Math.max(p1.getX(), p2.getX());
|
// final double maxX = Math.max(p1.getX(), p2.getX());
|
||||||
final double maxX = xpos;
|
final double maxX = xpos;
|
||||||
|
@ -61,7 +61,7 @@ public class GConnectionVerticalDown extends GAbstractConnection {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
public void drawTranslate(UGraphic ug, UTranslate translate1, UTranslate translate2) {
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), Arrows.asToDown()).withLabel(textBlock,
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), Arrows.asToDown()).withLabel(textBlock,
|
||||||
HorizontalAlignment.LEFT);
|
HorizontalAlignment.LEFT);
|
||||||
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
||||||
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
||||||
@ -78,7 +78,7 @@ public class GConnectionVerticalDown extends GAbstractConnection {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), Arrows.asToDown()).withLabel(textBlock,
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), Arrows.asToDown()).withLabel(textBlock,
|
||||||
HorizontalAlignment.LEFT);
|
HorizontalAlignment.LEFT);
|
||||||
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
||||||
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
||||||
|
@ -68,7 +68,7 @@ public class GConnectionVerticalDownThenBack extends GAbstractConnection {
|
|||||||
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
||||||
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
||||||
final UPolygon arrow = Arrows.asToLeft();
|
final UPolygon arrow = Arrows.asToLeft();
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), arrow)
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), arrow)
|
||||||
.withLabel(textBlock, HorizontalAlignment.LEFT).emphasizeDirection(Direction.UP);
|
.withLabel(textBlock, HorizontalAlignment.LEFT).emphasizeDirection(Direction.UP);
|
||||||
|
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
@ -94,7 +94,7 @@ public class GConnectionVerticalDownThenBack extends GAbstractConnection {
|
|||||||
p2 = translate2.getTranslated(p2);
|
p2 = translate2.getTranslated(p2);
|
||||||
|
|
||||||
final UPolygon arrow = Arrows.asToLeft();
|
final UPolygon arrow = Arrows.asToLeft();
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), arrow)
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), arrow)
|
||||||
.withLabel(textBlock, HorizontalAlignment.LEFT).emphasizeDirection(Direction.UP);
|
.withLabel(textBlock, HorizontalAlignment.LEFT).emphasizeDirection(Direction.UP);
|
||||||
|
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
|
@ -82,14 +82,14 @@ public class GConnectionVerticalDownThenHorizontal extends GAbstractConnection {
|
|||||||
if (originalDirection == newDirection) {
|
if (originalDirection == newDirection) {
|
||||||
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
||||||
final Point2D mp2bc = new Point2D.Double(mp2b.getX() + delta, mp2b.getY());
|
final Point2D mp2bc = new Point2D.Double(mp2b.getX() + delta, mp2b.getY());
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor()).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor()).withMerge(MergeStrategy.LIMITED);
|
||||||
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
final double middle = (mp1a.getY() + mp2b.getY()) / 2.0;
|
||||||
snake.addPoint(mp1a);
|
snake.addPoint(mp1a);
|
||||||
snake.addPoint(mp1a.getX(), middle);
|
snake.addPoint(mp1a.getX(), middle);
|
||||||
snake.addPoint(mp2bc.getX(), middle);
|
snake.addPoint(mp2bc.getX(), middle);
|
||||||
snake.addPoint(mp2bc);
|
snake.addPoint(mp2bc);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
final Snake small = Snake.create(getInLinkRenderingColor(), arrow).withMerge(MergeStrategy.LIMITED);
|
final Snake small = Snake.create(skinParam(), getInLinkRenderingColor(), arrow).withMerge(MergeStrategy.LIMITED);
|
||||||
small.addPoint(mp2bc);
|
small.addPoint(mp2bc);
|
||||||
small.addPoint(mp2bc.getX(), mp2b.getY());
|
small.addPoint(mp2bc.getX(), mp2b.getY());
|
||||||
small.addPoint(mp2b);
|
small.addPoint(mp2b);
|
||||||
@ -97,12 +97,12 @@ public class GConnectionVerticalDownThenHorizontal extends GAbstractConnection {
|
|||||||
} else {
|
} else {
|
||||||
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
final double delta = (x2 > x1 ? -1 : 1) * 1.5 * Hexagon.hexagonHalfSize;
|
||||||
final Point2D mp2bb = new Point2D.Double(mp2b.getX() + delta, mp2b.getY() - 1.5 * Hexagon.hexagonHalfSize);
|
final Point2D mp2bb = new Point2D.Double(mp2b.getX() + delta, mp2b.getY() - 1.5 * Hexagon.hexagonHalfSize);
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor()).withMerge(MergeStrategy.LIMITED);
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor()).withMerge(MergeStrategy.LIMITED);
|
||||||
snake.addPoint(mp1a);
|
snake.addPoint(mp1a);
|
||||||
snake.addPoint(mp1a.getX(), mp2bb.getY());
|
snake.addPoint(mp1a.getX(), mp2bb.getY());
|
||||||
snake.addPoint(mp2bb);
|
snake.addPoint(mp2bb);
|
||||||
ug.draw(snake);
|
ug.draw(snake);
|
||||||
final Snake small = Snake.create(getInLinkRenderingColor(), arrow).withMerge(MergeStrategy.LIMITED);
|
final Snake small = Snake.create(skinParam(), getInLinkRenderingColor(), arrow).withMerge(MergeStrategy.LIMITED);
|
||||||
small.addPoint(mp2bb);
|
small.addPoint(mp2bb);
|
||||||
small.addPoint(mp2bb.getX(), mp2b.getY());
|
small.addPoint(mp2bb.getX(), mp2b.getY());
|
||||||
small.addPoint(mp2b);
|
small.addPoint(mp2b);
|
||||||
@ -117,7 +117,7 @@ public class GConnectionVerticalDownThenHorizontal extends GAbstractConnection {
|
|||||||
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
final Point2D p1 = pos1.getTranslated(gpoint1.getPoint2D());
|
||||||
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
final Point2D p2 = pos2.getTranslated(gpoint2.getPoint2D());
|
||||||
final UPolygon arrow = p1.getX() < p2.getX() ? Arrows.asToRight() : Arrows.asToLeft();
|
final UPolygon arrow = p1.getX() < p2.getX() ? Arrows.asToRight() : Arrows.asToLeft();
|
||||||
final Snake snake = Snake.create(getInLinkRenderingColor(), arrow).withLabel(textBlock,
|
final Snake snake = Snake.create(skinParam(), getInLinkRenderingColor(), arrow).withLabel(textBlock,
|
||||||
HorizontalAlignment.LEFT);
|
HorizontalAlignment.LEFT);
|
||||||
snake.addPoint(p1);
|
snake.addPoint(p1);
|
||||||
snake.addPoint(new Point2D.Double(p1.getX(), p2.getY()));
|
snake.addPoint(new Point2D.Double(p1.getX(), p2.getY()));
|
||||||
|
@ -126,7 +126,7 @@ public class GtileGroup extends AbstractGtileRoot {
|
|||||||
if (Display.isNull(displayNote)) {
|
if (Display.isNull(displayNote)) {
|
||||||
this.headerNote = TextBlockUtils.empty(0, 0);
|
this.headerNote = TextBlockUtils.empty(0, 0);
|
||||||
} else {
|
} else {
|
||||||
this.headerNote = new FloatingNote(displayNote, skinParam, style);
|
this.headerNote = new FloatingNote(displayNote, skinParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
final UStroke thickness = skinParam.getThickness(LineParam.partitionBorder, null);
|
final UStroke thickness = skinParam.getThickness(LineParam.partitionBorder, null);
|
||||||
|
@ -86,7 +86,7 @@ public class GtileWithNoteOpale extends AbstractGtile implements Stencil, Stylea
|
|||||||
private final Dimension2D dimNote;
|
private final Dimension2D dimNote;
|
||||||
private final Dimension2D dimTile;
|
private final Dimension2D dimTile;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.note);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -111,7 +111,6 @@ public class GtileWithNoteOpale extends AbstractGtile implements Stencil, Stylea
|
|||||||
if (note.getType() == NoteType.FLOATING_NOTE)
|
if (note.getType() == NoteType.FLOATING_NOTE)
|
||||||
withLink = false;
|
withLink = false;
|
||||||
|
|
||||||
|
|
||||||
final Rose rose = new Rose();
|
final Rose rose = new Rose();
|
||||||
|
|
||||||
final HColor noteBackgroundColor;
|
final HColor noteBackgroundColor;
|
||||||
@ -120,8 +119,9 @@ public class GtileWithNoteOpale extends AbstractGtile implements Stencil, Stylea
|
|||||||
|
|
||||||
final double shadowing;
|
final double shadowing;
|
||||||
final LineBreakStrategy wrapWidth;
|
final LineBreakStrategy wrapWidth;
|
||||||
|
UStroke stroke = new UStroke();
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
final Style style = getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder())
|
final Style style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder())
|
||||||
.eventuallyOverride(note.getColors());
|
.eventuallyOverride(note.getColors());
|
||||||
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
noteBackgroundColor = style.value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
getIHtmlColorSet());
|
getIHtmlColorSet());
|
||||||
@ -129,6 +129,7 @@ public class GtileWithNoteOpale extends AbstractGtile implements Stencil, Stylea
|
|||||||
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
shadowing = style.value(PName.Shadowing).asDouble();
|
shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
wrapWidth = style.wrapWidth();
|
wrapWidth = style.wrapWidth();
|
||||||
|
stroke = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
noteBackgroundColor = rose.getHtmlColor(skinParam, ColorParam.noteBackground);
|
||||||
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
borderColor = rose.getHtmlColor(skinParam, ColorParam.noteBorder);
|
||||||
@ -142,7 +143,7 @@ public class GtileWithNoteOpale extends AbstractGtile implements Stencil, Stylea
|
|||||||
final Sheet sheet = Parser.build(fc, align, skinParam, CreoleMode.FULL).createSheet(note.getDisplay());
|
final Sheet sheet = Parser.build(fc, align, skinParam, CreoleMode.FULL).createSheet(note.getDisplay());
|
||||||
final TextBlock text = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this,
|
final TextBlock text = new SheetBlock2(new SheetBlock1(sheet, wrapWidth, skinParam.getPadding()), this,
|
||||||
new UStroke(1));
|
new UStroke(1));
|
||||||
this.opale = new Opale(shadowing, borderColor, noteBackgroundColor, text, withLink);
|
this.opale = new Opale(shadowing, borderColor, noteBackgroundColor, text, withLink, stroke);
|
||||||
|
|
||||||
this.dimNote = opale.calculateDimension(stringBounder);
|
this.dimNote = opale.calculateDimension(stringBounder);
|
||||||
this.dimTile = tile.calculateDimension(stringBounder);
|
this.dimTile = tile.calculateDimension(stringBounder);
|
||||||
|
@ -118,6 +118,7 @@ public class GtileWithNotes extends AbstractGtile {
|
|||||||
final HColor borderColor;
|
final HColor borderColor;
|
||||||
final FontConfiguration fc;
|
final FontConfiguration fc;
|
||||||
final double shadowing;
|
final double shadowing;
|
||||||
|
UStroke stroke = new UStroke();
|
||||||
|
|
||||||
final LineBreakStrategy wrapWidth;
|
final LineBreakStrategy wrapWidth;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
@ -129,6 +130,7 @@ public class GtileWithNotes extends AbstractGtile {
|
|||||||
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
fc = style.getFontConfiguration(skinParam.getThemeStyle(), getIHtmlColorSet());
|
||||||
shadowing = style.value(PName.Shadowing).asDouble();
|
shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
wrapWidth = style.wrapWidth();
|
wrapWidth = style.wrapWidth();
|
||||||
|
stroke = style.getStroke();
|
||||||
} else {
|
} else {
|
||||||
noteBackgroundColor = rose.getHtmlColor(skinParam2, ColorParam.noteBackground);
|
noteBackgroundColor = rose.getHtmlColor(skinParam2, ColorParam.noteBackground);
|
||||||
borderColor = rose.getHtmlColor(skinParam2, ColorParam.noteBorder);
|
borderColor = rose.getHtmlColor(skinParam2, ColorParam.noteBorder);
|
||||||
@ -150,9 +152,9 @@ public class GtileWithNotes extends AbstractGtile {
|
|||||||
public double getEndingX(StringBounder stringBounder, double y) {
|
public double getEndingX(StringBounder stringBounder, double y) {
|
||||||
return sheet1.getEndingX(stringBounder, y) + 15;
|
return sheet1.getEndingX(stringBounder, y) + 15;
|
||||||
}
|
}
|
||||||
}, new UStroke());
|
}, stroke);
|
||||||
|
|
||||||
final Opale opale = new Opale(shadowing, borderColor, noteBackgroundColor, sheet2, false);
|
final Opale opale = new Opale(shadowing, borderColor, noteBackgroundColor, sheet2, false, stroke);
|
||||||
final TextBlock opaleMarged = TextBlockUtils.withMargin(opale, 10, 10);
|
final TextBlock opaleMarged = TextBlockUtils.withMargin(opale, 10, 10);
|
||||||
if (note.getNotePosition() == NotePosition.LEFT) {
|
if (note.getNotePosition() == NotePosition.LEFT) {
|
||||||
if (left == null) {
|
if (left == null) {
|
||||||
|
@ -55,7 +55,7 @@ public abstract class AbstractComponentText implements Component {
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,6 +59,8 @@ public class CreoleHorizontalLine extends AbstractAtom implements Atom {
|
|||||||
private final char style;
|
private final char style;
|
||||||
private final ISkinSimple skinParam;
|
private final ISkinSimple skinParam;
|
||||||
|
|
||||||
|
private final static double defaultThickness = 1;
|
||||||
|
|
||||||
public static CreoleHorizontalLine create(FontConfiguration fontConfiguration, String line, char style,
|
public static CreoleHorizontalLine create(FontConfiguration fontConfiguration, String line, char style,
|
||||||
ISkinSimple skinParam) {
|
ISkinSimple skinParam) {
|
||||||
return new CreoleHorizontalLine(fontConfiguration, line, style, skinParam);
|
return new CreoleHorizontalLine(fontConfiguration, line, style, skinParam);
|
||||||
@ -73,10 +75,10 @@ public class CreoleHorizontalLine extends AbstractAtom implements Atom {
|
|||||||
|
|
||||||
private UHorizontalLine getHorizontalLine() {
|
private UHorizontalLine getHorizontalLine() {
|
||||||
if (line.length() == 0) {
|
if (line.length() == 0) {
|
||||||
return UHorizontalLine.infinite(0, 0, style);
|
return UHorizontalLine.infinite(defaultThickness, 0, 0, style);
|
||||||
}
|
}
|
||||||
final TextBlock tb = getTitle();
|
final TextBlock tb = getTitle();
|
||||||
return UHorizontalLine.infinite(0, 0, tb, style);
|
return UHorizontalLine.infinite(defaultThickness, 0, 0, tb, style);
|
||||||
}
|
}
|
||||||
|
|
||||||
private TextBlock getTitle() {
|
private TextBlock getTitle() {
|
||||||
|
@ -52,6 +52,7 @@ import net.sourceforge.plantuml.graphic.TextBlock;
|
|||||||
import net.sourceforge.plantuml.graphic.TextBlockLineBefore;
|
import net.sourceforge.plantuml.graphic.TextBlockLineBefore;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
import net.sourceforge.plantuml.skin.VisibilityModifier;
|
import net.sourceforge.plantuml.skin.VisibilityModifier;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
import net.sourceforge.plantuml.style.Style;
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
|
||||||
public class BodierLikeClassOrObject implements Bodier {
|
public class BodierLikeClassOrObject implements Bodier {
|
||||||
@ -228,7 +229,7 @@ public class BodierLikeClassOrObject implements Bodier {
|
|||||||
}
|
}
|
||||||
if (type == LeafType.OBJECT) {
|
if (type == LeafType.OBJECT) {
|
||||||
if (showFields == false) {
|
if (showFields == false) {
|
||||||
return new TextBlockLineBefore(TextBlockUtils.empty(0, 0));
|
return new TextBlockLineBefore(style.value(PName.LineThickness).asDouble(), TextBlockUtils.empty(0, 0));
|
||||||
}
|
}
|
||||||
return BodyFactory.create1(skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT),
|
return BodyFactory.create1(skinParam.getDefaultTextAlignment(HorizontalAlignment.LEFT),
|
||||||
rawBodyWithoutHidden(), fontParam, skinParam, stereotype, leaf, style);
|
rawBodyWithoutHidden(), fontParam, skinParam, stereotype, leaf, style);
|
||||||
|
@ -48,6 +48,7 @@ import net.sourceforge.plantuml.FontParam;
|
|||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.StringUtils;
|
import net.sourceforge.plantuml.StringUtils;
|
||||||
import net.sourceforge.plantuml.Url;
|
import net.sourceforge.plantuml.Url;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.creole.CreoleMode;
|
import net.sourceforge.plantuml.creole.CreoleMode;
|
||||||
import net.sourceforge.plantuml.creole.Parser;
|
import net.sourceforge.plantuml.creole.Parser;
|
||||||
import net.sourceforge.plantuml.creole.legacy.CreoleParser;
|
import net.sourceforge.plantuml.creole.legacy.CreoleParser;
|
||||||
@ -76,7 +77,8 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
|
|
||||||
BodyEnhanced1(HorizontalAlignment align, List<CharSequence> rawBody, FontParam fontParam, ISkinParam skinParam,
|
BodyEnhanced1(HorizontalAlignment align, List<CharSequence> rawBody, FontParam fontParam, ISkinParam skinParam,
|
||||||
Stereotype stereotype, ILeaf entity, Style style) {
|
Stereotype stereotype, ILeaf entity, Style style) {
|
||||||
super(align, new FontConfiguration(skinParam, fontParam, stereotype));
|
super(align, UseStyle.useBetaStyle() == false ? new FontConfiguration(skinParam, fontParam, stereotype)
|
||||||
|
: style.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet()), style);
|
||||||
this.style = style;
|
this.style = style;
|
||||||
this.rawBody2 = Display.create(rawBody);
|
this.rawBody2 = Display.create(rawBody);
|
||||||
this.stereotype = stereotype;
|
this.stereotype = stereotype;
|
||||||
@ -92,7 +94,7 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
BodyEnhanced1(HorizontalAlignment align, Display display, FontParam fontParam, ISkinParam skinParam,
|
BodyEnhanced1(HorizontalAlignment align, Display display, FontParam fontParam, ISkinParam skinParam,
|
||||||
Stereotype stereotype, ILeaf entity, Style style) {
|
Stereotype stereotype, ILeaf entity, Style style) {
|
||||||
super(align, style == null ? new FontConfiguration(skinParam, fontParam, stereotype)
|
super(align, style == null ? new FontConfiguration(skinParam, fontParam, stereotype)
|
||||||
: style.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet()));
|
: style.getFontConfiguration(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet()), style);
|
||||||
|
|
||||||
this.style = style;
|
this.style = style;
|
||||||
this.entity = entity;
|
this.entity = entity;
|
||||||
@ -104,9 +106,9 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
|
|
||||||
this.inEllipse = fontParam == FontParam.USECASE;
|
this.inEllipse = fontParam == FontParam.USECASE;
|
||||||
|
|
||||||
if (inEllipse && display.size() > 0 && isBlockSeparator(display.get(0).toString())) {
|
if (inEllipse && display.size() > 0 && isBlockSeparator(display.get(0).toString()))
|
||||||
display = display.add("");
|
display = display.add("");
|
||||||
}
|
|
||||||
this.rawBody2 = display;
|
this.rawBody2 = display;
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -123,9 +125,9 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
final protected TextBlock getArea(StringBounder stringBounder) {
|
final protected TextBlock getArea(StringBounder stringBounder) {
|
||||||
if (area != null) {
|
if (area != null)
|
||||||
return area;
|
return area;
|
||||||
}
|
|
||||||
urls.clear();
|
urls.clear();
|
||||||
final List<TextBlock> blocks = new ArrayList<>();
|
final List<TextBlock> blocks = new ArrayList<>();
|
||||||
|
|
||||||
@ -155,25 +157,25 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
display = Display.empty();
|
display = Display.empty();
|
||||||
} else if (isTreeOrTable(s)) {
|
} else if (isTreeOrTable(s)) {
|
||||||
final boolean isTable = CreoleParser.isTableLine(s);
|
final boolean isTable = CreoleParser.isTableLine(s);
|
||||||
if (display.size() > 0) {
|
if (display.size() > 0)
|
||||||
blocks.add(decorate(stringBounder, new MethodsOrFieldsArea(display, fontParam, skinParam, align,
|
blocks.add(decorate(stringBounder, new MethodsOrFieldsArea(display, fontParam, skinParam, align,
|
||||||
stereotype, entity, style), separator, title));
|
stereotype, entity, style), separator, title));
|
||||||
}
|
|
||||||
separator = 0;
|
separator = 0;
|
||||||
title = null;
|
title = null;
|
||||||
display = Display.empty();
|
display = Display.empty();
|
||||||
final List<CharSequence> allTree = buildTreeOrTable(s, it);
|
final List<CharSequence> allTree = buildTreeOrTable(s, it);
|
||||||
TextBlock bloc = Display.create(allTree).create7(fontParam.getFontConfiguration(skinParam), align,
|
TextBlock bloc = Display.create(allTree).create7(fontParam.getFontConfiguration(skinParam), align,
|
||||||
skinParam, CreoleMode.FULL);
|
skinParam, CreoleMode.FULL);
|
||||||
if (isTable) {
|
if (isTable)
|
||||||
bloc = TextBlockUtils.withMargin(bloc, 10, 10, 0, 5);
|
bloc = TextBlockUtils.withMargin(bloc, 10, 10, 0, 5);
|
||||||
}
|
|
||||||
blocks.add(bloc);
|
blocks.add(bloc);
|
||||||
} else {
|
} else {
|
||||||
display = display.add(cs);
|
display = display.add(cs);
|
||||||
if (cs instanceof Member && ((Member) cs).getUrl() != null) {
|
if (cs instanceof Member && ((Member) cs).getUrl() != null)
|
||||||
urls.add(((Member) cs).getUrl());
|
urls.add(((Member) cs).getUrl());
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -184,15 +186,13 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
new MethodsOrFieldsArea(display, fontParam, skinParam, align, stereotype, entity, style), separator,
|
new MethodsOrFieldsArea(display, fontParam, skinParam, align, stereotype, entity, style), separator,
|
||||||
title));
|
title));
|
||||||
|
|
||||||
if (blocks.size() == 1) {
|
if (blocks.size() == 1)
|
||||||
this.area = blocks.get(0);
|
this.area = blocks.get(0);
|
||||||
} else {
|
else
|
||||||
this.area = new TextBlockVertical2(blocks, align);
|
this.area = new TextBlockVertical2(blocks, align);
|
||||||
}
|
|
||||||
|
|
||||||
if (skinParam.minClassWidth() > 0) {
|
if (skinParam.minClassWidth() > 0)
|
||||||
this.area = TextBlockUtils.withMinWidth(this.area, skinParam.minClassWidth(), align);
|
this.area = TextBlockUtils.withMinWidth(this.area, skinParam.minClassWidth(), align);
|
||||||
}
|
|
||||||
|
|
||||||
return area;
|
return area;
|
||||||
}
|
}
|
||||||
@ -202,9 +202,9 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
final Pattern p = Pattern.compile("^(\\s+)");
|
final Pattern p = Pattern.compile("^(\\s+)");
|
||||||
final Matcher m = p.matcher(init);
|
final Matcher m = p.matcher(init);
|
||||||
String start = "";
|
String start = "";
|
||||||
if (m.find()) {
|
if (m.find())
|
||||||
start = m.group(1);
|
start = m.group(1);
|
||||||
}
|
|
||||||
result.add(purge(init, start));
|
result.add(purge(init, start));
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
String s = it.next().toString();
|
String s = it.next().toString();
|
||||||
@ -220,18 +220,18 @@ public class BodyEnhanced1 extends BodyEnhancedAbstract implements TextBlock, Wi
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static String purge(String s, String start) {
|
private static String purge(String s, String start) {
|
||||||
if (s.startsWith(start)) {
|
if (s.startsWith(start))
|
||||||
return s.substring(start.length());
|
return s.substring(start.length());
|
||||||
}
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Ports getPorts(StringBounder stringBounder) {
|
public Ports getPorts(StringBounder stringBounder) {
|
||||||
final TextBlock area = getArea(stringBounder);
|
final TextBlock area = getArea(stringBounder);
|
||||||
if (area instanceof WithPorts) {
|
if (area instanceof WithPorts)
|
||||||
return ((WithPorts) area).getPorts(stringBounder);
|
return ((WithPorts) area).getPorts(stringBounder);
|
||||||
}
|
|
||||||
return new Ports();
|
return new Ports();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,6 +48,7 @@ import net.sourceforge.plantuml.graphic.StringBounder;
|
|||||||
import net.sourceforge.plantuml.graphic.TextBlock;
|
import net.sourceforge.plantuml.graphic.TextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockVertical2;
|
import net.sourceforge.plantuml.graphic.TextBlockVertical2;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
|
||||||
public class BodyEnhanced2 extends BodyEnhancedAbstract {
|
public class BodyEnhanced2 extends BodyEnhancedAbstract {
|
||||||
|
|
||||||
@ -57,8 +58,8 @@ public class BodyEnhanced2 extends BodyEnhancedAbstract {
|
|||||||
private final LineBreakStrategy lineBreakStrategy;
|
private final LineBreakStrategy lineBreakStrategy;
|
||||||
|
|
||||||
BodyEnhanced2(Display rawBody, FontParam fontParam, ISkinSimple skinParam, HorizontalAlignment align,
|
BodyEnhanced2(Display rawBody, FontParam fontParam, ISkinSimple skinParam, HorizontalAlignment align,
|
||||||
FontConfiguration titleConfig, LineBreakStrategy lineBreakStrategy) {
|
FontConfiguration titleConfig, LineBreakStrategy lineBreakStrategy, Style style) {
|
||||||
super(align, titleConfig);
|
super(align, titleConfig, style);
|
||||||
this.rawBody = rawBody;
|
this.rawBody = rawBody;
|
||||||
this.lineBreakStrategy = lineBreakStrategy;
|
this.lineBreakStrategy = lineBreakStrategy;
|
||||||
this.skinParam = skinParam;
|
this.skinParam = skinParam;
|
||||||
|
@ -39,6 +39,7 @@ import java.awt.geom.Dimension2D;
|
|||||||
|
|
||||||
import net.sourceforge.plantuml.ISkinSimple;
|
import net.sourceforge.plantuml.ISkinSimple;
|
||||||
import net.sourceforge.plantuml.StringUtils;
|
import net.sourceforge.plantuml.StringUtils;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.FontConfiguration;
|
import net.sourceforge.plantuml.graphic.FontConfiguration;
|
||||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||||
@ -46,6 +47,8 @@ import net.sourceforge.plantuml.graphic.StringBounder;
|
|||||||
import net.sourceforge.plantuml.graphic.TextBlock;
|
import net.sourceforge.plantuml.graphic.TextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockLineBefore;
|
import net.sourceforge.plantuml.graphic.TextBlockLineBefore;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
|
|
||||||
public abstract class BodyEnhancedAbstract extends AbstractTextBlock implements TextBlock {
|
public abstract class BodyEnhancedAbstract extends AbstractTextBlock implements TextBlock {
|
||||||
@ -53,10 +56,12 @@ public abstract class BodyEnhancedAbstract extends AbstractTextBlock implements
|
|||||||
protected final HorizontalAlignment align;
|
protected final HorizontalAlignment align;
|
||||||
protected final FontConfiguration titleConfig;
|
protected final FontConfiguration titleConfig;
|
||||||
protected TextBlock area;
|
protected TextBlock area;
|
||||||
|
private final Style style;
|
||||||
|
|
||||||
BodyEnhancedAbstract(HorizontalAlignment align, FontConfiguration titleConfig) {
|
BodyEnhancedAbstract(HorizontalAlignment align, FontConfiguration titleConfig, Style style) {
|
||||||
this.align = align;
|
this.align = align;
|
||||||
this.titleConfig = titleConfig;
|
this.titleConfig = titleConfig;
|
||||||
|
this.style = style;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isBlockSeparator(CharSequence cs) {
|
public static boolean isBlockSeparator(CharSequence cs) {
|
||||||
@ -85,9 +90,9 @@ public abstract class BodyEnhancedAbstract extends AbstractTextBlock implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
final protected TextBlock getTitle(String s, ISkinSimple spriteContainer) {
|
final protected TextBlock getTitle(String s, ISkinSimple spriteContainer) {
|
||||||
if (s.length() <= 4) {
|
if (s.length() <= 4)
|
||||||
return null;
|
return null;
|
||||||
}
|
|
||||||
s = StringUtils.trin(s.substring(2, s.length() - 2));
|
s = StringUtils.trin(s.substring(2, s.length() - 2));
|
||||||
return Display.getWithNewlines(s).create(titleConfig, HorizontalAlignment.LEFT, spriteContainer);
|
return Display.getWithNewlines(s).create(titleConfig, HorizontalAlignment.LEFT, spriteContainer);
|
||||||
}
|
}
|
||||||
@ -98,16 +103,22 @@ public abstract class BodyEnhancedAbstract extends AbstractTextBlock implements
|
|||||||
|
|
||||||
final protected TextBlock decorate(StringBounder stringBounder, TextBlock b, char separator, TextBlock title) {
|
final protected TextBlock decorate(StringBounder stringBounder, TextBlock b, char separator, TextBlock title) {
|
||||||
final double marginX = getMarginX();
|
final double marginX = getMarginX();
|
||||||
if (separator == 0) {
|
if (separator == 0)
|
||||||
return TextBlockUtils.withMargin(b, marginX, 0);
|
return TextBlockUtils.withMargin(b, marginX, 0);
|
||||||
}
|
|
||||||
if (title == null) {
|
if (title == null)
|
||||||
return new TextBlockLineBefore(TextBlockUtils.withMargin(b, marginX, 4), separator);
|
return new TextBlockLineBefore(getDefaultThickness(), TextBlockUtils.withMargin(b, marginX, 4), separator);
|
||||||
}
|
|
||||||
final Dimension2D dimTitle = title.calculateDimension(stringBounder);
|
final Dimension2D dimTitle = title.calculateDimension(stringBounder);
|
||||||
final TextBlock raw = new TextBlockLineBefore(
|
final TextBlock raw = new TextBlockLineBefore(getDefaultThickness(),
|
||||||
TextBlockUtils.withMargin(b, marginX, 6, dimTitle.getHeight() / 2, 4), separator, title);
|
TextBlockUtils.withMargin(b, marginX, 6, dimTitle.getHeight() / 2, 4), separator, title);
|
||||||
return TextBlockUtils.withMargin(raw, 0, 0, dimTitle.getHeight() / 2, 0);
|
return TextBlockUtils.withMargin(raw, 0, 0, dimTitle.getHeight() / 2, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final protected double getDefaultThickness() {
|
||||||
|
if (UseStyle.useBetaStyle())
|
||||||
|
return style.value(PName.LineThickness).asDouble();
|
||||||
|
return 1.5;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -74,8 +74,9 @@ public class BodyFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static TextBlock create3(Display rawBody, FontParam fontParam, ISkinSimple skinParam,
|
public static TextBlock create3(Display rawBody, FontParam fontParam, ISkinSimple skinParam,
|
||||||
HorizontalAlignment align, FontConfiguration titleConfig, LineBreakStrategy lineBreakStrategy) {
|
HorizontalAlignment align, FontConfiguration titleConfig, LineBreakStrategy lineBreakStrategy,
|
||||||
return new BodyEnhanced2(rawBody, fontParam, skinParam, align, titleConfig, lineBreakStrategy);
|
Style style) {
|
||||||
|
return new BodyEnhanced2(rawBody, fontParam, skinParam, align, titleConfig, lineBreakStrategy, style);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -56,13 +56,10 @@ import net.sourceforge.plantuml.graphic.TextBlock;
|
|||||||
import net.sourceforge.plantuml.graphic.TextBlockLineBefore;
|
import net.sourceforge.plantuml.graphic.TextBlockLineBefore;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
import net.sourceforge.plantuml.graphic.TextBlockUtils;
|
||||||
import net.sourceforge.plantuml.graphic.TextBlockWithUrl;
|
import net.sourceforge.plantuml.graphic.TextBlockWithUrl;
|
||||||
import net.sourceforge.plantuml.graphic.color.ColorType;
|
|
||||||
import net.sourceforge.plantuml.skin.VisibilityModifier;
|
import net.sourceforge.plantuml.skin.VisibilityModifier;
|
||||||
import net.sourceforge.plantuml.skin.rose.Rose;
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
import net.sourceforge.plantuml.style.PName;
|
import net.sourceforge.plantuml.style.PName;
|
||||||
import net.sourceforge.plantuml.style.SName;
|
|
||||||
import net.sourceforge.plantuml.style.Style;
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.style.StyleSignature;
|
|
||||||
import net.sourceforge.plantuml.svek.Ports;
|
import net.sourceforge.plantuml.svek.Ports;
|
||||||
import net.sourceforge.plantuml.svek.WithPorts;
|
import net.sourceforge.plantuml.svek.WithPorts;
|
||||||
import net.sourceforge.plantuml.ugraphic.PlacementStrategy;
|
import net.sourceforge.plantuml.ugraphic.PlacementStrategy;
|
||||||
@ -73,13 +70,13 @@ import net.sourceforge.plantuml.ugraphic.PlacementStrategyY1Y2Right;
|
|||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.ULayoutGroup;
|
import net.sourceforge.plantuml.ugraphic.ULayoutGroup;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColorUtils;
|
|
||||||
import net.sourceforge.plantuml.utils.CharHidder;
|
import net.sourceforge.plantuml.utils.CharHidder;
|
||||||
|
|
||||||
public class MethodsOrFieldsArea extends AbstractTextBlock implements TextBlock, WithPorts {
|
public class MethodsOrFieldsArea extends AbstractTextBlock implements TextBlock, WithPorts {
|
||||||
|
|
||||||
public TextBlock asBlockMemberImpl() {
|
public TextBlock asBlockMemberImpl() {
|
||||||
return new TextBlockLineBefore(TextBlockUtils.withMargin(this, 6, 4));
|
return new TextBlockLineBefore(style.value(PName.LineThickness).asDouble(),
|
||||||
|
TextBlockUtils.withMargin(this, 6, 4));
|
||||||
}
|
}
|
||||||
|
|
||||||
private final FontParam fontParam;
|
private final FontParam fontParam;
|
||||||
|
@ -78,6 +78,7 @@ public class Rainbow {
|
|||||||
return Rainbow.build(new HtmlColorAndStyle(arrowColor, arrowHeadColor));
|
return Rainbow.build(new HtmlColorAndStyle(arrowColor, arrowHeadColor));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
public static Rainbow build(ISkinParam skinParam) {
|
public static Rainbow build(ISkinParam skinParam) {
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
|
@ -51,19 +51,21 @@ public class TextBlockLineBefore extends AbstractTextBlock implements TextBlock,
|
|||||||
private final TextBlock textBlock;
|
private final TextBlock textBlock;
|
||||||
private final char separator;
|
private final char separator;
|
||||||
private final TextBlock title;
|
private final TextBlock title;
|
||||||
|
private final double defaultThickness;
|
||||||
|
|
||||||
public TextBlockLineBefore(TextBlock textBlock, char separator, TextBlock title) {
|
public TextBlockLineBefore(double defaultThickness, TextBlock textBlock, char separator, TextBlock title) {
|
||||||
this.textBlock = textBlock;
|
this.textBlock = textBlock;
|
||||||
this.separator = separator;
|
this.separator = separator;
|
||||||
this.title = title;
|
this.title = title;
|
||||||
|
this.defaultThickness = defaultThickness;
|
||||||
}
|
}
|
||||||
|
|
||||||
public TextBlockLineBefore(TextBlock textBlock, char separator) {
|
public TextBlockLineBefore(double defaultThickness, TextBlock textBlock, char separator) {
|
||||||
this(textBlock, separator, null);
|
this(defaultThickness, textBlock, separator, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TextBlockLineBefore(TextBlock textBlock) {
|
public TextBlockLineBefore(double defaultThickness, TextBlock textBlock) {
|
||||||
this(textBlock, '\0');
|
this(defaultThickness, textBlock, '\0');
|
||||||
}
|
}
|
||||||
|
|
||||||
public Dimension2D calculateDimension(StringBounder stringBounder) {
|
public Dimension2D calculateDimension(StringBounder stringBounder) {
|
||||||
@ -77,18 +79,18 @@ public class TextBlockLineBefore extends AbstractTextBlock implements TextBlock,
|
|||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final HColor color = ug.getParam().getColor();
|
final HColor color = ug.getParam().getColor();
|
||||||
if (title == null) {
|
if (title == null)
|
||||||
UHorizontalLine.infinite(1, 1, separator).drawMe(ug);
|
UHorizontalLine.infinite(defaultThickness, 1, 1, separator).drawMe(ug);
|
||||||
}
|
|
||||||
textBlock.drawU(ug);
|
textBlock.drawU(ug);
|
||||||
if (color == null) {
|
if (color == null)
|
||||||
ug = ug.apply(new HColorNone());
|
ug = ug.apply(new HColorNone());
|
||||||
} else {
|
else
|
||||||
ug = ug.apply(color);
|
ug = ug.apply(color);
|
||||||
}
|
|
||||||
if (title != null) {
|
if (title != null)
|
||||||
UHorizontalLine.infinite(1, 1, title, separator).drawMe(ug);
|
UHorizontalLine.infinite(defaultThickness, 1, 1, title, separator).drawMe(ug);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -102,10 +102,10 @@ public class TextBlockVertical2 extends AbstractTextBlock implements TextBlock,
|
|||||||
final Dimension2D dimb = block.calculateDimension(ug.getStringBounder());
|
final Dimension2D dimb = block.calculateDimension(ug.getStringBounder());
|
||||||
if (block instanceof TextBlockBackcolored) {
|
if (block instanceof TextBlockBackcolored) {
|
||||||
final HColor back = ((TextBlockBackcolored) block).getBackcolor();
|
final HColor back = ((TextBlockBackcolored) block).getBackcolor();
|
||||||
if (back != null) {
|
if (back != null)
|
||||||
ug.apply(UTranslate.dy(y)).apply(back).apply(back.bg())
|
ug.apply(UTranslate.dy(y)).apply(back).apply(back.bg())
|
||||||
.draw(new URectangle(dimtotal.getWidth(), dimb.getHeight()));
|
.draw(new URectangle(dimtotal.getWidth(), dimb.getHeight()));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (horizontalAlignment == HorizontalAlignment.LEFT) {
|
if (horizontalAlignment == HorizontalAlignment.LEFT) {
|
||||||
block.drawU(ug.apply(UTranslate.dy(y)));
|
block.drawU(ug.apply(UTranslate.dy(y)));
|
||||||
|
@ -65,7 +65,7 @@ public class Frame implements Component {
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -223,7 +223,7 @@ public class TaskDrawRegular extends AbstractTaskDraw {
|
|||||||
final HColor borderColor = style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getColorSet());
|
final HColor borderColor = style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), getColorSet());
|
||||||
final double shadowing = style.value(PName.Shadowing).asDouble();
|
final double shadowing = style.value(PName.Shadowing).asDouble();
|
||||||
|
|
||||||
return new Opale(shadowing, borderColor, noteBackgroundColor, sheet1, false);
|
return new Opale(shadowing, borderColor, noteBackgroundColor, sheet1, false, style.getStroke());
|
||||||
}
|
}
|
||||||
|
|
||||||
public FingerPrint getFingerPrint(StringBounder stringBounder) {
|
public FingerPrint getFingerPrint(StringBounder stringBounder) {
|
||||||
|
@ -133,7 +133,8 @@ public class CucaDiagramFileMakerSmetana implements CucaDiagramFileMaker {
|
|||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
if (minMax != null) {
|
if (minMax != null) {
|
||||||
// Matches the adjustment in SvekResult.calculateDimension() except no need to adjust for minY because
|
// Matches the adjustment in SvekResult.calculateDimension() except no need to
|
||||||
|
// adjust for minY because
|
||||||
// mirroring takes care of that
|
// mirroring takes care of that
|
||||||
ug = ug.apply(new UTranslate(6 - minMax.getMinX(), 6));
|
ug = ug.apply(new UTranslate(6 - minMax.getMinX(), 6));
|
||||||
}
|
}
|
||||||
@ -158,8 +159,8 @@ public class CucaDiagramFileMakerSmetana implements CucaDiagramFileMaker {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
final ST_Agedge_s edge = ent.getValue();
|
final ST_Agedge_s edge = ent.getValue();
|
||||||
new SmetanaPath(link, edge, ymirror, diagram, getLabel(link), getQualifier(link, 1), getQualifier(link, 2))
|
new SmetanaPath(link, edge, ymirror, diagram, getLabel(link), getQualifier(link, 1),
|
||||||
.drawU(ug);
|
getQualifier(link, 2)).drawU(ug);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -221,7 +222,7 @@ public class CucaDiagramFileMakerSmetana implements CucaDiagramFileMaker {
|
|||||||
// ug.apply(new UTranslate(llx, lly)).apply(new
|
// ug.apply(new UTranslate(llx, lly)).apply(new
|
||||||
// UChangeColor(HtmlColorUtils.BLUE))
|
// UChangeColor(HtmlColorUtils.BLUE))
|
||||||
// .draw(new URectangle(urx - llx, ury - lly));
|
// .draw(new URectangle(urx - llx, ury - lly));
|
||||||
cluster.drawU(ug, new UStroke(1.5), diagram.getUmlDiagramType(), diagram.getSkinParam());
|
cluster.drawU(ug, diagram.getUmlDiagramType(), diagram.getSkinParam());
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
System.err.println("CANNOT DRAW GROUP");
|
System.err.println("CANNOT DRAW GROUP");
|
||||||
}
|
}
|
||||||
@ -324,7 +325,8 @@ public class CucaDiagramFileMakerSmetana implements CucaDiagramFileMaker {
|
|||||||
throw new IllegalStateException();
|
throw new IllegalStateException();
|
||||||
}
|
}
|
||||||
final IEntityImage image = printEntityInternal(ent);
|
final IEntityImage image = printEntityInternal(ent);
|
||||||
final SvekNode node = getBibliotekon().createNode(ent, image, dotStringFactory.getColorSequence(), stringBounder);
|
final SvekNode node = getBibliotekon().createNode(ent, image, dotStringFactory.getColorSequence(),
|
||||||
|
stringBounder);
|
||||||
dotStringFactory.addNode(node);
|
dotStringFactory.addNode(node);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -449,9 +451,7 @@ public class CucaDiagramFileMakerSmetana implements CucaDiagramFileMaker {
|
|||||||
|
|
||||||
// imageBuilder.setUDrawable(new Drawing(new YMirror(dim.getHeight())));
|
// imageBuilder.setUDrawable(new Drawing(new YMirror(dim.getHeight())));
|
||||||
final TextBlock drawable = new Drawing(new YMirror(minMax.getMaxY()), minMax);
|
final TextBlock drawable = new Drawing(new YMirror(minMax.getMaxY()), minMax);
|
||||||
return diagram.createImageBuilder(fileFormatOption)
|
return diagram.createImageBuilder(fileFormatOption).drawable(drawable).write(os);
|
||||||
.drawable(drawable)
|
|
||||||
.write(os);
|
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
SmetanaDebug.printMe();
|
SmetanaDebug.printMe();
|
||||||
UmlDiagram.exportDiagramError(os, e, fileFormatOption, diagram.seed(), diagram.getMetadata(),
|
UmlDiagram.exportDiagramError(os, e, fileFormatOption, diagram.seed(), diagram.getMetadata(),
|
||||||
@ -620,7 +620,8 @@ public class CucaDiagramFileMakerSmetana implements CucaDiagramFileMaker {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final IEntityImage image = printEntityInternal(ent);
|
final IEntityImage image = printEntityInternal(ent);
|
||||||
final SvekNode shape = getBibliotekon().createNode(ent, image, dotStringFactory.getColorSequence(), stringBounder);
|
final SvekNode shape = getBibliotekon().createNode(ent, image, dotStringFactory.getColorSequence(),
|
||||||
|
stringBounder);
|
||||||
// dotStringFactory.addShape(shape);
|
// dotStringFactory.addShape(shape);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,14 +54,14 @@ import net.sourceforge.plantuml.style.WithStyle;
|
|||||||
public abstract class AbstractMessage implements EventWithDeactivate, WithStyle {
|
public abstract class AbstractMessage implements EventWithDeactivate, WithStyle {
|
||||||
|
|
||||||
public Style[] getUsedStyles() {
|
public Style[] getUsedStyles() {
|
||||||
Style style = getDefaultStyleDefinition().getMergedStyle(styleBuilder);
|
Style style = getStyleSignature().getMergedStyle(styleBuilder);
|
||||||
if (style != null && arrowConfiguration.getColor() != null) {
|
if (style != null && arrowConfiguration.getColor() != null) {
|
||||||
style = style.eventuallyOverride(PName.LineColor, arrowConfiguration.getColor());
|
style = style.eventuallyOverride(PName.LineColor, arrowConfiguration.getColor());
|
||||||
}
|
}
|
||||||
return new Style[] { style };
|
return new Style[] { style };
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.sequenceDiagram, SName.arrow);
|
return StyleSignature.of(SName.root, SName.element, SName.sequenceDiagram, SName.arrow);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,8 +48,8 @@ public class Delay extends AbstractEvent implements Event, WithStyle {
|
|||||||
|
|
||||||
final private Style style;
|
final private Style style;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return ComponentType.DELAY_TEXT.getDefaultStyleDefinition();
|
return ComponentType.DELAY_TEXT.getStyleSignature();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Style[] getUsedStyles() {
|
public Style[] getUsedStyles() {
|
||||||
@ -58,7 +58,7 @@ public class Delay extends AbstractEvent implements Event, WithStyle {
|
|||||||
|
|
||||||
public Delay(Display text, StyleBuilder styleBuilder) {
|
public Delay(Display text, StyleBuilder styleBuilder) {
|
||||||
this.text = text;
|
this.text = text;
|
||||||
this.style = getDefaultStyleDefinition().getMergedStyle(styleBuilder);
|
this.style = getStyleSignature().getMergedStyle(styleBuilder);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final Display getText() {
|
public final Display getText() {
|
||||||
|
@ -48,8 +48,8 @@ public class Divider extends AbstractEvent implements Event, WithStyle {
|
|||||||
|
|
||||||
final private Style style;
|
final private Style style;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return ComponentType.DIVIDER.getDefaultStyleDefinition();
|
return ComponentType.DIVIDER.getStyleSignature();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Style[] getUsedStyles() {
|
public Style[] getUsedStyles() {
|
||||||
@ -58,7 +58,7 @@ public class Divider extends AbstractEvent implements Event, WithStyle {
|
|||||||
|
|
||||||
public Divider(Display text, StyleBuilder styleBuilder) {
|
public Divider(Display text, StyleBuilder styleBuilder) {
|
||||||
this.text = text;
|
this.text = text;
|
||||||
this.style = getDefaultStyleDefinition().getMergedStyle(styleBuilder);
|
this.style = getStyleSignature().getMergedStyle(styleBuilder);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final Display getText() {
|
public final Display getText() {
|
||||||
|
@ -94,12 +94,12 @@ public class Doll implements WithStyle {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
final public StyleSignature getDefaultStyleDefinition() {
|
final public StyleSignature getStyleSignature() {
|
||||||
return ComponentType.ENGLOBER.getDefaultStyleDefinition();
|
return ComponentType.ENGLOBER.getStyleSignature();
|
||||||
}
|
}
|
||||||
|
|
||||||
final public Style[] getUsedStyles() {
|
final public Style[] getUsedStyles() {
|
||||||
Style tmp = getDefaultStyleDefinition().with(englober.getStereotype()).getMergedStyle(styleBuilder);
|
Style tmp = getStyleSignature().with(englober.getStereotype()).getMergedStyle(styleBuilder);
|
||||||
final HColor backColor = englober.getBoxColor();
|
final HColor backColor = englober.getBoxColor();
|
||||||
if (tmp != null)
|
if (tmp != null)
|
||||||
tmp = tmp.eventuallyOverride(PName.BackGroundColor, backColor);
|
tmp = tmp.eventuallyOverride(PName.BackGroundColor, backColor);
|
||||||
|
@ -55,7 +55,7 @@ public abstract class Grouping implements Event, WithStyle {
|
|||||||
final private Style style;
|
final private Style style;
|
||||||
final private Style styleHeader;
|
final private Style styleHeader;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return StyleSignature.of(SName.root, SName.element, SName.sequenceDiagram, SName.group);
|
return StyleSignature.of(SName.root, SName.element, SName.sequenceDiagram, SName.group);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,7 +76,7 @@ public abstract class Grouping implements Event, WithStyle {
|
|||||||
this.comment = comment;
|
this.comment = comment;
|
||||||
this.type = type;
|
this.type = type;
|
||||||
this.backColorElement = backColorElement;
|
this.backColorElement = backColorElement;
|
||||||
this.style = getDefaultStyleDefinition().getMergedStyle(styleBuilder);
|
this.style = getStyleSignature().getMergedStyle(styleBuilder);
|
||||||
this.styleHeader = getHeaderStyleDefinition().getMergedStyle(styleBuilder);
|
this.styleHeader = getHeaderStyleDefinition().getMergedStyle(styleBuilder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +112,7 @@ public class LinkAnchor {
|
|||||||
|
|
||||||
final Display display = Display.getWithNewlines(message);
|
final Display display = Display.getWithNewlines(message);
|
||||||
final TextBlock title = display.create(fontConfiguration, HorizontalAlignment.CENTER, skinParam);
|
final TextBlock title = display.create(fontConfiguration, HorizontalAlignment.CENTER, skinParam);
|
||||||
final Snake snake = Snake.create(Arrows.asToUp(), rainbow, Arrows.asToDown()).withLabel(title,
|
final Snake snake = Snake.create(skinParam, Arrows.asToUp(), rainbow, Arrows.asToDown()).withLabel(title,
|
||||||
HorizontalAlignment.CENTER);
|
HorizontalAlignment.CENTER);
|
||||||
|
|
||||||
snake.addPoint(x, ymin + 2);
|
snake.addPoint(x, ymin + 2);
|
||||||
|
@ -72,7 +72,7 @@ final public class Note extends AbstractEvent implements Event, SpecificBackcolo
|
|||||||
|
|
||||||
private Style style;
|
private Style style;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return noteStyle.getDefaultStyleDefinition();
|
return noteStyle.getDefaultStyleDefinition();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,14 +103,14 @@ final public class Note extends AbstractEvent implements Event, SpecificBackcolo
|
|||||||
this.position = position;
|
this.position = position;
|
||||||
this.strings = strings;
|
this.strings = strings;
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
this.style = getDefaultStyleDefinition().getMergedStyle(styleBuilder);
|
this.style = getStyleSignature().getMergedStyle(styleBuilder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setStereotype(Stereotype stereotype) {
|
public void setStereotype(Stereotype stereotype) {
|
||||||
if (UseStyle.useBetaStyle()) {
|
if (UseStyle.useBetaStyle()) {
|
||||||
final List<Style> others = stereotype.getStyles(styleBuilder);
|
final List<Style> others = stereotype.getStyles(styleBuilder);
|
||||||
this.style = getDefaultStyleDefinition().mergeWith(others).getMergedStyle(styleBuilder);
|
this.style = getStyleSignature().mergeWith(others).getMergedStyle(styleBuilder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,18 +72,18 @@ public class Participant implements SpecificBackcolorable, WithStyle {
|
|||||||
|
|
||||||
// private Style style;
|
// private Style style;
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
return type.getDefaultStyleDefinition().addClickable(getUrl());
|
return type.getStyleSignature().addClickable(getUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
public Style[] getUsedStyles() {
|
public Style[] getUsedStyles() {
|
||||||
if (UseStyle.useBetaStyle() == false) {
|
if (UseStyle.useBetaStyle() == false) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
final StyleSignature signature = getDefaultStyleDefinition().with(stereotype);
|
final StyleSignature signature = getStyleSignature().with(stereotype);
|
||||||
Style tmp = signature.getMergedStyle(styleBuilder);
|
Style tmp = signature.getMergedStyle(styleBuilder);
|
||||||
tmp = tmp.eventuallyOverride(getColors());
|
tmp = tmp.eventuallyOverride(getColors());
|
||||||
Style stereo = getDefaultStyleDefinition().forStereotypeItself(stereotype).getMergedStyle(styleBuilder);
|
Style stereo = getStyleSignature().forStereotypeItself(stereotype).getMergedStyle(styleBuilder);
|
||||||
if (tmp != null) {
|
if (tmp != null) {
|
||||||
stereo = tmp.mergeWith(stereo);
|
stereo = tmp.mergeWith(stereo);
|
||||||
}
|
}
|
||||||
|
@ -60,7 +60,7 @@ public enum ParticipantType implements Styleable {
|
|||||||
return background;
|
return background;
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
if (this == PARTICIPANT) {
|
if (this == PARTICIPANT) {
|
||||||
return StyleSignature.of(SName.root, SName.element,
|
return StyleSignature.of(SName.root, SName.element,
|
||||||
SName.sequenceDiagram, SName.participant);
|
SName.sequenceDiagram, SName.participant);
|
||||||
|
@ -623,7 +623,7 @@ class DrawableSetInitializer {
|
|||||||
participantDisplay);
|
participantDisplay);
|
||||||
final Component tail = drawableSet.getSkin().createComponent(p.getUsedStyles(), tailType, null, skinParam,
|
final Component tail = drawableSet.getSkin().createComponent(p.getUsedStyles(), tailType, null, skinParam,
|
||||||
participantDisplay);
|
participantDisplay);
|
||||||
final Style style = this.defaultLineType.getDefaultStyleDefinition().with(p.getStereotype())
|
final Style style = this.defaultLineType.getStyleSignature().with(p.getStereotype())
|
||||||
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
final Component line = drawableSet.getSkin().createComponent(new Style[] { style }, this.defaultLineType, null,
|
final Component line = drawableSet.getSkin().createComponent(new Style[] { style }, this.defaultLineType, null,
|
||||||
drawableSet.getSkinParam(), participantDisplay);
|
drawableSet.getSkinParam(), participantDisplay);
|
||||||
@ -633,7 +633,7 @@ class DrawableSetInitializer {
|
|||||||
skinParam.maxAsciiMessageLength() > 0 ? 1 : 5);
|
skinParam.maxAsciiMessageLength() > 0 ? 1 : 5);
|
||||||
|
|
||||||
final Component comp = drawableSet.getSkin().createComponent(
|
final Component comp = drawableSet.getSkin().createComponent(
|
||||||
new Style[] { ComponentType.ALIVE_BOX_CLOSE_CLOSE.getDefaultStyleDefinition()
|
new Style[] { ComponentType.ALIVE_BOX_CLOSE_CLOSE.getStyleSignature()
|
||||||
.getMergedStyle(drawableSet.getSkinParam().getCurrentStyleBuilder()) },
|
.getMergedStyle(drawableSet.getSkinParam().getCurrentStyleBuilder()) },
|
||||||
ComponentType.ALIVE_BOX_CLOSE_CLOSE, null, drawableSet.getSkinParam(), null);
|
ComponentType.ALIVE_BOX_CLOSE_CLOSE, null, drawableSet.getSkinParam(), null);
|
||||||
|
|
||||||
|
@ -220,7 +220,7 @@ public class LifeLine {
|
|||||||
type = type == ComponentType.ALIVE_BOX_CLOSE_OPEN ? ComponentType.ALIVE_BOX_CLOSE_CLOSE
|
type = type == ComponentType.ALIVE_BOX_CLOSE_OPEN ? ComponentType.ALIVE_BOX_CLOSE_CLOSE
|
||||||
: ComponentType.ALIVE_BOX_OPEN_CLOSE;
|
: ComponentType.ALIVE_BOX_OPEN_CLOSE;
|
||||||
}
|
}
|
||||||
Style style = type.getDefaultStyleDefinition().getMergedStyle(skinParam2.getCurrentStyleBuilder());
|
Style style = type.getStyleSignature().getMergedStyle(skinParam2.getCurrentStyleBuilder());
|
||||||
if (style != null) {
|
if (style != null) {
|
||||||
style = style.eventuallyOverride(PName.BackGroundColor, specificBackColor);
|
style = style.eventuallyOverride(PName.BackGroundColor, specificBackColor);
|
||||||
style = style.eventuallyOverride(PName.LineColor, specificLineColor);
|
style = style.eventuallyOverride(PName.LineColor, specificLineColor);
|
||||||
|
@ -74,7 +74,7 @@ class Step1Message extends Step1Abstract {
|
|||||||
final ArrowComponent comp = drawingSet.getSkin().createComponentArrow(message.getUsedStyles(), getConfig(),
|
final ArrowComponent comp = drawingSet.getSkin().createComponentArrow(message.getUsedStyles(), getConfig(),
|
||||||
drawingSet.getSkinParam(), message.getLabelNumbered());
|
drawingSet.getSkinParam(), message.getLabelNumbered());
|
||||||
final Component compAliveBox = drawingSet.getSkin().createComponent(
|
final Component compAliveBox = drawingSet.getSkin().createComponent(
|
||||||
new Style[] { ComponentType.ALIVE_BOX_OPEN_OPEN.getDefaultStyleDefinition()
|
new Style[] { ComponentType.ALIVE_BOX_OPEN_OPEN.getStyleSignature()
|
||||||
.getMergedStyle(drawingSet.getSkinParam().getCurrentStyleBuilder()) },
|
.getMergedStyle(drawingSet.getSkinParam().getCurrentStyleBuilder()) },
|
||||||
ComponentType.ALIVE_BOX_OPEN_OPEN, null, drawingSet.getSkinParam(), null);
|
ComponentType.ALIVE_BOX_OPEN_OPEN, null, drawingSet.getSkinParam(), null);
|
||||||
|
|
||||||
@ -224,7 +224,7 @@ class Step1Message extends Step1Abstract {
|
|||||||
private double getHalfLifeWidth() {
|
private double getHalfLifeWidth() {
|
||||||
return getDrawingSet().getSkin()
|
return getDrawingSet().getSkin()
|
||||||
.createComponent(
|
.createComponent(
|
||||||
new Style[] { ComponentType.ALIVE_BOX_OPEN_OPEN.getDefaultStyleDefinition()
|
new Style[] { ComponentType.ALIVE_BOX_OPEN_OPEN.getStyleSignature()
|
||||||
.getMergedStyle(getDrawingSet().getSkinParam().getCurrentStyleBuilder()) },
|
.getMergedStyle(getDrawingSet().getSkinParam().getCurrentStyleBuilder()) },
|
||||||
ComponentType.ALIVE_BOX_OPEN_OPEN, null, getDrawingSet().getSkinParam(), Display.create(""))
|
ComponentType.ALIVE_BOX_OPEN_OPEN, null, getDrawingSet().getSkinParam(), Display.create(""))
|
||||||
.getPreferredWidth(null) / 2;
|
.getPreferredWidth(null) / 2;
|
||||||
|
@ -37,66 +37,23 @@ package net.sourceforge.plantuml.sequencediagram.teoz;
|
|||||||
|
|
||||||
import java.awt.geom.Dimension2D;
|
import java.awt.geom.Dimension2D;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.ColorParam;
|
|
||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
import net.sourceforge.plantuml.graphic.UDrawable;
|
import net.sourceforge.plantuml.graphic.UDrawable;
|
||||||
import net.sourceforge.plantuml.real.Real;
|
|
||||||
import net.sourceforge.plantuml.sequencediagram.AbstractMessage;
|
import net.sourceforge.plantuml.sequencediagram.AbstractMessage;
|
||||||
import net.sourceforge.plantuml.sequencediagram.Event;
|
|
||||||
import net.sourceforge.plantuml.sequencediagram.Note;
|
import net.sourceforge.plantuml.sequencediagram.Note;
|
||||||
import net.sourceforge.plantuml.skin.Area;
|
import net.sourceforge.plantuml.skin.Area;
|
||||||
import net.sourceforge.plantuml.skin.Component;
|
import net.sourceforge.plantuml.skin.Component;
|
||||||
import net.sourceforge.plantuml.skin.ComponentType;
|
|
||||||
import net.sourceforge.plantuml.skin.Context2D;
|
import net.sourceforge.plantuml.skin.Context2D;
|
||||||
import net.sourceforge.plantuml.skin.rose.Rose;
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.ULine;
|
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
|
||||||
|
|
||||||
public class CommunicationTileNoteBottom extends AbstractTile {
|
public class CommunicationTileNoteBottom extends CommunicationTileNoteBottomTopAbstract {
|
||||||
|
|
||||||
private final Tile tile;
|
|
||||||
private final AbstractMessage message;
|
|
||||||
private final Rose skin;
|
|
||||||
private final ISkinParam skinParam;
|
|
||||||
private final Note noteOnMessage;
|
|
||||||
|
|
||||||
public Event getEvent() {
|
|
||||||
return message;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public double getContactPointRelative() {
|
|
||||||
return tile.getContactPointRelative();
|
|
||||||
}
|
|
||||||
|
|
||||||
public CommunicationTileNoteBottom(Tile tile, AbstractMessage message, Rose skin, ISkinParam skinParam,
|
public CommunicationTileNoteBottom(Tile tile, AbstractMessage message, Rose skin, ISkinParam skinParam,
|
||||||
Note noteOnMessage) {
|
Note noteOnMessage) {
|
||||||
super(((AbstractTile) tile).getStringBounder());
|
super(tile, message, skin, skinParam, noteOnMessage);
|
||||||
this.tile = tile;
|
|
||||||
this.message = message;
|
|
||||||
this.skin = skin;
|
|
||||||
this.skinParam = skinParam;
|
|
||||||
this.noteOnMessage = noteOnMessage;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
final protected void callbackY_internal(double y) {
|
|
||||||
tile.callbackY(y);
|
|
||||||
}
|
|
||||||
|
|
||||||
private Component getComponent(StringBounder stringBounder) {
|
|
||||||
final Component comp = skin.createComponentNote(noteOnMessage.getUsedStyles(), ComponentType.NOTE, noteOnMessage.getSkinParamBackcolored(skinParam),
|
|
||||||
noteOnMessage.getStrings());
|
|
||||||
return comp;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Real getNotePosition(StringBounder stringBounder) {
|
|
||||||
final Real minX = tile.getMinX();
|
|
||||||
return minX;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
@ -118,34 +75,4 @@ public class CommunicationTileNoteBottom extends AbstractTile {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private final double spacey = 10;
|
|
||||||
|
|
||||||
private void drawLine(UGraphic ug, double x1, double y1, double x2, double y2) {
|
|
||||||
final HColor color = new Rose().getHtmlColor(skinParam, ColorParam.arrow);
|
|
||||||
|
|
||||||
final double dx = x2 - x1;
|
|
||||||
final double dy = y2 - y1;
|
|
||||||
|
|
||||||
ug.apply(new UTranslate(x1, y1)).apply(color).apply(new UStroke(2, 2, 1)).draw(new ULine(dx, dy));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getPreferredHeight() {
|
|
||||||
final Component comp = getComponent(getStringBounder());
|
|
||||||
final Dimension2D dim = comp.getPreferredDimension(getStringBounder());
|
|
||||||
return tile.getPreferredHeight() + dim.getHeight() + spacey;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addConstraints() {
|
|
||||||
tile.addConstraints();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Real getMinX() {
|
|
||||||
return tile.getMinX();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Real getMaxX() {
|
|
||||||
return tile.getMaxX();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,163 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* (C) Copyright 2009-2020, Arnaud Roques
|
||||||
|
*
|
||||||
|
* Project Info: http://plantuml.com
|
||||||
|
*
|
||||||
|
* If you like this project or if you find it useful, you can support us at:
|
||||||
|
*
|
||||||
|
* http://plantuml.com/patreon (only 1$ per month!)
|
||||||
|
* http://plantuml.com/paypal
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Original Author: Arnaud Roques
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package net.sourceforge.plantuml.sequencediagram.teoz;
|
||||||
|
|
||||||
|
import java.awt.geom.Dimension2D;
|
||||||
|
|
||||||
|
import net.sourceforge.plantuml.ColorParam;
|
||||||
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
|
import net.sourceforge.plantuml.graphic.UDrawable;
|
||||||
|
import net.sourceforge.plantuml.real.Real;
|
||||||
|
import net.sourceforge.plantuml.sequencediagram.AbstractMessage;
|
||||||
|
import net.sourceforge.plantuml.sequencediagram.Event;
|
||||||
|
import net.sourceforge.plantuml.sequencediagram.Note;
|
||||||
|
import net.sourceforge.plantuml.skin.Area;
|
||||||
|
import net.sourceforge.plantuml.skin.Component;
|
||||||
|
import net.sourceforge.plantuml.skin.ComponentType;
|
||||||
|
import net.sourceforge.plantuml.skin.Context2D;
|
||||||
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
|
import net.sourceforge.plantuml.style.SName;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.ULine;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
|
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
||||||
|
|
||||||
|
public abstract class CommunicationTileNoteBottomTopAbstract extends AbstractTile {
|
||||||
|
|
||||||
|
protected final Tile tile;
|
||||||
|
protected final AbstractMessage message;
|
||||||
|
protected final Rose skin;
|
||||||
|
protected final ISkinParam skinParam;
|
||||||
|
protected final Note noteOnMessage;
|
||||||
|
|
||||||
|
final public Event getEvent() {
|
||||||
|
return message;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
final public double getContactPointRelative() {
|
||||||
|
return tile.getContactPointRelative();
|
||||||
|
}
|
||||||
|
|
||||||
|
public CommunicationTileNoteBottomTopAbstract(Tile tile, AbstractMessage message, Rose skin, ISkinParam skinParam,
|
||||||
|
Note noteOnMessage) {
|
||||||
|
super(((AbstractTile) tile).getStringBounder());
|
||||||
|
this.tile = tile;
|
||||||
|
this.message = message;
|
||||||
|
this.skin = skin;
|
||||||
|
this.skinParam = skinParam;
|
||||||
|
this.noteOnMessage = noteOnMessage;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
final protected void callbackY_internal(double y) {
|
||||||
|
tile.callbackY(y);
|
||||||
|
}
|
||||||
|
|
||||||
|
final protected Component getComponent(StringBounder stringBounder) {
|
||||||
|
final Component comp = skin.createComponentNote(noteOnMessage.getUsedStyles(), ComponentType.NOTE,
|
||||||
|
noteOnMessage.getSkinParamBackcolored(skinParam), noteOnMessage.getStrings());
|
||||||
|
return comp;
|
||||||
|
}
|
||||||
|
|
||||||
|
final protected Real getNotePosition(StringBounder stringBounder) {
|
||||||
|
final Real minX = tile.getMinX();
|
||||||
|
return minX;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void drawU(UGraphic ug) {
|
||||||
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
|
final Component comp = getComponent(stringBounder);
|
||||||
|
final Dimension2D dim = comp.getPreferredDimension(stringBounder);
|
||||||
|
final Area area = new Area(dim.getWidth(), dim.getHeight());
|
||||||
|
((UDrawable) tile).drawU(ug);
|
||||||
|
|
||||||
|
final double middleMsg = (tile.getMinX().getCurrentValue() + tile.getMaxX().getCurrentValue()) / 2;
|
||||||
|
|
||||||
|
final double xNote = getNotePosition(stringBounder).getCurrentValue();
|
||||||
|
final double yNote = tile.getPreferredHeight();
|
||||||
|
|
||||||
|
comp.drawU(ug.apply(new UTranslate(xNote, yNote + spacey)), area, (Context2D) ug);
|
||||||
|
|
||||||
|
drawLine(ug, middleMsg, tile.getContactPointRelative(), xNote + dim.getWidth() / 2,
|
||||||
|
yNote + spacey + Rose.paddingY);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected final double spacey = 10;
|
||||||
|
|
||||||
|
protected final void drawLine(UGraphic ug, double x1, double y1, double x2, double y2) {
|
||||||
|
final HColor color;
|
||||||
|
|
||||||
|
if (UseStyle.useBetaStyle()) {
|
||||||
|
final Style style = StyleSignature.of(SName.root, SName.element, SName.sequenceDiagram)
|
||||||
|
.getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
|
color = style.value(PName.LineColor).asColor(skinParam.getThemeStyle(), skinParam.getIHtmlColorSet());
|
||||||
|
} else
|
||||||
|
color = new Rose().getHtmlColor(skinParam, ColorParam.arrow);
|
||||||
|
|
||||||
|
final double dx = x2 - x1;
|
||||||
|
final double dy = y2 - y1;
|
||||||
|
|
||||||
|
ug.apply(new UTranslate(x1, y1)).apply(color).apply(new UStroke(2, 2, 1)).draw(new ULine(dx, dy));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPreferredHeight() {
|
||||||
|
final Component comp = getComponent(getStringBounder());
|
||||||
|
final Dimension2D dim = comp.getPreferredDimension(getStringBounder());
|
||||||
|
return tile.getPreferredHeight() + dim.getHeight() + spacey;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addConstraints() {
|
||||||
|
tile.addConstraints();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Real getMinX() {
|
||||||
|
return tile.getMinX();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Real getMaxX() {
|
||||||
|
return tile.getMaxX();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -37,66 +37,23 @@ package net.sourceforge.plantuml.sequencediagram.teoz;
|
|||||||
|
|
||||||
import java.awt.geom.Dimension2D;
|
import java.awt.geom.Dimension2D;
|
||||||
|
|
||||||
import net.sourceforge.plantuml.ColorParam;
|
|
||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
import net.sourceforge.plantuml.graphic.UDrawable;
|
import net.sourceforge.plantuml.graphic.UDrawable;
|
||||||
import net.sourceforge.plantuml.real.Real;
|
|
||||||
import net.sourceforge.plantuml.sequencediagram.AbstractMessage;
|
import net.sourceforge.plantuml.sequencediagram.AbstractMessage;
|
||||||
import net.sourceforge.plantuml.sequencediagram.Event;
|
|
||||||
import net.sourceforge.plantuml.sequencediagram.Note;
|
import net.sourceforge.plantuml.sequencediagram.Note;
|
||||||
import net.sourceforge.plantuml.skin.Area;
|
import net.sourceforge.plantuml.skin.Area;
|
||||||
import net.sourceforge.plantuml.skin.Component;
|
import net.sourceforge.plantuml.skin.Component;
|
||||||
import net.sourceforge.plantuml.skin.ComponentType;
|
|
||||||
import net.sourceforge.plantuml.skin.Context2D;
|
import net.sourceforge.plantuml.skin.Context2D;
|
||||||
import net.sourceforge.plantuml.skin.rose.Rose;
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.ULine;
|
|
||||||
import net.sourceforge.plantuml.ugraphic.UStroke;
|
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
import net.sourceforge.plantuml.ugraphic.color.HColor;
|
|
||||||
|
|
||||||
public class CommunicationTileNoteTop extends AbstractTile {
|
public class CommunicationTileNoteTop extends CommunicationTileNoteBottomTopAbstract {
|
||||||
|
|
||||||
private final Tile tile;
|
|
||||||
private final AbstractMessage message;
|
|
||||||
private final Rose skin;
|
|
||||||
private final ISkinParam skinParam;
|
|
||||||
private final Note noteOnMessage;
|
|
||||||
|
|
||||||
public Event getEvent() {
|
|
||||||
return message;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public double getContactPointRelative() {
|
|
||||||
return tile.getContactPointRelative();
|
|
||||||
}
|
|
||||||
|
|
||||||
public CommunicationTileNoteTop(Tile tile, AbstractMessage message, Rose skin, ISkinParam skinParam,
|
public CommunicationTileNoteTop(Tile tile, AbstractMessage message, Rose skin, ISkinParam skinParam,
|
||||||
Note noteOnMessage) {
|
Note noteOnMessage) {
|
||||||
super(((AbstractTile) tile).getStringBounder());
|
super(tile, message, skin, skinParam, noteOnMessage);
|
||||||
this.tile = tile;
|
|
||||||
this.message = message;
|
|
||||||
this.skin = skin;
|
|
||||||
this.skinParam = skinParam;
|
|
||||||
this.noteOnMessage = noteOnMessage;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
final protected void callbackY_internal(double y) {
|
|
||||||
tile.callbackY(y);
|
|
||||||
}
|
|
||||||
|
|
||||||
private Component getComponent(StringBounder stringBounder) {
|
|
||||||
final Component comp = skin.createComponentNote(noteOnMessage.getUsedStyles(), ComponentType.NOTE, noteOnMessage.getSkinParamBackcolored(skinParam),
|
|
||||||
noteOnMessage.getStrings());
|
|
||||||
return comp;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Real getNotePosition(StringBounder stringBounder) {
|
|
||||||
final Real minX = tile.getMinX();
|
|
||||||
return minX;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
@ -118,34 +75,4 @@ public class CommunicationTileNoteTop extends AbstractTile {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private final double spacey = 10;
|
|
||||||
|
|
||||||
private void drawLine(UGraphic ug, double x1, double y1, double x2, double y2) {
|
|
||||||
final HColor color = new Rose().getHtmlColor(skinParam, ColorParam.arrow);
|
|
||||||
|
|
||||||
final double dx = x2 - x1;
|
|
||||||
final double dy = y2 - y1;
|
|
||||||
|
|
||||||
ug.apply(new UTranslate(x1, y1)).apply(color).apply(new UStroke(2, 2, 1)).draw(new ULine(dx, dy));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public double getPreferredHeight() {
|
|
||||||
final Component comp = getComponent(getStringBounder());
|
|
||||||
final Dimension2D dim = comp.getPreferredDimension(getStringBounder());
|
|
||||||
return tile.getPreferredHeight() + dim.getHeight() + spacey;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addConstraints() {
|
|
||||||
tile.addConstraints();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Real getMinX() {
|
|
||||||
return tile.getMinX();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Real getMaxX() {
|
|
||||||
return tile.getMaxX();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -47,6 +47,8 @@ import net.sourceforge.plantuml.skin.Component;
|
|||||||
import net.sourceforge.plantuml.skin.ComponentType;
|
import net.sourceforge.plantuml.skin.ComponentType;
|
||||||
import net.sourceforge.plantuml.skin.Context2D;
|
import net.sourceforge.plantuml.skin.Context2D;
|
||||||
import net.sourceforge.plantuml.skin.rose.Rose;
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
import net.sourceforge.plantuml.ugraphic.UTranslate;
|
||||||
|
|
||||||
@ -84,9 +86,15 @@ public class LifeEventTile extends AbstractTile {
|
|||||||
this.skinParam = skinParam;
|
this.skinParam = skinParam;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private StyleSignature getStyleSignature() {
|
||||||
|
return ComponentType.DESTROY.getStyleSignature();
|
||||||
|
}
|
||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
if (isDestroyWithoutMessage()) {
|
if (isDestroyWithoutMessage()) {
|
||||||
final Component cross = skin.createComponent(null, ComponentType.DESTROY, null, skinParam, null);
|
final Style style = getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
|
final Component cross = skin.createComponent(new Style[] { style }, ComponentType.DESTROY, null, skinParam,
|
||||||
|
null);
|
||||||
final Dimension2D dimCross = cross.getPreferredDimension(ug.getStringBounder());
|
final Dimension2D dimCross = cross.getPreferredDimension(ug.getStringBounder());
|
||||||
final double x = livingSpace.getPosC(ug.getStringBounder()).getCurrentValue();
|
final double x = livingSpace.getPosC(ug.getStringBounder()).getCurrentValue();
|
||||||
cross.drawU(ug.apply(UTranslate.dx(x - dimCross.getWidth() / 2)), null, (Context2D) ug);
|
cross.drawU(ug.apply(UTranslate.dx(x - dimCross.getWidth() / 2)), null, (Context2D) ug);
|
||||||
|
@ -70,11 +70,11 @@ public class LiveBoxesDrawer {
|
|||||||
|
|
||||||
public LiveBoxesDrawer(Context2D context, Rose skin, ISkinParam skinParam, Map<Double, Double> delays) {
|
public LiveBoxesDrawer(Context2D context, Rose skin, ISkinParam skinParam, Map<Double, Double> delays) {
|
||||||
this.cross = skin.createComponent(
|
this.cross = skin.createComponent(
|
||||||
new Style[] { ComponentType.DESTROY.getDefaultStyleDefinition()
|
new Style[] { ComponentType.DESTROY.getStyleSignature()
|
||||||
.getMergedStyle(skinParam.getCurrentStyleBuilder()) },
|
.getMergedStyle(skinParam.getCurrentStyleBuilder()) },
|
||||||
ComponentType.DESTROY, null, skinParam, null);
|
ComponentType.DESTROY, null, skinParam, null);
|
||||||
this.compForWidth = skin.createComponent(
|
this.compForWidth = skin.createComponent(
|
||||||
new Style[] { ComponentType.ALIVE_BOX_CLOSE_CLOSE.getDefaultStyleDefinition()
|
new Style[] { ComponentType.ALIVE_BOX_CLOSE_CLOSE.getStyleSignature()
|
||||||
.getMergedStyle(skinParam.getCurrentStyleBuilder()) },
|
.getMergedStyle(skinParam.getCurrentStyleBuilder()) },
|
||||||
ComponentType.ALIVE_BOX_CLOSE_CLOSE, null, skinParam, null);
|
ComponentType.ALIVE_BOX_CLOSE_CLOSE, null, skinParam, null);
|
||||||
this.context = context;
|
this.context = context;
|
||||||
@ -126,7 +126,7 @@ public class LiveBoxesDrawer {
|
|||||||
final Area area = new Area(width, yb - ya);
|
final Area area = new Area(width, yb - ya);
|
||||||
SkinParamBackcolored skinParam2 = new SkinParamBackcolored(skinParam,
|
SkinParamBackcolored skinParam2 = new SkinParamBackcolored(skinParam,
|
||||||
symbolContext == null ? null : symbolContext.getBackColor());
|
symbolContext == null ? null : symbolContext.getBackColor());
|
||||||
Style style = type.getDefaultStyleDefinition().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
Style style = type.getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
if (style == null) {
|
if (style == null) {
|
||||||
if (symbolContext != null)
|
if (symbolContext != null)
|
||||||
skinParam2.forceColor(ColorParam.sequenceLifeLineBorder, symbolContext.getForeColor());
|
skinParam2.forceColor(ColorParam.sequenceLifeLineBorder, symbolContext.getForeColor());
|
||||||
|
@ -110,7 +110,7 @@ public class MutingLine {
|
|||||||
if (y2 < y1) {
|
if (y2 < y1) {
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
}
|
||||||
final Style style = defaultLineType.getDefaultStyleDefinition().getMergedStyle(styleBuilder);
|
final Style style = defaultLineType.getStyleSignature().getMergedStyle(styleBuilder);
|
||||||
final Component comp = skin.createComponent(new Style[] { style }, defaultLineType, null, skinParam,
|
final Component comp = skin.createComponent(new Style[] { style }, defaultLineType, null, skinParam,
|
||||||
participant.getDisplay(skinParam.forceSequenceParticipantUnderlined()));
|
participant.getDisplay(skinParam.forceSequenceParticipantUnderlined()));
|
||||||
final Dimension2D dim = comp.getPreferredDimension(ug.getStringBounder());
|
final Dimension2D dim = comp.getPreferredDimension(ug.getStringBounder());
|
||||||
|
@ -50,7 +50,7 @@ public abstract class AbstractComponent implements Component {
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ public abstract class AbstractTextualComponent extends AbstractComponent {
|
|||||||
textBlock = new TextBlockEmpty();
|
textBlock = new TextBlockEmpty();
|
||||||
} else if (enhanced) {
|
} else if (enhanced) {
|
||||||
textBlock = BodyFactory.create3(this.display, FontParam.NOTE, spriteContainer, horizontalAlignment, fc,
|
textBlock = BodyFactory.create3(this.display, FontParam.NOTE, spriteContainer, horizontalAlignment, fc,
|
||||||
maxMessageSize);
|
maxMessageSize, style);
|
||||||
} else {
|
} else {
|
||||||
textBlock = this.display.create0(fc, horizontalAlignment, spriteContainer, maxMessageSize, CreoleMode.FULL,
|
textBlock = this.display.create0(fc, horizontalAlignment, spriteContainer, maxMessageSize, CreoleMode.FULL,
|
||||||
fontForStereotype, htmlColorForStereotype, marginX1, marginX2);
|
fontForStereotype, htmlColorForStereotype, marginX1, marginX2);
|
||||||
|
@ -70,7 +70,7 @@ public enum ComponentType implements Styleable {
|
|||||||
return this == ARROW;
|
return this == ARROW;
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
if (this == PARTICIPANT_HEAD || this == PARTICIPANT_TAIL) {
|
if (this == PARTICIPANT_HEAD || this == PARTICIPANT_TAIL) {
|
||||||
return StyleSignature.of(SName.root, SName.element,
|
return StyleSignature.of(SName.root, SName.element,
|
||||||
SName.sequenceDiagram, SName.participant);
|
SName.sequenceDiagram, SName.participant);
|
||||||
|
@ -35,9 +35,11 @@
|
|||||||
*/
|
*/
|
||||||
package net.sourceforge.plantuml.skin.rose;
|
package net.sourceforge.plantuml.skin.rose;
|
||||||
|
|
||||||
|
import net.sourceforge.plantuml.ISkinSimple;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
import net.sourceforge.plantuml.skin.AbstractComponent;
|
import net.sourceforge.plantuml.skin.AbstractComponent;
|
||||||
import net.sourceforge.plantuml.skin.Area;
|
import net.sourceforge.plantuml.skin.Area;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
import net.sourceforge.plantuml.style.Style;
|
import net.sourceforge.plantuml.style.Style;
|
||||||
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
import net.sourceforge.plantuml.ugraphic.UGraphic;
|
||||||
import net.sourceforge.plantuml.ugraphic.ULine;
|
import net.sourceforge.plantuml.ugraphic.ULine;
|
||||||
@ -49,8 +51,12 @@ public class ComponentRoseDestroy extends AbstractComponent {
|
|||||||
|
|
||||||
private final HColor foregroundColor;
|
private final HColor foregroundColor;
|
||||||
|
|
||||||
public ComponentRoseDestroy(Style style, HColor foregroundColor) {
|
public ComponentRoseDestroy(Style style, HColor foregroundColor, ISkinSimple spriteContainer) {
|
||||||
super(style);
|
super(style);
|
||||||
|
if (style != null)
|
||||||
|
this.foregroundColor = style.value(PName.LineColor).asColor(spriteContainer.getThemeStyle(),
|
||||||
|
spriteContainer.getIHtmlColorSet());
|
||||||
|
else
|
||||||
this.foregroundColor = foregroundColor;
|
this.foregroundColor = foregroundColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ public class ComponentRoseGroupingSpace implements Component {
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition() {
|
public StyleSignature getStyleSignature() {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,9 +99,9 @@ public class ComponentRoseReference extends AbstractTextualComponent {
|
|||||||
|
|
||||||
URectangle rect = new URectangle(dimensionToUse.getWidth() - xMargin * 2 - symbolContextBody.getDeltaShadow(),
|
URectangle rect = new URectangle(dimensionToUse.getWidth() - xMargin * 2 - symbolContextBody.getDeltaShadow(),
|
||||||
dimensionToUse.getHeight() - heightFooter);
|
dimensionToUse.getHeight() - heightFooter);
|
||||||
if (this.roundCorner != 0) {
|
if (this.roundCorner != 0)
|
||||||
rect = rect.rounded(this.roundCorner);
|
rect = rect.rounded(this.roundCorner);
|
||||||
}
|
|
||||||
rect.setDeltaShadow(symbolContextBody.getDeltaShadow());
|
rect.setDeltaShadow(symbolContextBody.getDeltaShadow());
|
||||||
ug = symbolContextBody.apply(ug);
|
ug = symbolContextBody.apply(ug);
|
||||||
ug.apply(UTranslate.dx(xMargin)).draw(rect);
|
ug.apply(UTranslate.dx(xMargin)).draw(rect);
|
||||||
|
@ -326,7 +326,8 @@ public class Rose {
|
|||||||
getUFont2(param, FontParam.SEQUENCE_DELAY), stringsToDisplay, param);
|
getUFont2(param, FontParam.SEQUENCE_DELAY), stringsToDisplay, param);
|
||||||
}
|
}
|
||||||
if (type == ComponentType.DESTROY) {
|
if (type == ComponentType.DESTROY) {
|
||||||
return new ComponentRoseDestroy(null, getHtmlColor(param, stereotype, ColorParam.sequenceLifeLineBorder));
|
return new ComponentRoseDestroy(styles == null ? null : styles[0],
|
||||||
|
getHtmlColor(param, stereotype, ColorParam.sequenceLifeLineBorder), param);
|
||||||
}
|
}
|
||||||
if (type == ComponentType.NEWPAGE) {
|
if (type == ComponentType.NEWPAGE) {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
|
69
src/net/sourceforge/plantuml/style/CssVariables.java
Normal file
69
src/net/sourceforge/plantuml/style/CssVariables.java
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* (C) Copyright 2009-2020, Arnaud Roques
|
||||||
|
*
|
||||||
|
* Project Info: http://plantuml.com
|
||||||
|
*
|
||||||
|
* If you like this project or if you find it useful, you can support us at:
|
||||||
|
*
|
||||||
|
* http://plantuml.com/patreon (only 1$ per month!)
|
||||||
|
* http://plantuml.com/paypal
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Original Author: Arnaud Roques
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package net.sourceforge.plantuml.style;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
public class CssVariables {
|
||||||
|
|
||||||
|
private final Map<String, String> variables = new HashMap<>();
|
||||||
|
|
||||||
|
private final Pattern learnPattern = Pattern.compile("^--([_\\w][-_\\w]+)[ :]+(.*?);?");
|
||||||
|
private final Pattern retrieve = Pattern.compile("var\\(-*([_\\w][-_\\w]+)\\)");
|
||||||
|
|
||||||
|
public void learn(String s) {
|
||||||
|
final Matcher m = learnPattern.matcher(s);
|
||||||
|
if (m.matches())
|
||||||
|
variables.put(m.group(1), m.group(2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public String value(String v) {
|
||||||
|
if (v.startsWith("var(")) {
|
||||||
|
final Matcher m = retrieve.matcher(v);
|
||||||
|
if (m.matches()) {
|
||||||
|
final String varname = m.group(1);
|
||||||
|
final String result = variables.get(varname);
|
||||||
|
if (result != null)
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -118,6 +118,7 @@ public class StyleLoader {
|
|||||||
public static Collection<Style> getDeclaredStyles(BlocLines lines, AutomaticCounter counter) {
|
public static Collection<Style> getDeclaredStyles(BlocLines lines, AutomaticCounter counter) {
|
||||||
lines = lines.eventuallyMoveAllEmptyBracket();
|
lines = lines.eventuallyMoveAllEmptyBracket();
|
||||||
final List<Style> result = new ArrayList<>();
|
final List<Style> result = new ArrayList<>();
|
||||||
|
final CssVariables variables = new CssVariables();
|
||||||
StyleScheme scheme = StyleScheme.REGULAR;
|
StyleScheme scheme = StyleScheme.REGULAR;
|
||||||
|
|
||||||
Context context = new Context();
|
Context context = new Context();
|
||||||
@ -125,6 +126,7 @@ public class StyleLoader {
|
|||||||
boolean inComment = false;
|
boolean inComment = false;
|
||||||
for (StringLocated s : lines) {
|
for (StringLocated s : lines) {
|
||||||
String trimmed = s.getTrimmed().getString();
|
String trimmed = s.getTrimmed().getString();
|
||||||
|
|
||||||
if (trimmed.startsWith("/*") || trimmed.endsWith("*/"))
|
if (trimmed.startsWith("/*") || trimmed.endsWith("*/"))
|
||||||
continue;
|
continue;
|
||||||
if (trimmed.startsWith("/'") || trimmed.endsWith("'/"))
|
if (trimmed.startsWith("/'") || trimmed.endsWith("'/"))
|
||||||
@ -146,6 +148,11 @@ public class StyleLoader {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (trimmed.startsWith("--")) {
|
||||||
|
variables.learn(trimmed);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
final int x = trimmed.lastIndexOf("//");
|
final int x = trimmed.lastIndexOf("//");
|
||||||
if (x != -1)
|
if (x != -1)
|
||||||
trimmed = trimmed.substring(0, x).trim();
|
trimmed = trimmed.substring(0, x).trim();
|
||||||
@ -164,7 +171,7 @@ public class StyleLoader {
|
|||||||
final Matcher2 mPropertyAndValue = propertyAndValue.matcher(trimmed);
|
final Matcher2 mPropertyAndValue = propertyAndValue.matcher(trimmed);
|
||||||
if (mPropertyAndValue.find()) {
|
if (mPropertyAndValue.find()) {
|
||||||
final PName key = PName.getFromName(mPropertyAndValue.group(1), scheme);
|
final PName key = PName.getFromName(mPropertyAndValue.group(1), scheme);
|
||||||
final String value = mPropertyAndValue.group(2);
|
final String value = variables.value(mPropertyAndValue.group(2));
|
||||||
if (key != null && maps.size() > 0)
|
if (key != null && maps.size() > 0)
|
||||||
maps.get(maps.size() - 1).put(key, //
|
maps.get(maps.size() - 1).put(key, //
|
||||||
scheme == StyleScheme.REGULAR ? //
|
scheme == StyleScheme.REGULAR ? //
|
||||||
|
@ -225,4 +225,18 @@ public class StyleSignature {
|
|||||||
return withDot;
|
return withDot;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Frequent use
|
||||||
|
|
||||||
|
public static StyleSignature activity() {
|
||||||
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StyleSignature activityDiamond() {
|
||||||
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity, SName.diamond);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static StyleSignature activityArrow() {
|
||||||
|
return StyleSignature.of(SName.root, SName.element, SName.activityDiagram, SName.activity, SName.arrow);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -37,6 +37,6 @@ package net.sourceforge.plantuml.style;
|
|||||||
|
|
||||||
public interface Styleable {
|
public interface Styleable {
|
||||||
|
|
||||||
public StyleSignature getDefaultStyleDefinition();
|
public StyleSignature getStyleSignature();
|
||||||
|
|
||||||
}
|
}
|
@ -304,7 +304,7 @@ public class Cluster implements Moveable {
|
|||||||
.with(stereotype);
|
.with(stereotype);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void drawU(UGraphic ug, UStroke strokeForState, UmlDiagramType umlDiagramType, ISkinParam skinParam2) {
|
public void drawU(UGraphic ug, UmlDiagramType umlDiagramType, ISkinParam skinParam2) {
|
||||||
if (group.isHidden())
|
if (group.isHidden())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -362,6 +362,8 @@ public class Cluster implements Moveable {
|
|||||||
final boolean isState = umlDiagramType == UmlDiagramType.STATE;
|
final boolean isState = umlDiagramType == UmlDiagramType.STATE;
|
||||||
|
|
||||||
if (isState && group.getUSymbol() == null) {
|
if (isState && group.getUSymbol() == null) {
|
||||||
|
UStroke strokeForState = getDefaultStyleDefinition(SName.stateDiagram, null)
|
||||||
|
.getMergedStyle(skinParam.getCurrentStyleBuilder()).getStroke();
|
||||||
if (group.getColors().getSpecificLineStroke() != null)
|
if (group.getColors().getSpecificLineStroke() != null)
|
||||||
strokeForState = group.getColors().getSpecificLineStroke();
|
strokeForState = group.getColors().getSpecificLineStroke();
|
||||||
|
|
||||||
|
@ -41,10 +41,15 @@ import java.util.List;
|
|||||||
import net.sourceforge.plantuml.ColorParam;
|
import net.sourceforge.plantuml.ColorParam;
|
||||||
import net.sourceforge.plantuml.Dimension2DDouble;
|
import net.sourceforge.plantuml.Dimension2DDouble;
|
||||||
import net.sourceforge.plantuml.ISkinParam;
|
import net.sourceforge.plantuml.ISkinParam;
|
||||||
|
import net.sourceforge.plantuml.UseStyle;
|
||||||
import net.sourceforge.plantuml.cucadiagram.Stereotype;
|
import net.sourceforge.plantuml.cucadiagram.Stereotype;
|
||||||
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
import net.sourceforge.plantuml.graphic.AbstractTextBlock;
|
||||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||||
import net.sourceforge.plantuml.skin.rose.Rose;
|
import net.sourceforge.plantuml.skin.rose.Rose;
|
||||||
|
import net.sourceforge.plantuml.style.PName;
|
||||||
|
import net.sourceforge.plantuml.style.SName;
|
||||||
|
import net.sourceforge.plantuml.style.Style;
|
||||||
|
import net.sourceforge.plantuml.style.StyleSignature;
|
||||||
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.UStroke;
|
import net.sourceforge.plantuml.ugraphic.UStroke;
|
||||||
@ -62,27 +67,27 @@ public final class CucaDiagramFileMakerSvek2InternalImage extends AbstractTextBl
|
|||||||
VERTICAL, HORIZONTAL;
|
VERTICAL, HORIZONTAL;
|
||||||
|
|
||||||
static Separator fromChar(char sep) {
|
static Separator fromChar(char sep) {
|
||||||
if (sep == '|') {
|
if (sep == '|')
|
||||||
return VERTICAL;
|
return VERTICAL;
|
||||||
}
|
|
||||||
if (sep == '-') {
|
if (sep == '-')
|
||||||
return HORIZONTAL;
|
return HORIZONTAL;
|
||||||
}
|
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
}
|
||||||
|
|
||||||
UTranslate move(Dimension2D dim) {
|
UTranslate move(Dimension2D dim) {
|
||||||
if (this == VERTICAL) {
|
if (this == VERTICAL)
|
||||||
return UTranslate.dx(dim.getWidth());
|
return UTranslate.dx(dim.getWidth());
|
||||||
}
|
|
||||||
return UTranslate.dy(dim.getHeight());
|
return UTranslate.dy(dim.getHeight());
|
||||||
}
|
}
|
||||||
|
|
||||||
Dimension2D add(Dimension2D orig, Dimension2D other) {
|
Dimension2D add(Dimension2D orig, Dimension2D other) {
|
||||||
if (this == VERTICAL) {
|
if (this == VERTICAL)
|
||||||
return new Dimension2DDouble(orig.getWidth() + other.getWidth(),
|
return new Dimension2DDouble(orig.getWidth() + other.getWidth(),
|
||||||
Math.max(orig.getHeight(), other.getHeight()));
|
Math.max(orig.getHeight(), other.getHeight()));
|
||||||
}
|
|
||||||
return new Dimension2DDouble(Math.max(orig.getWidth(), other.getWidth()),
|
return new Dimension2DDouble(Math.max(orig.getWidth(), other.getWidth()),
|
||||||
orig.getHeight() + other.getHeight());
|
orig.getHeight() + other.getHeight());
|
||||||
}
|
}
|
||||||
@ -91,19 +96,14 @@ public final class CucaDiagramFileMakerSvek2InternalImage extends AbstractTextBl
|
|||||||
final double THICKNESS_BORDER = 1.5;
|
final double THICKNESS_BORDER = 1.5;
|
||||||
final int DASH = 8;
|
final int DASH = 8;
|
||||||
ug = ug.apply(new UStroke(DASH, 10, THICKNESS_BORDER));
|
ug = ug.apply(new UStroke(DASH, 10, THICKNESS_BORDER));
|
||||||
if (this == VERTICAL) {
|
if (this == VERTICAL)
|
||||||
ug.draw(ULine.vline(dimTotal.getHeight() + DASH));
|
ug.draw(ULine.vline(dimTotal.getHeight() + DASH));
|
||||||
} else {
|
else
|
||||||
ug.draw(ULine.hline(dimTotal.getWidth() + DASH));
|
ug.draw(ULine.hline(dimTotal.getWidth() + DASH));
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private HColor getColor(ColorParam colorParam, Stereotype stereotype) {
|
|
||||||
return new Rose().getHtmlColor(skinParam, stereotype, colorParam);
|
|
||||||
}
|
|
||||||
|
|
||||||
public CucaDiagramFileMakerSvek2InternalImage(List<IEntityImage> inners, char concurrentSeparator,
|
public CucaDiagramFileMakerSvek2InternalImage(List<IEntityImage> inners, char concurrentSeparator,
|
||||||
ISkinParam skinParam, Stereotype stereotype) {
|
ISkinParam skinParam, Stereotype stereotype) {
|
||||||
this.separator = Separator.fromChar(concurrentSeparator);
|
this.separator = Separator.fromChar(concurrentSeparator);
|
||||||
@ -112,8 +112,21 @@ public final class CucaDiagramFileMakerSvek2InternalImage extends AbstractTextBl
|
|||||||
this.inners = inners;
|
this.inners = inners;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Style getStyle() {
|
||||||
|
return getStyleSignature().getMergedStyle(skinParam.getCurrentStyleBuilder());
|
||||||
|
}
|
||||||
|
|
||||||
|
private StyleSignature getStyleSignature() {
|
||||||
|
return StyleSignature.of(SName.root, SName.element, SName.stateDiagram, SName.state);
|
||||||
|
}
|
||||||
|
|
||||||
public void drawU(UGraphic ug) {
|
public void drawU(UGraphic ug) {
|
||||||
final HColor dotColor = getColor(ColorParam.stateBorder, stereotype);
|
final HColor borderColor;
|
||||||
|
if (UseStyle.useBetaStyle())
|
||||||
|
borderColor = getStyle().value(PName.LineColor).asColor(skinParam.getThemeStyle(),
|
||||||
|
skinParam.getIHtmlColorSet());
|
||||||
|
else
|
||||||
|
borderColor = new Rose().getHtmlColor(skinParam, stereotype, ColorParam.stateBorder);
|
||||||
final StringBounder stringBounder = ug.getStringBounder();
|
final StringBounder stringBounder = ug.getStringBounder();
|
||||||
final Dimension2D dimTotal = calculateDimension(stringBounder);
|
final Dimension2D dimTotal = calculateDimension(stringBounder);
|
||||||
|
|
||||||
@ -122,9 +135,9 @@ public final class CucaDiagramFileMakerSvek2InternalImage extends AbstractTextBl
|
|||||||
inner.drawU(ug);
|
inner.drawU(ug);
|
||||||
final Dimension2D dim = inner.calculateDimension(stringBounder);
|
final Dimension2D dim = inner.calculateDimension(stringBounder);
|
||||||
ug = ug.apply(separator.move(dim));
|
ug = ug.apply(separator.move(dim));
|
||||||
if (i < inners.size() - 1) {
|
if (i < inners.size() - 1)
|
||||||
separator.drawSeparator(ug.apply(dotColor), dimTotal);
|
separator.drawSeparator(ug.apply(borderColor), dimTotal);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -185,7 +185,7 @@ public final class GeneralImageBuilder {
|
|||||||
}
|
}
|
||||||
if (leaf.getStereotype() != null
|
if (leaf.getStereotype() != null
|
||||||
&& "<<sdlreceive>>".equals(leaf.getStereotype().getLabel(Guillemet.DOUBLE_COMPARATOR))) {
|
&& "<<sdlreceive>>".equals(leaf.getStereotype().getLabel(Guillemet.DOUBLE_COMPARATOR))) {
|
||||||
return new EntityImageState2(leaf, skinParam);
|
return new EntityImageState2(leaf, skinParam, umlDiagramType.getStyleName());
|
||||||
}
|
}
|
||||||
return new EntityImageState(leaf, skinParam);
|
return new EntityImageState(leaf, skinParam);
|
||||||
|
|
||||||
@ -262,13 +262,13 @@ public final class GeneralImageBuilder {
|
|||||||
return new EntityImageEmptyPackage(leaf, skinParam, portionShower, umlDiagramType.getStyleName());
|
return new EntityImageEmptyPackage(leaf, skinParam, portionShower, umlDiagramType.getStyleName());
|
||||||
}
|
}
|
||||||
if (leaf.getLeafType() == LeafType.ASSOCIATION) {
|
if (leaf.getLeafType() == LeafType.ASSOCIATION) {
|
||||||
return new EntityImageAssociation(leaf, skinParam);
|
return new EntityImageAssociation(leaf, skinParam, umlDiagramType.getStyleName());
|
||||||
}
|
}
|
||||||
if (leaf.getLeafType() == LeafType.PSEUDO_STATE) {
|
if (leaf.getLeafType() == LeafType.PSEUDO_STATE) {
|
||||||
return new EntityImagePseudoState(leaf, skinParam);
|
return new EntityImagePseudoState(leaf, skinParam, umlDiagramType.getStyleName());
|
||||||
}
|
}
|
||||||
if (leaf.getLeafType() == LeafType.DEEP_HISTORY) {
|
if (leaf.getLeafType() == LeafType.DEEP_HISTORY) {
|
||||||
return new EntityImageDeepHistory(leaf, skinParam);
|
return new EntityImageDeepHistory(leaf, skinParam, umlDiagramType.getStyleName());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (leaf.getLeafType() == LeafType.TIPS) {
|
if (leaf.getLeafType() == LeafType.TIPS) {
|
||||||
|
@ -92,9 +92,9 @@ public final class GroupPngMakerState {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Collection<IGroup> getChildrenGroups(IGroup parent) {
|
public Collection<IGroup> getChildrenGroups(IGroup parent) {
|
||||||
if (EntityUtils.groupRoot(parent)) {
|
if (EntityUtils.groupRoot(parent))
|
||||||
return diagram.getChildrenGroups(group);
|
return diagram.getChildrenGroups(group);
|
||||||
}
|
|
||||||
return diagram.getChildrenGroups(parent);
|
return diagram.getChildrenGroups(parent);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,18 +108,17 @@ public final class GroupPngMakerState {
|
|||||||
this.diagram = diagram;
|
this.diagram = diagram;
|
||||||
this.stringBounder = stringBounder;
|
this.stringBounder = stringBounder;
|
||||||
this.group = group;
|
this.group = group;
|
||||||
if (group.isGroup() == false) {
|
if (group.isGroup() == false)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<Link> getPureInnerLinks() {
|
private List<Link> getPureInnerLinks() {
|
||||||
final List<Link> result = new ArrayList<>();
|
final List<Link> result = new ArrayList<>();
|
||||||
for (Link link : diagram.getLinks()) {
|
for (Link link : diagram.getLinks())
|
||||||
if (EntityUtils.isPureInnerLink12(group, link)) {
|
if (EntityUtils.isPureInnerLink12(group, link))
|
||||||
result.add(link);
|
result.add(link);
|
||||||
}
|
|
||||||
}
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,9 +154,9 @@ public final class GroupPngMakerState {
|
|||||||
|
|
||||||
final TextBlock title = display.create(fontConfiguration, HorizontalAlignment.CENTER, diagram.getSkinParam());
|
final TextBlock title = display.create(fontConfiguration, HorizontalAlignment.CENTER, diagram.getSkinParam());
|
||||||
|
|
||||||
if (group.size() == 0 && group.getChildren().size() == 0) {
|
if (group.size() == 0 && group.getChildren().size() == 0)
|
||||||
return new EntityImageState(group, diagram.getSkinParam());
|
return new EntityImageState(group, diagram.getSkinParam());
|
||||||
}
|
|
||||||
final List<Link> links = getPureInnerLinks();
|
final List<Link> links = getPureInnerLinks();
|
||||||
|
|
||||||
final DotData dotData = new DotData(group, links, group.getLeafsDirect(), diagram.getUmlDiagramType(),
|
final DotData dotData = new DotData(group, links, group.getLeafsDirect(), diagram.getUmlDiagramType(),
|
||||||
@ -168,37 +167,39 @@ public final class GroupPngMakerState {
|
|||||||
final GeneralImageBuilder svek2 = new GeneralImageBuilder(false, dotData, diagram.getEntityFactory(),
|
final GeneralImageBuilder svek2 = new GeneralImageBuilder(false, dotData, diagram.getEntityFactory(),
|
||||||
diagram.getSource(), diagram.getPragma(), stringBounder, SName.stateDiagram);
|
diagram.getSource(), diagram.getPragma(), stringBounder, SName.stateDiagram);
|
||||||
|
|
||||||
if (group.getGroupType() == GroupType.CONCURRENT_STATE) {
|
if (group.getGroupType() == GroupType.CONCURRENT_STATE)
|
||||||
// return new InnerStateConcurrent(svek2.createFile());
|
|
||||||
return svek2.buildImage(null, new String[0]);
|
return svek2.buildImage(null, new String[0]);
|
||||||
}
|
|
||||||
|
|
||||||
if (group.getGroupType() != GroupType.STATE) {
|
if (group.getGroupType() != GroupType.STATE)
|
||||||
throw new UnsupportedOperationException(group.getGroupType().toString());
|
throw new UnsupportedOperationException(group.getGroupType().toString());
|
||||||
}
|
|
||||||
|
|
||||||
HColor borderColor = group.getColors().getColor(ColorType.LINE);
|
HColor borderColor = group.getColors().getColor(ColorType.LINE);
|
||||||
if (borderColor == null) {
|
if (borderColor == null)
|
||||||
if (UseStyle.useBetaStyle())
|
if (UseStyle.useBetaStyle())
|
||||||
borderColor = getStyleState().value(PName.LineColor).asColor(skinParam.getThemeStyle(),
|
borderColor = getStyleState().value(PName.LineColor).asColor(skinParam.getThemeStyle(),
|
||||||
skinParam.getIHtmlColorSet());
|
skinParam.getIHtmlColorSet());
|
||||||
else
|
else
|
||||||
borderColor = getColor(ColorParam.stateBorder, group.getStereotype());
|
borderColor = getColor(ColorParam.stateBorder, group.getStereotype());
|
||||||
}
|
|
||||||
final Stereotype stereo = group.getStereotype();
|
final Stereotype stereo = group.getStereotype();
|
||||||
final HColor tmp = group.getColors().getColor(ColorType.BACK);
|
final HColor tmp = group.getColors().getColor(ColorType.BACK);
|
||||||
final HColor backColor;
|
final HColor backColor;
|
||||||
if (tmp == null)
|
if (tmp == null)
|
||||||
if (UseStyle.useBetaStyle())
|
if (UseStyle.useBetaStyle())
|
||||||
backColor =
|
backColor = getStyleState().value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
||||||
|
|
||||||
getStyleState().value(PName.BackGroundColor).asColor(skinParam.getThemeStyle(),
|
|
||||||
skinParam.getIHtmlColorSet());
|
skinParam.getIHtmlColorSet());
|
||||||
else
|
else
|
||||||
backColor = getColor(ColorParam.stateBackground, stereo);
|
backColor = getColor(ColorParam.stateBackground, stereo);
|
||||||
else
|
else
|
||||||
backColor = tmp;
|
backColor = tmp;
|
||||||
|
|
||||||
|
UStroke stroke = group.getColors().getSpecificLineStroke();
|
||||||
|
if (stroke == null)
|
||||||
|
if (UseStyle.useBetaStyle())
|
||||||
|
stroke = getStyleState().getStroke();
|
||||||
|
else
|
||||||
|
stroke = new UStroke(1.5);
|
||||||
|
|
||||||
final TextBlock attribute = GeneralImageBuilder.stateHeader((IEntity) group, null, skinParam);
|
final TextBlock attribute = GeneralImageBuilder.stateHeader((IEntity) group, null, skinParam);
|
||||||
|
|
||||||
final Stereotype stereotype = group.getStereotype();
|
final Stereotype stereotype = group.getStereotype();
|
||||||
@ -207,10 +208,7 @@ public final class GroupPngMakerState {
|
|||||||
final boolean containsOnlyConcurrentStates = containsOnlyConcurrentStates(dotData);
|
final boolean containsOnlyConcurrentStates = containsOnlyConcurrentStates(dotData);
|
||||||
final IEntityImage image = containsOnlyConcurrentStates ? buildImageForConcurrentState(dotData)
|
final IEntityImage image = containsOnlyConcurrentStates ? buildImageForConcurrentState(dotData)
|
||||||
: svek2.buildImage(null, new String[0]);
|
: svek2.buildImage(null, new String[0]);
|
||||||
UStroke stroke = group.getColors().getSpecificLineStroke();
|
|
||||||
if (stroke == null) {
|
|
||||||
stroke = new UStroke(1.5);
|
|
||||||
}
|
|
||||||
return new InnerStateAutonom(image, title, attribute, borderColor, backColor, group.getUrl99(), withSymbol,
|
return new InnerStateAutonom(image, title, attribute, borderColor, backColor, group.getUrl99(), withSymbol,
|
||||||
stroke, rounded, shadowing);
|
stroke, rounded, shadowing);
|
||||||
|
|
||||||
@ -218,9 +216,9 @@ public final class GroupPngMakerState {
|
|||||||
|
|
||||||
private IEntityImage buildImageForConcurrentState(DotData dotData) {
|
private IEntityImage buildImageForConcurrentState(DotData dotData) {
|
||||||
final List<IEntityImage> inners = new ArrayList<>();
|
final List<IEntityImage> inners = new ArrayList<>();
|
||||||
for (ILeaf inner : dotData.getLeafs()) {
|
for (ILeaf inner : dotData.getLeafs())
|
||||||
inners.add(inner.getSvekImage());
|
inners.add(inner.getSvekImage());
|
||||||
}
|
|
||||||
return new CucaDiagramFileMakerSvek2InternalImage(inners, dotData.getTopParent().getConcurrentSeparator(),
|
return new CucaDiagramFileMakerSvek2InternalImage(inners, dotData.getTopParent().getConcurrentSeparator(),
|
||||||
dotData.getSkinParam(), group.getStereotype());
|
dotData.getSkinParam(), group.getStereotype());
|
||||||
|
|
||||||
@ -228,12 +226,12 @@ public final class GroupPngMakerState {
|
|||||||
|
|
||||||
private boolean containsOnlyConcurrentStates(DotData dotData) {
|
private boolean containsOnlyConcurrentStates(DotData dotData) {
|
||||||
for (ILeaf leaf : dotData.getLeafs()) {
|
for (ILeaf leaf : dotData.getLeafs()) {
|
||||||
if (leaf instanceof IGroup == false) {
|
if (leaf instanceof IGroup == false)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
if (((IGroup) leaf).getLeafType() != LeafType.STATE_CONCURRENT) {
|
if (((IGroup) leaf).getLeafType() != LeafType.STATE_CONCURRENT)
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -85,9 +85,8 @@ public final class InnerStateAutonom extends AbstractTextBlock implements IEntit
|
|||||||
final RoundedContainer r = new RoundedContainer(total, titreHeight, attr.getHeight() + marginForFields,
|
final RoundedContainer r = new RoundedContainer(total, titreHeight, attr.getHeight() + marginForFields,
|
||||||
borderColor, backColor, im.getBackcolor(), stroke, rounded, shadowing);
|
borderColor, backColor, im.getBackcolor(), stroke, rounded, shadowing);
|
||||||
|
|
||||||
if (url != null) {
|
if (url != null)
|
||||||
ug.startUrl(url);
|
ug.startUrl(url);
|
||||||
}
|
|
||||||
|
|
||||||
r.drawU(ug);
|
r.drawU(ug);
|
||||||
title.drawU(ug.apply(new UTranslate((total.getWidth() - text.getWidth()) / 2, IEntityImage.MARGIN)));
|
title.drawU(ug.apply(new UTranslate((total.getWidth() - text.getWidth()) / 2, IEntityImage.MARGIN)));
|
||||||
@ -97,14 +96,12 @@ public final class InnerStateAutonom extends AbstractTextBlock implements IEntit
|
|||||||
final double spaceYforURL = getSpaceYforURL(ug.getStringBounder());
|
final double spaceYforURL = getSpaceYforURL(ug.getStringBounder());
|
||||||
im.drawU(ug.apply(new UTranslate(IEntityImage.MARGIN, spaceYforURL)));
|
im.drawU(ug.apply(new UTranslate(IEntityImage.MARGIN, spaceYforURL)));
|
||||||
|
|
||||||
if (withSymbol) {
|
if (withSymbol)
|
||||||
EntityImageState.drawSymbol(ug.apply(borderColor), total.getWidth(), total.getHeight());
|
EntityImageState.drawSymbol(ug.apply(borderColor), total.getWidth(), total.getHeight());
|
||||||
|
|
||||||
}
|
if (url != null)
|
||||||
|
|
||||||
if (url != null) {
|
|
||||||
ug.closeUrl();
|
ug.closeUrl();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private double getSpaceYforURL(StringBounder stringBounder) {
|
private double getSpaceYforURL(StringBounder stringBounder) {
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user