X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FFontChooser.java;h=2f380845f3b3f44e42d852a86aad00d62dddda71;hb=3d731dad51b259b16c50834ec24550280fb7dd64;hp=7a27df89754ca2375e4c73b44391e22d524bd400;hpb=a45774ee31d9f35d4eff46d54d7deab719afb092;p=jalview.git diff --git a/src/jalview/appletgui/FontChooser.java b/src/jalview/appletgui/FontChooser.java index 7a27df8..2f38084 100755 --- a/src/jalview/appletgui/FontChooser.java +++ b/src/jalview/appletgui/FontChooser.java @@ -1,6 +1,6 @@ /* * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7) - * Copyright (C) 2011 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle + * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle * * This file is part of Jalview. * @@ -153,20 +153,54 @@ public class FontChooser extends Panel implements ActionListener, frame.setVisible(false); } + private Font lastSelected=null; + private int lastSelStyle=0; + private int lastSelSize=0; + /** + * DOCUMENT ME! + */ void changeFont() { + if (lastSelected==null) + { + // initialise with original font + lastSelected=oldFont; + lastSelSize=oldFont.getSize(); + lastSelStyle=oldFont.getStyle(); + } + Font newFont = new Font(fontName.getSelectedItem().toString(), fontStyle.getSelectedIndex(), Integer.parseInt(fontSize .getSelectedItem().toString())); - if (ap != null) - { - ap.av.setFont(newFont); - ap.fontChanged(); + FontMetrics fm = getGraphics().getFontMetrics(newFont); + double mw=fm.getStringBounds("M", getGraphics()) + .getWidth(),iw=fm.getStringBounds("I", getGraphics()) + .getWidth(); + if (mw<1 || iw < 1) { + // TODO: JAL-1100 + fontName.select(lastSelected.getName()); + fontStyle.select(lastSelStyle); + fontSize.select(""+lastSelSize); + JVDialog d = new JVDialog(this.frame, "Invalid Font", true, 350,200); + Panel mp=new Panel(); + d.cancel.setVisible(false); + mp.setLayout(new FlowLayout()); + mp.add(new Label("Font doesn't have letters defined\nso cannot be used\nwith alignment data.")); + d.setMainPanel(mp); + d.setVisible(true); + return; } - else if (tp != null) + if (tp != null) { tp.setTreeFont(newFont); } + else if (ap != null) + { + ap.av.setFont(newFont); + ap.fontChanged(); + } + // remember last selected + lastSelected=newFont; } protected void fontName_actionPerformed()