2 * Jalview - A Sequence Alignment Editor and Viewer
\r
3 * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle
\r
5 * This program is free software; you can redistribute it and/or
\r
6 * modify it under the terms of the GNU General Public License
\r
7 * as published by the Free Software Foundation; either version 2
\r
8 * of the License, or (at your option) any later version.
\r
10 * This program is distributed in the hope that it will be useful,
\r
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
\r
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
\r
13 * GNU General Public License for more details.
\r
15 * You should have received a copy of the GNU General Public License
\r
16 * along with this program; if not, write to the Free Software
\r
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
\r
19 package jalview.gui;
\r
21 import jalview.datamodel.*;
\r
32 * @version $Revision$
\r
34 public class PaintRefresher
\r
36 static Hashtable components;
\r
41 * @param comp DOCUMENT ME!
\r
42 * @param al DOCUMENT ME!
\r
44 public static void Register(Component comp, String seqSetId)
\r
46 if (components == null)
\r
47 components = new Hashtable();
\r
49 if (components.containsKey(seqSetId))
\r
51 Vector comps = (Vector) components.get(seqSetId);
\r
52 if(!comps.contains(comp))
\r
54 comps.addElement(comp);
\r
59 Vector vcoms = new Vector();
\r
60 vcoms.addElement(comp);
\r
61 components.put(seqSetId, vcoms);
\r
65 public static void RemoveComponent(Component comp)
\r
67 if (components == null)
\r
70 Enumeration en = components.keys();
\r
71 while(en.hasMoreElements())
\r
73 String id = en.nextElement().toString();
\r
74 Vector comps = (Vector) components.get(id);
\r
78 components.remove(id);
\r
83 public static void Refresh(Component source, String id)
\r
85 Refresh( source, id, false, false);
\r
88 public static void Refresh(Component source,
\r
90 boolean alignmentChanged,
\r
91 boolean validateSequences)
\r
93 if (components == null)
\r
97 Vector comps = (Vector) components.get(id);
\r
104 Enumeration e = comps.elements();
\r
105 while (e.hasMoreElements())
\r
107 comp = (Component) e.nextElement();
\r
114 if (!comp.isValid())
\r
116 comps.removeElement(comp);
\r
118 else if(validateSequences
\r
119 && comp instanceof AlignmentPanel
\r
120 && source instanceof AlignmentPanel )
\r
122 validateSequences( ((AlignmentPanel)source).av.alignment,
\r
123 ((AlignmentPanel)comp).av.alignment);
\r
126 if(comp instanceof AlignmentPanel && alignmentChanged)
\r
128 ((AlignmentPanel)comp).alignmentChanged();
\r
135 static void validateSequences(AlignmentI source, AlignmentI comp)
\r
138 if(source.getHiddenSequences().getSize()>0)
\r
139 a1 = source.getHiddenSequences().getFullAlignment().getSequencesArray();
\r
141 a1 = source.getSequencesArray();
\r
144 if (comp.getHiddenSequences().getSize() > 0)
\r
145 a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray();
\r
147 a2 = comp.getSequencesArray();
\r
149 int i, iSize=a1.length, j, jSize=a2.length;
\r
154 boolean exists = false;
\r
155 for(i=0; i<iSize; i++)
\r
159 for(j=0; j<jSize; j++)
\r
169 comp.getSequences().insertElementAt(a1[i], i);
\r
171 comp.addSequence(a1[i]);
\r
175 if (comp.getHiddenSequences().getSize() > 0)
\r
176 a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray();
\r
178 a2 = comp.getSequencesArray();
\r
185 for(j=0; j<jSize; j++)
\r
188 for(i=0; i<iSize; i++)
\r
199 comp.deleteSequence(a2[j]);
\r