From 2e5b60235d4efd41144f44ddd81094310c1b6de7 Mon Sep 17 00:00:00 2001 From: Phillipus Date: Sat, 14 Dec 2024 16:13:27 +0000 Subject: [PATCH] Add "None" line style - Note - Canvas Block and Canvas Image have a "None" border colour and Note has a "None" border type so in these cases the "None" option is doubled up --- .../canvas/figures/CanvasBlockFigure.java | 12 +++-- com.archimatetool.editor/img/line-none.png | Bin 0 -> 1931 bytes .../DiagramModelObjectLineStyleCommand.java | 2 +- .../figures/AbstractFigureDelegate.java | 4 ++ .../figures/EllipseFigureDelegate.java | 19 +++++--- .../figures/RectangleFigureDelegate.java | 19 +++++--- .../RoundedRectangleFigureDelegate.java | 19 +++++--- .../figures/diagram/DiagramImageFigure.java | 12 +++-- .../diagram/figures/diagram/GroupFigure.java | 43 ++++++++++-------- .../diagram/figures/diagram/NoteFigure.java | 5 +- .../elements/AbstractMotivationFigure.java | 18 +++++--- .../figures/elements/GroupingFigure.java | 26 +++++++---- .../diagram/sketch/figures/StickyFigure.java | 18 +++++--- .../propertysections/LineStyleComposite.java | 4 ++ .../editor/propertysections/Messages.java | 2 + .../propertysections/messages.properties | 1 + .../archimatetool/editor/ui/IArchiImages.java | 1 + .../help/Text/properties_canvas_block.html | 2 +- .../help/Text/properties_canvas_image.html | 2 +- .../Text/properties_element_appearance.html | 2 +- .../help/Text/properties_group.html | 2 +- .../help/Text/properties_note.html | 2 +- .../help/Text/properties_viewref.html | 2 +- .../model/IDiagramModelObject.java | 1 + 24 files changed, 135 insertions(+), 83 deletions(-) create mode 100644 com.archimatetool.editor/img/line-none.png diff --git a/com.archimatetool.canvas/src/com/archimatetool/canvas/figures/CanvasBlockFigure.java b/com.archimatetool.canvas/src/com/archimatetool/canvas/figures/CanvasBlockFigure.java index b1ce6bb87..c2af6c0a4 100644 --- a/com.archimatetool.canvas/src/com/archimatetool/canvas/figures/CanvasBlockFigure.java +++ b/com.archimatetool.canvas/src/com/archimatetool/canvas/figures/CanvasBlockFigure.java @@ -26,6 +26,7 @@ import com.archimatetool.editor.diagram.figures.TextPositionDelegate; import com.archimatetool.editor.ui.ColorFactory; import com.archimatetool.editor.utils.StringUtils; +import com.archimatetool.model.IDiagramModelObject; /** @@ -159,10 +160,11 @@ private void drawFigure(Graphics graphics, Color background) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getBorderColor() != null && getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } graphics.setBackgroundColor(background); graphics.fillRectangle(bounds); @@ -171,7 +173,7 @@ private void drawFigure(Graphics graphics, Color background) { drawIconImage(graphics, bounds); // Border - if(getBorderColor() != null) { + if(getBorderColor() != null && getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { graphics.setAlpha(getLineAlpha()); graphics.setForegroundColor(getBorderColor()); graphics.drawRectangle(bounds.x, bounds.y, bounds.width, bounds.height); diff --git a/com.archimatetool.editor/img/line-none.png b/com.archimatetool.editor/img/line-none.png new file mode 100644 index 0000000000000000000000000000000000000000..b531aec81a6f8bdf803ba04ce8bc8fb6e8ab22ca GIT binary patch literal 1931 zcmaJ?Yfuwc6kaMtK~SrRFRIHTRZ+5e@LUNB1Oy?JLa30LDoe5nE6MJf-IxW%Q42-E z;-FCLl(wMO3PM#{9T5d8S^)>eT5+tlfEKk{r=wVl1EakgkcUuzY_j)$-}%nD=iGC4 zdu+@KCx_V%5Cl0zMkwOIKMbD96YRim_U4uu5M+CRR3&nW%4keO8%4O5P9a3RkpVaa z1uo+mT$4s{a0;O(DLL|YO&tQ0S~;@HM=4e^p+qVfkzpd@Gh$Slj5JMv7FibL5XfUd zz({a7%o`09i}7;As*8blVH-tYD}_swBZ@2es91_hrCxyH#immn&U;a;yCBi8p&(d|iDWpEreHx6 zPod4696(_5d|m@qky>G2CLP)rgbZe(5(yLuTn~d1hcG$fCqX4cR!L(*LaMP? zk|zv_3ereWEKnWvHUuUO0|!F1f}ym5HpPQ$O@Pp?z6R@nSurK81(57DC^9rO)o^N;B7*gxta2n+rz1gC(qYgrq@E&7utX#gi~L6#SyBlgIOd_yfw)ki z%U%T*h>i+9&`KEAmcXum541a&8|dKR0E@xVLr`Gen809(xcbd42(sBsf>Mks0R$~9 zFc(~m3JG@3S$1699Cs)z&t+Pk)oKZFo}LQxb*%5-g|aw>6vzoe@~e|2+NZ4-WcWzkK&ZhxWZ0Rn60P%MxCAC*@rTNjBTp$jrqR8jr(W*?OVCpQlIb)W5xxbywfOKN{ETyRpdW&YebaZT^qXZ1-fVH$9#b{<{Lb z?tR(D->nSkYZsTUJjw#KYi_sC_FY>^PJS6KsJ$zV3q%;Erq2~p&vNs)Gg2` znWmeLYoBBnrFS^*S@L4q3!Ag`$+Af|lJT&k>hmY5Q_TLv^AB)YHM~un*Xj14JEMKh zrsu`oz5e4T_35KMjx2TWbvtcSY?D@htQ)UYZQ0uB!Zxv3%zg8Hu&$)QAU%g#xrEI}=%k9GOPxv(j_QE$bGAu^% JT}blQ{{WPuzh?jd literal 0 HcmV?d00001 diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/commands/DiagramModelObjectLineStyleCommand.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/commands/DiagramModelObjectLineStyleCommand.java index c014869a1..39662bba9 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/commands/DiagramModelObjectLineStyleCommand.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/commands/DiagramModelObjectLineStyleCommand.java @@ -27,7 +27,7 @@ public DiagramModelObjectLineStyleCommand(IDiagramModelObject dmo, int style) { @Override public boolean canExecute() { - return super.canExecute() && style >= IDiagramModelObject.LINE_STYLE_SOLID && style <= IDiagramModelObject.LINE_STYLE_DOTTED; + return super.canExecute() && style >= IDiagramModelObject.LINE_STYLE_SOLID && style <= IDiagramModelObject.LINE_STYLE_NONE; } /** diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/AbstractFigureDelegate.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/AbstractFigureDelegate.java index 96dc34cf4..ccf293c4e 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/AbstractFigureDelegate.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/AbstractFigureDelegate.java @@ -129,6 +129,10 @@ protected void setLineWidth(Graphics graphics, int lineWidth, Rectangle bounds) getOwner().setLineWidth(graphics, lineWidth, bounds); } + protected int getLineStyle() { + return getOwner().getLineStyle(); + } + /** * Set line style * @param graphics diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/EllipseFigureDelegate.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/EllipseFigureDelegate.java index 9c91125ea..bee585d3e 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/EllipseFigureDelegate.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/EllipseFigureDelegate.java @@ -9,6 +9,8 @@ import org.eclipse.draw2d.geometry.Rectangle; import org.eclipse.swt.graphics.Pattern; +import com.archimatetool.model.IDiagramModelObject; + /** @@ -31,10 +33,11 @@ public void drawFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Line Width - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } graphics.setAlpha(getAlpha()); @@ -51,9 +54,11 @@ public void drawFigure(Graphics graphics) { disposeGradientPattern(graphics, gradient); // Outline - graphics.setAlpha(getLineAlpha()); - graphics.setForegroundColor(getLineColor()); - graphics.drawOval(bounds); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.setForegroundColor(getLineColor()); + graphics.drawOval(bounds); + } // Image Icon Rectangle imageArea = new Rectangle(bounds.x + (bounds.width / 6), bounds.y + (bounds.height / 6), diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RectangleFigureDelegate.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RectangleFigureDelegate.java index 8217407cc..0b26efc47 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RectangleFigureDelegate.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RectangleFigureDelegate.java @@ -9,6 +9,8 @@ import org.eclipse.draw2d.geometry.Rectangle; import org.eclipse.swt.graphics.Pattern; +import com.archimatetool.model.IDiagramModelObject; + /** @@ -31,11 +33,12 @@ public void drawFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } - setLineStyle(graphics); - graphics.setAlpha(getAlpha()); if(!isEnabled()) { @@ -52,9 +55,11 @@ public void drawFigure(Graphics graphics) { disposeGradientPattern(graphics, gradient); // Outline - graphics.setAlpha(getLineAlpha()); - graphics.setForegroundColor(getLineColor()); - graphics.drawRectangle(bounds); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.setForegroundColor(getLineColor()); + graphics.drawRectangle(bounds); + } // Icon // getOwner().drawIconImage(graphics, bounds); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RoundedRectangleFigureDelegate.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RoundedRectangleFigureDelegate.java index 368276d99..fd6a1b530 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RoundedRectangleFigureDelegate.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/RoundedRectangleFigureDelegate.java @@ -10,6 +10,8 @@ import org.eclipse.draw2d.geometry.Rectangle; import org.eclipse.swt.graphics.Pattern; +import com.archimatetool.model.IDiagramModelObject; + @@ -36,10 +38,11 @@ public void drawFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } graphics.setAlpha(getAlpha()); @@ -57,9 +60,11 @@ public void drawFigure(Graphics graphics) { disposeGradientPattern(graphics, gradient); // Outline - graphics.setAlpha(getLineAlpha()); - graphics.setForegroundColor(getLineColor()); - graphics.drawRoundRectangle(bounds, fArc.width, fArc.height); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.setForegroundColor(getLineColor()); + graphics.drawRoundRectangle(bounds, fArc.width, fArc.height); + } // Image Icon Rectangle imageArea = new Rectangle(bounds.x + 2, bounds.y + 2, bounds.width - 4, bounds.height - 4); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/DiagramImageFigure.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/DiagramImageFigure.java index ea18e069e..78b8399e7 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/DiagramImageFigure.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/DiagramImageFigure.java @@ -23,6 +23,7 @@ import com.archimatetool.editor.ui.IArchiImages; import com.archimatetool.editor.ui.ImageFactory; import com.archimatetool.model.IDiagramModelImage; +import com.archimatetool.model.IDiagramModelObject; /** @@ -102,10 +103,11 @@ protected void paintFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } if(fImage != null) { // Faster but no transparency @@ -130,7 +132,7 @@ protected void paintFigure(Graphics graphics) { } // Border - if(getBorderColor() != null) { + if(getBorderColor() != null && getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { graphics.setAlpha(getDiagramModelObject().getLineAlpha()); graphics.setForegroundColor(getBorderColor()); graphics.drawRectangle(bounds.x, bounds.y, bounds.width, bounds.height); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/GroupFigure.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/GroupFigure.java index 88d134fdc..b44a68180 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/GroupFigure.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/GroupFigure.java @@ -54,10 +54,11 @@ protected void drawFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } graphics.setAlpha(getAlpha()); @@ -111,18 +112,20 @@ protected void drawFigure(Graphics graphics) { } // Line - graphics.setForegroundColor(getLineColor()); - graphics.setAlpha(getLineAlpha()); - - Path path = new Path(null); - path.moveTo(bounds.x, bounds.y + tabHeight); - path.lineTo(bounds.x, bounds.y); - path.lineTo(bounds.x + tabWidth, bounds.y); - path.lineTo(bounds.x + tabWidth, bounds.y + tabHeight); - graphics.drawPath(path); - path.dispose(); - - graphics.drawRectangle(bounds.x, bounds.y + tabHeight, bounds.width, bounds.height - tabHeight); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setForegroundColor(getLineColor()); + graphics.setAlpha(getLineAlpha()); + + Path path = new Path(null); + path.moveTo(bounds.x, bounds.y + tabHeight); + path.lineTo(bounds.x, bounds.y); + path.lineTo(bounds.x + tabWidth, bounds.y); + path.lineTo(bounds.x + tabWidth, bounds.y + tabHeight); + graphics.drawPath(path); + path.dispose(); + + graphics.drawRectangle(bounds.x, bounds.y + tabHeight, bounds.width, bounds.height - tabHeight); + } } else { graphics.setBackgroundColor(getFillColor()); @@ -139,9 +142,11 @@ protected void drawFigure(Graphics graphics) { } // Line - graphics.setForegroundColor(getLineColor()); - graphics.setAlpha(getLineAlpha()); - graphics.drawRectangle(bounds); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setForegroundColor(getLineColor()); + graphics.setAlpha(getLineAlpha()); + graphics.drawRectangle(bounds); + } } graphics.popState(); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/NoteFigure.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/NoteFigure.java index 72a236816..1ee54b7e2 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/NoteFigure.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/diagram/NoteFigure.java @@ -25,6 +25,7 @@ import com.archimatetool.editor.diagram.figures.TextPositionDelegate; import com.archimatetool.editor.ui.textrender.TextRenderer; import com.archimatetool.model.IDiagramModelNote; +import com.archimatetool.model.IDiagramModelObject; /** @@ -114,7 +115,7 @@ protected void paintFigure(Graphics graphics) { bounds.height--; // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - if(getDiagramModelObject().getBorderType() != IDiagramModelNote.BORDER_NONE) { + if(getDiagramModelObject().getBorderType() != IDiagramModelNote.BORDER_NONE && getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { setLineWidth(graphics, bounds); setLineStyle(graphics); } @@ -151,7 +152,7 @@ protected void paintFigure(Graphics graphics) { // Icon drawIconImage(graphics, bounds); - if(getDiagramModelObject().getBorderType() != IDiagramModelNote.BORDER_NONE) { + if(getDiagramModelObject().getBorderType() != IDiagramModelNote.BORDER_NONE && getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { graphics.setAlpha(getLineAlpha()); graphics.setForegroundColor(getLineColor()); graphics.drawPolygon(points); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/AbstractMotivationFigure.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/AbstractMotivationFigure.java index 0d7f4071b..15710915d 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/AbstractMotivationFigure.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/AbstractMotivationFigure.java @@ -13,6 +13,7 @@ import com.archimatetool.editor.diagram.figures.AbstractTextControlContainerFigure; import com.archimatetool.editor.diagram.figures.FigureUtils; +import com.archimatetool.model.IDiagramModelObject; /** @@ -42,10 +43,11 @@ protected void drawFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } PointList points = new PointList(); points.addPoint(bounds.x + FLANGE, bounds.y); @@ -76,9 +78,11 @@ protected void drawFigure(Graphics graphics) { disposeGradientPattern(graphics, gradient); // Line - graphics.setAlpha(getLineAlpha()); - graphics.setForegroundColor(getLineColor()); - graphics.drawPolygon(points); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.setForegroundColor(getLineColor()); + graphics.drawPolygon(points); + } // Image Icon Rectangle imageArea = new Rectangle(bounds.x + FLANGE / 2, bounds.y + FLANGE / 2, bounds.width - FLANGE, bounds.height - FLANGE); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/GroupingFigure.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/GroupingFigure.java index ebd4c7787..3530617bc 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/GroupingFigure.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/figures/elements/GroupingFigure.java @@ -18,6 +18,7 @@ import com.archimatetool.editor.diagram.figures.AbstractTextControlContainerFigure; import com.archimatetool.editor.diagram.figures.FigureUtils; +import com.archimatetool.model.IDiagramModelObject; import com.archimatetool.model.ITextAlignment; import com.archimatetool.model.ITextPosition; @@ -58,10 +59,11 @@ protected void drawFigure(Graphics graphics) { setDisabledState(graphics); } - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } graphics.setBackgroundColor(getFillColor()); graphics.setForegroundColor(getLineColor()); @@ -131,17 +133,21 @@ protected void drawFigure(Graphics graphics) { drawIconImage(graphics, bounds); } - graphics.setAlpha(getLineAlpha()); - graphics.drawLine(bounds.x, bounds.y, bounds.x, bounds.y + tabHeight); - graphics.drawLine(bounds.x, bounds.y, bounds.x + tabWidth, bounds.y); - graphics.drawLine(bounds.x + tabWidth, bounds.y, bounds.x + tabWidth, bounds.y + tabHeight); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.drawLine(bounds.x, bounds.y, bounds.x, bounds.y + tabHeight); + graphics.drawLine(bounds.x, bounds.y, bounds.x + tabWidth, bounds.y); + graphics.drawLine(bounds.x + tabWidth, bounds.y, bounds.x + tabWidth, bounds.y + tabHeight); + } } disposeGradientPattern(graphics, gradient); // Outlines - graphics.setAlpha(getLineAlpha()); - graphics.drawPolygon(mainRectangle); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.drawPolygon(mainRectangle); + } graphics.popState(); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/sketch/figures/StickyFigure.java b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/sketch/figures/StickyFigure.java index 66caf75d9..cac490e7a 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/diagram/sketch/figures/StickyFigure.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/diagram/sketch/figures/StickyFigure.java @@ -12,6 +12,7 @@ import com.archimatetool.editor.diagram.figures.AbstractTextControlContainerFigure; import com.archimatetool.editor.utils.StringUtils; +import com.archimatetool.model.IDiagramModelObject; import com.archimatetool.model.ISketchModelSticky; @@ -48,10 +49,11 @@ protected void drawFigure(Graphics graphics) { bounds.width--; bounds.height--; - // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill - setLineWidth(graphics, bounds); - - setLineStyle(graphics); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + // Set line width here so that the whole figure is constrained, otherwise SVG graphics will have overspill + setLineWidth(graphics, bounds); + setLineStyle(graphics); + } graphics.setBackgroundColor(getFillColor()); @@ -65,9 +67,11 @@ protected void drawFigure(Graphics graphics) { drawIconImage(graphics, bounds); // Outline - graphics.setAlpha(getLineAlpha()); - graphics.setForegroundColor(getLineColor()); - graphics.drawRectangle(bounds.x, bounds.y, bounds.width, bounds.height); + if(getLineStyle() != IDiagramModelObject.LINE_STYLE_NONE) { + graphics.setAlpha(getLineAlpha()); + graphics.setForegroundColor(getLineColor()); + graphics.drawRectangle(bounds.x, bounds.y, bounds.width, bounds.height); + } graphics.popState(); } diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/LineStyleComposite.java b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/LineStyleComposite.java index d667883b9..d8acd2e70 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/LineStyleComposite.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/LineStyleComposite.java @@ -62,6 +62,7 @@ private void createControls(Composite parent) { menuManager.add(createAction(Messages.LineStyleComposite_1, IDiagramModelObject.LINE_STYLE_SOLID, IArchiImages.ImageFactory.getImageDescriptor(IArchiImages.LINE_SOLID))); menuManager.add(createAction(Messages.LineStyleComposite_2, IDiagramModelObject.LINE_STYLE_DASHED, IArchiImages.ImageFactory.getImageDescriptor(IArchiImages.LINE_DASHED))); menuManager.add(createAction(Messages.LineStyleComposite_3, IDiagramModelObject.LINE_STYLE_DOTTED, IArchiImages.ImageFactory.getImageDescriptor(IArchiImages.LINE_DOTTED))); + menuManager.add(createAction(Messages.LineStyleComposite_4, IDiagramModelObject.LINE_STYLE_NONE, IArchiImages.ImageFactory.getImageDescriptor(IArchiImages.LINE_NONE))); Menu menu = menuManager.createContextMenu(button.getShell()); Rectangle buttonBounds = button.getBounds(); @@ -133,6 +134,9 @@ void updateControl() { case IDiagramModelObject.LINE_STYLE_DOTTED: button.setImage(IArchiImages.ImageFactory.getImage(IArchiImages.LINE_DOTTED)); break; + case IDiagramModelObject.LINE_STYLE_NONE: + button.setImage(IArchiImages.ImageFactory.getImage(IArchiImages.LINE_NONE)); + break; } button.setEnabled(!section.isLocked(dmo)); diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/Messages.java b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/Messages.java index 7664a71ce..b45e3ad65 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/Messages.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/Messages.java @@ -255,6 +255,8 @@ public class Messages extends NLS { public static String LineStyleComposite_3; + public static String LineStyleComposite_4; + public static String LineWidthSection_0; public static String LineWidthSection_1; diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/messages.properties b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/messages.properties index 12a73676d..e933a254b 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/messages.properties +++ b/com.archimatetool.editor/src/com/archimatetool/editor/propertysections/messages.properties @@ -133,6 +133,7 @@ LineStyleComposite_0=Line Style: LineStyleComposite_1=Solid LineStyleComposite_2=Dashed LineStyleComposite_3=Dotted +LineStyleComposite_4=None LineWidthSection_0=Line Width: LineWidthSection_1=Normal LineWidthSection_2=Medium diff --git a/com.archimatetool.editor/src/com/archimatetool/editor/ui/IArchiImages.java b/com.archimatetool.editor/src/com/archimatetool/editor/ui/IArchiImages.java index 0662f3156..bf7c2cd06 100644 --- a/com.archimatetool.editor/src/com/archimatetool/editor/ui/IArchiImages.java +++ b/com.archimatetool.editor/src/com/archimatetool/editor/ui/IArchiImages.java @@ -192,6 +192,7 @@ public interface IArchiImages { String LINE_SOLID = IMGPATH + "line-solid.png"; String LINE_DASHED = IMGPATH + "line-dashed.png"; String LINE_DOTTED = IMGPATH + "line-dotted.png"; + String LINE_NONE = IMGPATH + "line-none.png"; String ARROW_SOURCE_FILL = IMGPATH + "arrow-source-fill.png"; String ARROW_TARGET_FILL = IMGPATH + "arrow-target-fill.png"; diff --git a/com.archimatetool.help/help/Text/properties_canvas_block.html b/com.archimatetool.help/help/Text/properties_canvas_block.html index bd02ec19f..df4c2114d 100644 --- a/com.archimatetool.help/help/Text/properties_canvas_block.html +++ b/com.archimatetool.help/help/Text/properties_canvas_block.html @@ -92,7 +92,7 @@

Canvas Block

Line Style: - Set the line style of the figure. Options are "Solid", "Dashed" and "Dotted". + Set the line style of the figure. Options are "Solid", "Dashed", "Dotted" and "None". Text Alignment: diff --git a/com.archimatetool.help/help/Text/properties_canvas_image.html b/com.archimatetool.help/help/Text/properties_canvas_image.html index fa8663aad..92eab6b45 100644 --- a/com.archimatetool.help/help/Text/properties_canvas_image.html +++ b/com.archimatetool.help/help/Text/properties_canvas_image.html @@ -75,7 +75,7 @@

Canvas Image

Line Style: - Set the line style of the figure. Options are "Solid", "Dashed" and "Dotted". + Set the line style of the figure. Options are "Solid", "Dashed", "Dotted" and "None". diff --git a/com.archimatetool.help/help/Text/properties_element_appearance.html b/com.archimatetool.help/help/Text/properties_element_appearance.html index 63cad83d4..3f01b7552 100644 --- a/com.archimatetool.help/help/Text/properties_element_appearance.html +++ b/com.archimatetool.help/help/Text/properties_element_appearance.html @@ -50,7 +50,7 @@

Element Appearance Properties

Line Style: - Set the line style of the figure. Options are "Solid", "Dashed" and "Dotted". + Set the line style of the figure. Options are "Solid", "Dashed", "Dotted" and "None". Icon Colour: diff --git a/com.archimatetool.help/help/Text/properties_group.html b/com.archimatetool.help/help/Text/properties_group.html index 9c7415fe7..66d208be8 100644 --- a/com.archimatetool.help/help/Text/properties_group.html +++ b/com.archimatetool.help/help/Text/properties_group.html @@ -80,7 +80,7 @@

Group Properties

Line Style: - Set the line style of the figure. Options are "Solid", "Dashed" and "Dotted". + Set the line style of the figure. Options are "Solid", "Dashed", "Dotted" and "None". Border: diff --git a/com.archimatetool.help/help/Text/properties_note.html b/com.archimatetool.help/help/Text/properties_note.html index 8b223d4b0..fc4ba8ff8 100644 --- a/com.archimatetool.help/help/Text/properties_note.html +++ b/com.archimatetool.help/help/Text/properties_note.html @@ -66,7 +66,7 @@

Note Properties

Line Style: - Set the line style of the figure. Options are "Solid", "Dashed" and "Dotted". + Set the line style of the figure. Options are "Solid", "Dashed", "Dotted" and "None". Border: diff --git a/com.archimatetool.help/help/Text/properties_viewref.html b/com.archimatetool.help/help/Text/properties_viewref.html index fe183e280..d8f0e282d 100644 --- a/com.archimatetool.help/help/Text/properties_viewref.html +++ b/com.archimatetool.help/help/Text/properties_viewref.html @@ -72,7 +72,7 @@

View Reference Properties

Line Style: - Set the line style of the figure. Options are "Solid", "Dashed" and "Dotted". + Set the line style of the figure. Options are "Solid", "Dashed", "Dotted" and "None". Text Alignment: diff --git a/com.archimatetool.model/src/com/archimatetool/model/IDiagramModelObject.java b/com.archimatetool.model/src/com/archimatetool/model/IDiagramModelObject.java index 7fe8b5dc4..f25c88746 100644 --- a/com.archimatetool.model/src/com/archimatetool/model/IDiagramModelObject.java +++ b/com.archimatetool.model/src/com/archimatetool/model/IDiagramModelObject.java @@ -50,6 +50,7 @@ public interface IDiagramModelObject extends IConnectable, IFontAttribute, ILine int LINE_STYLE_SOLID = 0; int LINE_STYLE_DASHED = 1; int LINE_STYLE_DOTTED = 2; + int LINE_STYLE_NONE = 3; int FEATURE_LINE_STYLE_DEFAULT = LINE_STYLE_DEFAULT; /**