weka.gui.visualize.PostscriptWriter Maven / Gradle / Ivy
Show all versions of weka-dev Show documentation
/*
* This program 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.
*
* This program is 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 program. If not, see .
*/
/*
* PostscriptWriter.java
* Copyright (C) 2005-2012 University of Waikato, Hamilton, New Zealand
*
*/
package weka.gui.visualize;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import javax.swing.JComponent;
/**
* This class takes any Component and outputs it to a Postscript file.
* Note:
* This writer does not work with Components that rely on clipping, like e.g.
* scroll lists. Here the complete list is printed, instead of only in the
* borders of the scroll list (may overlap other components!). This is due to
* the way, clipping is handled in Postscript. There was no easy way around
* this issue. :-(
*
* @author FracPete (fracpete at waikato dot ac dot nz)
* @version $Revision: 8034 $
* @see PostscriptGraphics
*/
public class PostscriptWriter
extends JComponentWriter {
/**
* initializes the object
*/
public PostscriptWriter() {
super(null);
}
/**
* initializes the object with the given Component
*
* @param c the component to print in the output format
*/
public PostscriptWriter(JComponent c) {
super(c);
}
/**
* initializes the object with the given Component and filename
*
* @param c the component to print in the output format
* @param f the file to store the output in
*/
public PostscriptWriter(JComponent c, File f) {
super(c, f);
}
/**
* returns the name of the writer, to display in the FileChooser.
* must be overridden in the derived class.
*/
public String getDescription() {
return "Postscript-File";
}
/**
* returns the extension (incl. ".") of the output format, to use in the
* FileChooser.
* must be overridden in the derived class.
*/
public String getExtension() {
return ".eps";
}
/**
* generates the actual output
*
* @throws Exception if something goes wrong
*/
public void generateOutput() throws Exception {
BufferedOutputStream ostrm;
PostscriptGraphics psg;
ostrm = null;
try {
ostrm = new BufferedOutputStream(new FileOutputStream(getFile()));
psg = new PostscriptGraphics(getComponent().getHeight(), getComponent().getWidth(), ostrm);
psg.setFont(getComponent().getFont());
psg.scale(getXScale(), getYScale());
getComponent().printAll(psg);
psg.finished();
}
catch (Exception e) {
System.err.println(e);
}
finally {
if (ostrm != null) {
try {
ostrm.close();
} catch (Exception e) {
// Nothing to really do for error on close
}
}
}
}
/**
* for testing only
*/
public static void main(String[] args) throws Exception {
System.out.println("building TreeVisualizer...");
weka.gui.treevisualizer.TreeBuild builder = new weka.gui.treevisualizer.TreeBuild();
weka.gui.treevisualizer.NodePlace arrange = new weka.gui.treevisualizer.PlaceNode2();
weka.gui.treevisualizer.Node top = builder.create(new java.io.StringReader("digraph atree { top [label=\"the top\"] a [label=\"the first node\"] b [label=\"the second nodes\"] c [label=\"comes off of first\"] top->a top->b b->c }"));
weka.gui.treevisualizer.TreeVisualizer tv = new weka.gui.treevisualizer.TreeVisualizer(null, top, arrange);
tv.setSize(800 ,600);
String filename = System.getProperty("java.io.tmpdir") + "test.eps";
System.out.println("outputting to '" + filename + "'...");
toOutput(new PostscriptWriter(), tv, new File(filename));
System.out.println("done!");
}
}