X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FPaintRefresher.java;h=fe99187ba71937b6a8df7a147289c71c83c18762;hb=14307f5cfcbc90c419c892434613a500ca550ecc;hp=e5e9e89a8a2bdd54627e460c52b9ff3619d54ee2;hpb=2de8acfae59aced665e4c37ad0f7dcc2ed68818e;p=jalview.git diff --git a/src/jalview/appletgui/PaintRefresher.java b/src/jalview/appletgui/PaintRefresher.java index e5e9e89..fe99187 100755 --- a/src/jalview/appletgui/PaintRefresher.java +++ b/src/jalview/appletgui/PaintRefresher.java @@ -1,28 +1,34 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Development Version 2.4.1) - * Copyright (C) 2009 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ 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.appletgui; -import java.util.*; +import jalview.datamodel.AlignmentI; +import jalview.datamodel.SequenceI; -import java.awt.*; - -import jalview.datamodel.*; +import java.awt.Component; +import java.util.Hashtable; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Vector; /** * DOCUMENT ME! @@ -32,26 +38,26 @@ import jalview.datamodel.*; */ public class PaintRefresher { - static Hashtable components; + static Map> components; /** * DOCUMENT ME! * * @param comp - * DOCUMENT ME! + * DOCUMENT ME! * @param al - * DOCUMENT ME! + * DOCUMENT ME! */ public static void Register(Component comp, String seqSetId) { if (components == null) { - components = new Hashtable(); + components = new Hashtable>(); } if (components.containsKey(seqSetId)) { - Vector comps = (Vector) components.get(seqSetId); + Vector comps = components.get(seqSetId); if (!comps.contains(comp)) { comps.addElement(comp); @@ -59,7 +65,7 @@ public class PaintRefresher } else { - Vector vcoms = new Vector(); + Vector vcoms = new Vector<>(); vcoms.addElement(comp); components.put(seqSetId, vcoms); } @@ -72,15 +78,14 @@ public class PaintRefresher return; } - Enumeration en = components.keys(); - while (en.hasMoreElements()) + Iterator it = components.keySet().iterator(); + while (it.hasNext()) { - String id = en.nextElement().toString(); - Vector comps = (Vector) components.get(id); + Vector comps = components.get(it.next()); comps.removeElement(comp); - if (comps.size() == 0) + if (comps.isEmpty()) { - components.remove(id); + it.remove(); } } } @@ -99,17 +104,17 @@ public class PaintRefresher } Component comp; - Vector comps = (Vector) components.get(id); + Vector comps = components.get(id); if (comps == null) { return; } - Enumeration e = comps.elements(); - while (e.hasMoreElements()) + Iterator it = comps.iterator(); + while (it.hasNext()) { - comp = (Component) e.nextElement(); + comp = it.next(); if (comp == source) { @@ -118,13 +123,13 @@ public class PaintRefresher if (!comp.isValid()) { - comps.removeElement(comp); + it.remove(); } else if (validateSequences && comp instanceof AlignmentPanel && source instanceof AlignmentPanel) { - validateSequences(((AlignmentPanel) source).av.alignment, - ((AlignmentPanel) comp).av.alignment); + validateSequences(((AlignmentPanel) source).av.getAlignment(), + ((AlignmentPanel) comp).av.getAlignment()); } if (comp instanceof AlignmentPanel && alignmentChanged) @@ -184,7 +189,13 @@ public class PaintRefresher { if (i < comp.getHeight()) { - comp.getSequences().insertElementAt(a1[i], i); + // TODO: the following does not trigger any recalculation of + // height/etc, or maintain the dataset + List alsq; + synchronized (alsq = comp.getSequences()) + { + alsq.add(i, a1[i]); + } } else { @@ -226,4 +237,26 @@ public class PaintRefresher } } } + + public static AlignmentPanel[] getAssociatedPanels(String id) + { + Vector comps = components.get(id); + Vector tmp = new Vector<>(); + int i, iSize = comps.size(); + for (i = 0; i < iSize; i++) + { + if (comps.elementAt(i) instanceof AlignmentPanel) + { + tmp.addElement(comps.elementAt(i)); + } + } + AlignmentPanel[] result = new AlignmentPanel[tmp.size()]; + for (int ix = 0; ix < result.length; ix++) + { + result[ix] = (AlignmentPanel) tmp.elementAt(ix); + } + + return result; + } + }