net.sourceforge.plantuml.png.PngSplitter 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.png;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import net.sourceforge.plantuml.file.SuggestedFile;
import net.sourceforge.plantuml.klimt.color.ColorMapper;
import net.sourceforge.plantuml.security.SFile;
import net.sourceforge.plantuml.security.SImageIO;
import net.sourceforge.plantuml.skin.SplitParam;
import net.sourceforge.plantuml.utils.Log;
public class PngSplitter {
// ::remove file when __CORE__
private final List files = new ArrayList<>();
public PngSplitter(ColorMapper colorMapper, SuggestedFile pngFile, int horizontalPages, int verticalPages,
String metadata, int dpi, SplitParam splitParam) throws IOException {
if (horizontalPages == 1 && verticalPages == 1) {
this.files.add(pngFile.getFile(0));
return;
}
Log.info("Splitting " + horizontalPages + " x " + verticalPages);
final SFile full = pngFile.getTmpFile(); // SecurityUtils.File(pngFile.getParentFile(), pngFile.getName() +
// ".tmp");
// Thread.yield();
full.delete();
// Thread.yield();
final boolean ok = pngFile.getFile(0).renameTo(full);
// Thread.yield();
if (ok == false) {
throw new IOException("Cannot rename");
}
// Thread.yield();
final BufferedImage im = SImageIO.read(full);
// Thread.yield();
final PngSegment horizontalSegment = new PngSegment(im.getWidth(), horizontalPages);
final PngSegment verticalSegment = new PngSegment(im.getHeight(), verticalPages);
int x = 0;
for (int i = 0; i < horizontalPages; i++) {
for (int j = 0; j < verticalPages; j++) {
final SFile f = pngFile.getFile(x++);
this.files.add(f);
final int width = horizontalSegment.getLen(i);
final int height = verticalSegment.getLen(j);
BufferedImage piece = im.getSubimage(horizontalSegment.getStart(i), verticalSegment.getStart(j), width,
height);
if (splitParam.isSet()) {
BufferedImage withMargin = new BufferedImage(width + 2 * splitParam.getExternalMargin(),
height + 2 * splitParam.getExternalMargin(), BufferedImage.TYPE_INT_ARGB);
final Graphics2D g2d = withMargin.createGraphics();
if (splitParam.getExternalColor() != null) {
g2d.setColor(splitParam.getExternalColor());
g2d.fillRect(0, 0, withMargin.getWidth(), withMargin.getHeight());
}
g2d.drawImage(piece, splitParam.getExternalMargin(), splitParam.getExternalMargin(), null);
if (splitParam.getBorderColor() != null) {
g2d.setColor(splitParam.getBorderColor());
g2d.drawRect(splitParam.getExternalMargin() - 1, splitParam.getExternalMargin() - 1,
piece.getWidth() + 1, piece.getHeight() + 1);
}
piece = withMargin;
g2d.dispose();
}
// Thread.yield();
PngIO.write(piece, colorMapper, f, metadata, dpi);
// Thread.yield();
}
}
full.delete();
Log.info("End of splitting");
}
public List getFiles() {
return Collections.unmodifiableList(files);
}
}