X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FFontChooser.java;h=d0782b961b336d91d6f074fa4916881b9b466d87;hb=02783b1d0f22e82e7854777646e39df0fc77de74;hp=12493ebd2af3db8506e4c4eb3b5c3583045141c6;hpb=8a6fa9ea9900d0f106529c3f6283e7f9d76dd2cb;p=jalview.git diff --git a/src/jalview/gui/FontChooser.java b/src/jalview/gui/FontChooser.java index 12493eb..d0782b9 100755 --- a/src/jalview/gui/FontChooser.java +++ b/src/jalview/gui/FontChooser.java @@ -1,13 +1,13 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.6) - * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8) + * Copyright (C) 2012 J Procter, AM Waterhouse, LM Lui, J Engelhardt, G Barton, M Clamp, S Searle * * 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 @@ -179,14 +179,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, + "Font doesn't have letters defined\nso cannot be used\nwith alignment data.", + "Invalid Font", JOptionPane.WARNING_MESSAGE); + return; + } if (tp != null) { tp.setTreeFont(newFont); @@ -197,12 +233,9 @@ 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; } /**