2013-12-10 19:36:50 +00:00
|
|
|
/* ========================================================================
|
|
|
|
* PlantUML : a free UML diagram generator
|
|
|
|
* ========================================================================
|
|
|
|
*
|
2016-01-09 12:15:40 +00:00
|
|
|
* (C) Copyright 2009-2017, Arnaud Roques
|
2013-12-10 19:36:50 +00:00
|
|
|
*
|
|
|
|
* Project Info: http://plantuml.sourceforge.net
|
|
|
|
*
|
|
|
|
* This file is part of PlantUML.
|
|
|
|
*
|
|
|
|
* PlantUML is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* PlantUML distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
|
|
|
|
* License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
|
|
|
* USA.
|
|
|
|
*
|
|
|
|
* [Java is a trademark or registered trademark of Sun Microsystems, Inc.
|
|
|
|
* in the United States and other countries.]
|
|
|
|
*
|
|
|
|
* Original Author: Arnaud Roques
|
|
|
|
*
|
|
|
|
* Revision $Revision: 5183 $
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
package net.sourceforge.plantuml.ugraphic;
|
|
|
|
|
|
|
|
import net.sourceforge.plantuml.graphic.UGraphicDelegator;
|
|
|
|
|
|
|
|
public class UGraphicCompress extends UGraphicDelegator {
|
|
|
|
|
|
|
|
public UGraphic apply(UChange change) {
|
|
|
|
if (change instanceof UTranslate) {
|
|
|
|
return new UGraphicCompress(getUg(), compressionTransform, translate.compose((UTranslate) change));
|
|
|
|
} else if (change instanceof UStroke || change instanceof UChangeBackColor || change instanceof UChangeColor) {
|
|
|
|
return new UGraphicCompress(getUg().apply(change), compressionTransform, translate);
|
|
|
|
}
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
private final CompressionTransform compressionTransform;
|
|
|
|
private final UTranslate translate;
|
|
|
|
|
|
|
|
public UGraphicCompress(UGraphic ug, CompressionTransform compressionTransform) {
|
|
|
|
this(ug, compressionTransform, new UTranslate());
|
|
|
|
}
|
|
|
|
|
|
|
|
private UGraphicCompress(UGraphic ug, CompressionTransform compressionTransform, UTranslate translate) {
|
|
|
|
super(ug);
|
|
|
|
this.compressionTransform = compressionTransform;
|
|
|
|
this.translate = translate;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void draw(UShape shape) {
|
|
|
|
final double x = translate.getDx();
|
|
|
|
final double y = translate.getDy();
|
|
|
|
if (shape instanceof ULine) {
|
|
|
|
drawLine(x, y, (ULine) shape);
|
|
|
|
} else {
|
|
|
|
getUg().apply(new UTranslate(x, ct(y))).draw(shape);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void drawLine(double x, double y, ULine shape) {
|
|
|
|
drawLine(x, ct(y), x + shape.getDX(), ct(y + shape.getDY()));
|
|
|
|
}
|
|
|
|
|
|
|
|
private double ct(double v) {
|
|
|
|
return compressionTransform.transform(v);
|
|
|
|
}
|
|
|
|
|
|
|
|
private void drawLine(double x1, double y1, double x2, double y2) {
|
2015-06-07 10:23:10 +00:00
|
|
|
if (y1 > y2) {
|
|
|
|
drawLine(x2, y2, x1, y1);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
assert y1 <= y2;
|
2013-12-10 19:36:50 +00:00
|
|
|
final double xmin = Math.min(x1, x2);
|
|
|
|
final double xmax = Math.max(x1, x2);
|
|
|
|
final double ymin = Math.min(y1, y2);
|
|
|
|
final double ymax = Math.max(y1, y2);
|
2015-06-07 10:23:10 +00:00
|
|
|
if (x2 >= x1) {
|
|
|
|
getUg().apply(new UTranslate(xmin, ymin)).draw(new ULine(xmax - xmin, ymax - ymin));
|
|
|
|
} else {
|
|
|
|
getUg().apply(new UTranslate(xmax, ymin)).draw(new ULine(-(xmax - xmin), ymax - ymin));
|
|
|
|
}
|
2013-12-10 19:36:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|