+/*
+ * 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 <http://www.gnu.org/licenses/>.
+ * 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;
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
*/
public interface ImageWriterI
{
- void exportImage(Graphics g)
- throws Exception;
+ void exportImage(Graphics g) throws Exception;
}
private IProgressIndicator messageBoard;
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
* 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);
- if (Jalview.isJS())
+ String renderStyle = renderer == null
+ ? Cache.getDefault(imageType.getName() + "_RENDERING",
+ LineartOptions.PROMPT_EACH_TIME)
+ : renderer;
+ if (Platform.isJS())
{
renderStyle = "Text";
}
&& !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<Void> okAction = () -> {
+ exportImage(chosenFile, !textSelected.get(), width, height,
+ messageId, userBis);
+ return null;
};
LineartOptions epsOption = new LineartOptions(TYPE.EPS.getName(),
textSelected);
- epsOption.setResponseAction(1, new RunResponse(JOptionPane.NO_OPTION)
+ epsOption.setResponseAction(1, new Callable<Void>()
{
@Override
- public void run()
+ public Void call()
{
setStatus(MessageManager.formatMessage(
"status.cancelled_image_export_operation",
imageType.getName()), messageId);
+ return null;
}
});
epsOption.setResponseAction(0, okAction);
* 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);
}
}
* @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(
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);
}