X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FFontChooser.java;h=36e4c52eaf8e33b43dda7f700680b512d66393c4;hb=cca50cb3aee94f3ed1a5e504d45b8d8b665f8c5b;hp=6e99d9156fb461c333c26f57b986ff4758e8ab76;hpb=506d60f0e188723ddc91c26824b41ac7034df3fe;p=jalview.git diff --git a/src/jalview/gui/FontChooser.java b/src/jalview/gui/FontChooser.java index 6e99d91..36e4c52 100755 --- a/src/jalview/gui/FontChooser.java +++ b/src/jalview/gui/FontChooser.java @@ -1,20 +1,22 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.4) - * Copyright (C) 2008 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2) + * Copyright (C) 2014 The Jalview Authors * - * 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 2 - * of the License, or (at your option) any later version. + * This file is part of Jalview. * - * 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. + * 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 this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + * along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. */ package jalview.gui; @@ -24,6 +26,7 @@ import javax.swing.*; import jalview.bin.*; import jalview.jbgui.*; +import jalview.util.MessageManager; /** * DOCUMENT ME! @@ -47,7 +50,7 @@ public class FontChooser extends GFontChooser * Creates a new FontChooser object. * * @param ap - * DOCUMENT ME! + * DOCUMENT ME! */ public FontChooser(TreePanel tp) { @@ -63,7 +66,7 @@ public class FontChooser extends GFontChooser * Creates a new FontChooser object. * * @param ap - * DOCUMENT ME! + * DOCUMENT ME! */ public FontChooser(AlignmentPanel ap) { @@ -81,12 +84,15 @@ public class FontChooser extends GFontChooser if (tp != null) { - Desktop.addInternalFrame(frame, "Change Font (Tree Panel)", 340, 170, - false); + Desktop.addInternalFrame(frame, + MessageManager.getString("action.change_font_tree_panel"), + 340, 170, false); } else { - Desktop.addInternalFrame(frame, "Change Font", 340, 170, false); + Desktop.addInternalFrame(frame, + MessageManager.getString("action.change_font"), 340, 170, + false); } frame.setLayer(JLayeredPane.PALETTE_LAYER); @@ -123,7 +129,7 @@ public class FontChooser extends GFontChooser public void smoothFont_actionPerformed(ActionEvent e) { ap.av.antiAlias = smoothFont.isSelected(); - ap.annotationPanel.image = null; + ap.getAnnotationPanel().image = null; ap.paintAlignment(true); } @@ -131,7 +137,7 @@ public class FontChooser extends GFontChooser * DOCUMENT ME! * * @param e - * DOCUMENT ME! + * DOCUMENT ME! */ protected void ok_actionPerformed(ActionEvent e) { @@ -155,7 +161,7 @@ public class FontChooser extends GFontChooser * DOCUMENT ME! * * @param e - * DOCUMENT ME! + * DOCUMENT ME! */ protected void cancel_actionPerformed(ActionEvent e) { @@ -180,14 +186,50 @@ public class FontChooser extends GFontChooser } } + private Font lastSelected = null; + + private int lastSelStyle = 0; + + private int lastSelSize = 0; + + private boolean lastSelMono = false; + /** * DOCUMENT ME! */ void changeFont() { + if (lastSelected == null) + { + // initialise with original font + lastSelected = oldFont; + lastSelSize = oldFont.getSize(); + lastSelStyle = oldFont.getStyle(); + FontMetrics fm = getGraphics().getFontMetrics(oldFont); + double mw = fm.getStringBounds("M", getGraphics()).getWidth(), iw = fm + .getStringBounds("I", getGraphics()).getWidth(); + lastSelMono = mw == iw; + } + Font newFont = new Font(fontName.getSelectedItem().toString(), fontStyle.getSelectedIndex(), Integer.parseInt(fontSize .getSelectedItem().toString())); + FontMetrics fm = getGraphics().getFontMetrics(newFont); + double mw = fm.getStringBounds("M", getGraphics()).getWidth(), iw = fm + .getStringBounds("I", getGraphics()).getWidth(); + if (mw < 1 || iw < 1) + { + fontName.setSelectedItem(lastSelected.getName()); + fontStyle.setSelectedIndex(lastSelStyle); + fontSize.setSelectedItem("" + lastSelSize); + monospaced.setSelected(lastSelMono); + JOptionPane + .showInternalMessageDialog( + this, + MessageManager.getString("label.font_doesnt_have_letters_defined"), + MessageManager.getString("label.invalid_font"), JOptionPane.WARNING_MESSAGE); + return; + } if (tp != null) { tp.setTreeFont(newFont); @@ -198,19 +240,16 @@ public class FontChooser extends GFontChooser ap.fontChanged(); } - FontMetrics fm = getGraphics().getFontMetrics(newFont); - - monospaced.setSelected(fm.getStringBounds("M", getGraphics()) - .getWidth() == fm.getStringBounds("|", getGraphics()) - .getWidth()); - + monospaced.setSelected(mw == iw); + // remember last selected + lastSelected = newFont; } /** * DOCUMENT ME! * * @param e - * DOCUMENT ME! + * DOCUMENT ME! */ protected void fontName_actionPerformed(ActionEvent e) { @@ -226,7 +265,7 @@ public class FontChooser extends GFontChooser * DOCUMENT ME! * * @param e - * DOCUMENT ME! + * DOCUMENT ME! */ protected void fontSize_actionPerformed(ActionEvent e) { @@ -242,7 +281,7 @@ public class FontChooser extends GFontChooser * DOCUMENT ME! * * @param e - * DOCUMENT ME! + * DOCUMENT ME! */ protected void fontStyle_actionPerformed(ActionEvent e) { @@ -258,14 +297,14 @@ public class FontChooser extends GFontChooser * DOCUMENT ME! * * @param e - * DOCUMENT ME! + * DOCUMENT ME! */ public void defaultButton_actionPerformed(ActionEvent e) { Cache.setProperty("FONT_NAME", fontName.getSelectedItem().toString()); Cache.setProperty("FONT_STYLE", fontStyle.getSelectedIndex() + ""); Cache.setProperty("FONT_SIZE", fontSize.getSelectedItem().toString()); - Cache.setProperty("ANTI_ALIAS", Boolean.toString(smoothFont - .isSelected())); + Cache.setProperty("ANTI_ALIAS", + Boolean.toString(smoothFont.isSelected())); } }