use of java.awt.print.PrinterJob in project pdfbox by apache.
the class Printing method printWithPaper.
/**
* Prints using a custom page size and custom margins.
*/
private static void printWithPaper(PDDocument document) throws IOException, PrinterException {
PrinterJob job = PrinterJob.getPrinterJob();
job.setPageable(new PDFPageable(document));
// define custom paper
Paper paper = new Paper();
// 1/72 inch
paper.setSize(306, 396);
// no margins
paper.setImageableArea(0, 0, paper.getWidth(), paper.getHeight());
// custom page format
PageFormat pageFormat = new PageFormat();
pageFormat.setPaper(paper);
// override the page format
Book book = new Book();
// append all pages
book.append(new PDFPrintable(document), pageFormat, document.getNumberOfPages());
job.setPageable(book);
job.print();
}
use of java.awt.print.PrinterJob in project pdfbox by apache.
the class Printing method printWithAttributes.
/**
* Prints using custom PrintRequestAttribute values.
*/
private static void printWithAttributes(PDDocument document) throws IOException, PrinterException {
PrinterJob job = PrinterJob.getPrinterJob();
job.setPageable(new PDFPageable(document));
PrintRequestAttributeSet attr = new HashPrintRequestAttributeSet();
// pages 1 to 1
attr.add(new PageRanges(1, 1));
job.print(attr);
}
use of java.awt.print.PrinterJob in project gephi by gephi.
the class SimpleHTMLReport method printButtonActionPerformed.
// </editor-fold>//GEN-END:initComponents
private void printButtonActionPerformed(java.awt.event.ActionEvent evt) {
// GEN-FIRST:event_printButtonActionPerformed
PrinterJob pjob = PrinterJob.getPrinterJob();
PageFormat pf = pjob.defaultPage();
pjob.setPrintable(this, pf);
try {
if (pjob.printDialog()) {
pjob.print();
}
} catch (PrinterException e) {
Exceptions.printStackTrace(e);
}
}
use of java.awt.print.PrinterJob in project logisim-evolution by reds-heig.
the class Print method doPrint.
public static void doPrint(Project proj) {
CircuitJList list = new CircuitJList(proj, true);
Frame frame = proj.getFrame();
if (list.getModel().getSize() == 0) {
JOptionPane.showMessageDialog(proj.getFrame(), Strings.get("printEmptyCircuitsMessage"), Strings.get("printEmptyCircuitsTitle"), JOptionPane.YES_NO_OPTION);
return;
}
ParmsPanel parmsPanel = new ParmsPanel(list);
int action = JOptionPane.showConfirmDialog(frame, parmsPanel, Strings.get("printParmsTitle"), JOptionPane.OK_CANCEL_OPTION, JOptionPane.QUESTION_MESSAGE);
if (action != JOptionPane.OK_OPTION)
return;
List<Circuit> circuits = list.getSelectedCircuits();
if (circuits.isEmpty())
return;
PageFormat format = new PageFormat();
Printable print = new MyPrintable(proj, circuits, parmsPanel.getHeader(), parmsPanel.getRotateToFit(), parmsPanel.getPrinterView());
PrinterJob job = PrinterJob.getPrinterJob();
job.setPrintable(print, format);
if (job.printDialog() == false)
return;
try {
job.print();
} catch (PrinterException e) {
JOptionPane.showMessageDialog(proj.getFrame(), StringUtil.format(Strings.get("printError"), e.toString()), Strings.get("printErrorTitle"), JOptionPane.ERROR_MESSAGE);
}
}
use of java.awt.print.PrinterJob in project CCDD by nasa.
the class CcddJTableHandler method printTable.
/**
********************************************************************************************
* Output the table to the user-selected printer (or file)
*
* @param tableName
* table name; displayed at the top of each printed page
*
* @param fieldHandler
* data field handler; null if no data fields are associated with the table
*
* @param parent
* parent window for this table
*
* @param orientation
* page orientation; e.g., PageFormat.LANDSCAPE or PageFormat.PORTRAIT
********************************************************************************************
*/
protected void printTable(String tableName, CcddFieldHandler fieldHandler, Component parent, int orientation) {
try {
GraphicsConfiguration gc;
// Create a printer job
PrinterJob printerJob = PrinterJob.getPrinterJob();
// The native print dialog does not allow simple positioning on the screen relative to
// another component. However, the ServiceUI.printDialog() method, which calls
// PrinterJob.printDialog(), does allow setting the dialog's x and y coordinates. The
// dimensions of the print dialog must be known in order to center it over its parent,
// but the size is unknown until the dialog is instantiated. Therefore, a dummy dialog
// is created using the same call within ServiceUI.printDialog() and the dialog's size
// is taken from it. The dialog's x, y coordinates can then be determined
PrintRequestAttributeSet attributes = new HashPrintRequestAttributeSet();
DocFlavor flavor = null;
PrintService[] services = PrintServiceLookup.lookupPrintServices(flavor, attributes);
PrintService defaultService = printerJob.getPrintService();
// Get the dialog/frame that contains the table
Component comp = table.getTopLevelAncestor();
// Create a dummy dialog in order to obtain the print dialog's dimensions
ServiceDialog dialog = new ServiceDialog(comp.getGraphicsConfiguration(), 0, 0, services, 0, flavor, attributes, (Dialog) null);
Rectangle newDlgSize = dialog.getBounds();
dialog.dispose();
// Get the array of graphics devices (this accounts for multiple screens)
GraphicsDevice[] gd = GraphicsEnvironment.getLocalGraphicsEnvironment().getScreenDevices();
// Check if more than one screen exists
if (gd.length > 1) {
// Get the graphics configuration for the screen on which the component resides
gc = gd[0].getDefaultConfiguration();
} else // Only one screen is present
{
// Get the component's graphics configuration
gc = comp.getGraphicsConfiguration();
}
// Now that the dialog's size is known the print dialog's position can be calculated so
// as to center it over calling component, adjusting the location so that the dialog
// appears fully on the screen in which the component resides
Dimension compSize = comp.getSize();
Point adjLocation = CcddDialogHandler.adjustDialogLocationForScreen(new Rectangle(comp.getX() + ((compSize.width - newDlgSize.width) / 2), comp.getY() + ((compSize.height - newDlgSize.height) / 2), newDlgSize.width, newDlgSize.height));
// selected printer
if (ServiceUI.printDialog(gc, adjLocation.x, adjLocation.y, services, defaultService, flavor, attributes) != null) {
// Set the page format
PageFormat pageFormat = new PageFormat();
pageFormat.setOrientation(orientation);
// Create a book object for the table and data fields (if applicable)
Book book = new Book();
// Determine the number of pages to print the table. The printable object is
// altered during the page counting process, so it cannot be reused when creating
// the page wrapper below
int tblPages = getNumberOfPages(getPrintable(JTable.PrintMode.FIT_WIDTH, new MessageFormat(tableName), new MessageFormat("page {0}")), pageFormat);
// Add the table to the book object
book.append(new PageWrapper(getPrintable(JTable.PrintMode.FIT_WIDTH, new MessageFormat(tableName), new MessageFormat("page {0}")), 0), pageFormat, tblPages);
// Check if data fields are provided
if (fieldHandler != null && !fieldHandler.getFieldInformation().isEmpty()) {
String fields = "";
// Step through each data field
for (FieldInformation fieldInfo : fieldHandler.getFieldInformation()) {
// Append the field name and value to the output string
fields += " " + fieldInfo.getFieldName() + ": " + fieldInfo.getValue() + "\n";
}
// Place the field information into a text area
JTextArea fldTxtArea = new JTextArea(fields);
// Get the printable object for the text area
Printable fldPrintable = fldTxtArea.getPrintable(new MessageFormat("Data Fields for " + tableName), new MessageFormat("page {0}"));
// Add the fields to the book object
book.append(new PageWrapper(fldPrintable, tblPages), pageFormat, getNumberOfPages(fldPrintable, pageFormat));
}
// Output the book object to the selected printer or file
printerJob.setPageable(book);
printerJob.print();
}
} catch (PrinterException pe) {
// Inform the user that printing failed
new CcddDialogHandler().showMessageDialog(parent, "<html><b>Table '" + tableName + "' printing failed; cause '" + pe.getMessage() + "'", "Print Fail", JOptionPane.WARNING_MESSAGE, DialogOption.OK_OPTION);
}
}
Aggregations