net.sourceforge.plantuml.nwdiag.next.GridTextBlockSimple Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of plantuml-mit Show documentation
Show all versions of plantuml-mit Show documentation
PlantUML is a component that allows to quickly write diagrams from text.
// THIS FILE HAS BEEN GENERATED BY A PREPROCESSOR.
package net.sourceforge.plantuml.nwdiag.next;
import net.atmp.InnerStrategy;
import net.sourceforge.plantuml.klimt.UTranslate;
import net.sourceforge.plantuml.klimt.color.HColor;
import net.sourceforge.plantuml.klimt.drawing.UGraphic;
import net.sourceforge.plantuml.klimt.font.StringBounder;
import net.sourceforge.plantuml.klimt.geom.MagneticBorder;
import net.sourceforge.plantuml.klimt.geom.MagneticBorderNone;
import net.sourceforge.plantuml.klimt.geom.MinMax;
import net.sourceforge.plantuml.klimt.geom.XDimension2D;
import net.sourceforge.plantuml.klimt.geom.XRectangle2D;
import net.sourceforge.plantuml.klimt.shape.TextBlock;
import net.sourceforge.plantuml.style.ISkinParam;
public class GridTextBlockSimple implements TextBlock {
public static final double MINIMUM_WIDTH = 70;
protected final NwArray data;
private final ISkinParam skinParam;
public GridTextBlockSimple(int lines, int cols, ISkinParam skinParam) {
this.skinParam = skinParam;
this.data = new NwArray(lines, cols);
}
protected void drawGrid(UGraphic ug) {
}
public void drawU(UGraphic ug) {
drawGrid(ug);
final StringBounder stringBounder = ug.getStringBounder();
double y = 0;
for (int i = 0; i < data.getNbLines(); i++) {
final double lineHeight = lineHeight(stringBounder, i);
double x = 0;
for (int j = 0; j < data.getNbCols(); j++) {
final double colWidth = colWidth(stringBounder, j);
if (data.get(i, j) != null)
data.get(i, j).drawMe(ug.apply(new UTranslate(x, y)), colWidth, lineHeight);
x += colWidth;
}
y += lineHeight;
}
}
protected double colWidth(StringBounder stringBounder, final int j) {
double width = 0;
for (int i = 0; i < data.getNbLines(); i++)
if (data.get(i, j) != null)
width = Math.max(width, data.get(i, j).naturalDimension(stringBounder).getWidth());
return width;
}
public double lineHeight(StringBounder stringBounder, final int i) {
double height = 50;
for (int j = 0; j < data.getNbCols(); j++)
if (data.get(i, j) != null)
height = Math.max(height, data.get(i, j).naturalDimension(stringBounder).getHeight());
return height;
}
public XDimension2D calculateDimension(StringBounder stringBounder) {
if (data.getNbLines() == 0)
return new XDimension2D(0, 0);
double height = 0;
for (int i = 0; i < data.getNbLines(); i++)
height += lineHeight(stringBounder, i);
double width = 0;
for (int j = 0; j < data.getNbCols(); j++)
width += colWidth(stringBounder, j);
return new XDimension2D(Math.max(MINIMUM_WIDTH, width), height);
}
public XRectangle2D getInnerPosition(String member, StringBounder stringBounder, InnerStrategy strategy) {
throw new UnsupportedOperationException("member=" + member + " " + getClass().toString());
}
public MinMax getMinMax(StringBounder stringBounder) {
throw new UnsupportedOperationException(getClass().toString());
}
public void add(int i, int j, NServerDraw value) {
data.set(i, j, value);
}
protected final ISkinParam getSkinParam() {
return skinParam;
}
@Override
public MagneticBorder getMagneticBorder() {
return new MagneticBorderNone();
}
@Override
public HColor getBackcolor() {
return null;
}
}