X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FImageExporter.java;h=1d472f1951e3f16f4adbefdab0fccdb9576af5b6;hb=173c541c3bdef7cee4f72a76cc8e23e8902a8614;hp=1f83b7cfe07a738a296dafe95ba17c45d5b9ad40;hpb=f9f0b83445a2da848d21614d94a909888484e25e;p=jalview.git diff --git a/src/jalview/gui/ImageExporter.java b/src/jalview/gui/ImageExporter.java index 1f83b7c..1d472f1 100644 --- a/src/jalview/gui/ImageExporter.java +++ b/src/jalview/gui/ImageExporter.java @@ -1,5 +1,31 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors + * + * This file is part of Jalview. + * + * Jalview 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. + * + * Jalview 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 Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. + */ package jalview.gui; +import java.awt.Component; +import java.awt.Graphics; +import java.io.File; +import java.util.concurrent.Callable; +import java.util.concurrent.atomic.AtomicBoolean; + import jalview.bin.Cache; import jalview.bin.Jalview; import jalview.io.JalviewFileChooser; @@ -7,14 +33,8 @@ import jalview.io.JalviewFileView; import jalview.util.ImageMaker; import jalview.util.ImageMaker.TYPE; import jalview.util.MessageManager; -import jalview.util.dialogrunner.RunResponse; - -import java.awt.Component; -import java.awt.Graphics; -import java.io.File; -import java.util.concurrent.atomic.AtomicBoolean; - -import javax.swing.JOptionPane; +import jalview.util.Platform; +import jalview.util.imagemaker.BitmapImageSizing; /** * A class that marshals steps in exporting a view in image graphics format @@ -40,8 +60,7 @@ public class ImageExporter */ public interface ImageWriterI { - void exportImage(Graphics g) - throws Exception; + void exportImage(Graphics g) throws Exception; } private IProgressIndicator messageBoard; @@ -87,7 +106,18 @@ public class ImageExporter public void doExport(File file, Component parent, int width, int height, String imageSource) { + doExport(file, parent, width, height, imageSource, null, + BitmapImageSizing.nullBitmapImageSizing()); + } + + public void doExport(File file, Component parent, int width, int height, + String imageSource, String renderer, BitmapImageSizing userBis) + { final long messageId = System.currentTimeMillis(); + setStatus( + MessageManager.formatMessage( + "status.exporting_alignment_as_x_file", imageType), + messageId); /* * prompt user for output file if not provided @@ -118,10 +148,16 @@ public class ImageExporter /* * Prompt for Text or Lineart (EPS/SVG) unless a preference is already set * for this as EPS_RENDERING / SVG_RENDERING + * Always set to Text for JalviewJS as Lineart (glyph fonts) not available */ - String renderStyle = Cache.getDefault( - imageType.getName() + "_RENDERING", - LineartOptions.PROMPT_EACH_TIME); + String renderStyle = renderer == null + ? Cache.getDefault(imageType.getName() + "_RENDERING", + LineartOptions.PROMPT_EACH_TIME) + : renderer; + if (Platform.isJS()) + { + renderStyle = "Text"; + } AtomicBoolean textSelected = new AtomicBoolean( !"Lineart".equals(renderStyle)); if ((imageType == TYPE.EPS || imageType == TYPE.SVG) @@ -129,28 +165,25 @@ public class ImageExporter && !Jalview.isHeadlessMode()) { final File chosenFile = file; - RunResponse okAction = new RunResponse(JOptionPane.OK_OPTION) - { - @Override - public void run() - { - exportImage(chosenFile, !textSelected.get(), width, height, - messageId); - } + Callable okAction = () -> { + exportImage(chosenFile, !textSelected.get(), width, height, + messageId, userBis); + return null; }; LineartOptions epsOption = new LineartOptions(TYPE.EPS.getName(), textSelected); - epsOption.setResponseAction(new RunResponse(JOptionPane.NO_OPTION) + epsOption.setResponseAction(1, new Callable() { @Override - public void run() + public Void call() { setStatus(MessageManager.formatMessage( "status.cancelled_image_export_operation", imageType.getName()), messageId); + return null; } }); - epsOption.setResponseAction(okAction); + epsOption.setResponseAction(0, okAction); epsOption.showDialog(); /* no code here - JalviewJS cannot execute it */ } @@ -160,7 +193,8 @@ public class ImageExporter * character rendering not required, or preference already set * - just do the export */ - exportImage(file, !textSelected.get(), width, height, messageId); + exportImage(file, !textSelected.get(), width, height, messageId, + userBis); } } @@ -176,17 +210,17 @@ public class ImageExporter * @param messageId */ protected void exportImage(File chosenFile, boolean asLineart, int width, - int height, long messageId) + int height, long messageId, BitmapImageSizing userBis) { String type = imageType.getName(); try { - setStatus( - MessageManager.formatMessage( - "status.exporting_alignment_as_x_file", type), - messageId); + // setStatus( + // MessageManager.formatMessage( + // "status.exporting_alignment_as_x_file", type), + // messageId); ImageMaker im = new ImageMaker(imageType, width, height, chosenFile, - title, asLineart); + title, asLineart, userBis); imageWriter.exportImage(im.getGraphics()); im.writeImage(); setStatus( @@ -194,9 +228,8 @@ public class ImageExporter messageId); } catch (Exception e) { - System.out - .println(String.format("Error creating %s file: %s", type, - e.toString())); + System.out.println(String.format("Error creating %s file: %s", type, + e.toString())); setStatus(MessageManager.formatMessage("info.error_creating_file", type), messageId); } @@ -210,7 +243,7 @@ public class ImageExporter */ void setStatus(String msg, long id) { - if (messageBoard != null) + if (messageBoard != null && !Jalview.isHeadlessMode()) { messageBoard.setProgressBar(msg, id); }