apply gpl development license
[jalview.git] / src / jalview / gui / PaintRefresher.java
1 /*
2  * Jalview - A Sequence Alignment Editor and Viewer (Development Version 2.4.1)
3  * Copyright (C) 2009 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle
4  * 
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version.
9  * 
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  * 
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
18  */
19 package jalview.gui;
20
21 import java.util.*;
22
23 import java.awt.*;
24
25 import jalview.datamodel.*;
26
27 /**
28  * DOCUMENT ME!
29  * 
30  * @author $author$
31  * @version $Revision$
32  */
33 public class PaintRefresher
34 {
35   static Hashtable components;
36
37   /**
38    * DOCUMENT ME!
39    * 
40    * @param comp
41    *                DOCUMENT ME!
42    * @param al
43    *                DOCUMENT ME!
44    */
45   public static void Register(Component comp, String seqSetId)
46   {
47     if (components == null)
48     {
49       components = new Hashtable();
50     }
51
52     if (components.containsKey(seqSetId))
53     {
54       Vector comps = (Vector) components.get(seqSetId);
55       if (!comps.contains(comp))
56       {
57         comps.addElement(comp);
58       }
59     }
60     else
61     {
62       Vector vcoms = new Vector();
63       vcoms.addElement(comp);
64       components.put(seqSetId, vcoms);
65     }
66   }
67
68   public static void RemoveComponent(Component comp)
69   {
70     if (components == null)
71     {
72       return;
73     }
74
75     Enumeration en = components.keys();
76     while (en.hasMoreElements())
77     {
78       String id = en.nextElement().toString();
79       Vector comps = (Vector) components.get(id);
80       comps.remove(comp);
81       if (comps.size() == 0)
82       {
83         components.remove(id);
84       }
85     }
86   }
87
88   public static void Refresh(Component source, String id)
89   {
90     Refresh(source, id, false, false);
91   }
92
93   public static void Refresh(Component source, String id,
94           boolean alignmentChanged, boolean validateSequences)
95   {
96     if (components == null)
97     {
98       return;
99     }
100
101     Component comp;
102     Vector comps = (Vector) components.get(id);
103
104     if (comps == null)
105     {
106       return;
107     }
108
109     Enumeration e = comps.elements();
110     while (e.hasMoreElements())
111     {
112       comp = (Component) e.nextElement();
113
114       if (comp == source)
115       {
116         continue;
117       }
118
119       if (validateSequences && comp instanceof AlignmentPanel
120               && source instanceof AlignmentPanel)
121       {
122         validateSequences(((AlignmentPanel) source).av.alignment,
123                 ((AlignmentPanel) comp).av.alignment);
124       }
125
126       if (comp instanceof AlignmentPanel && alignmentChanged)
127       {
128         ((AlignmentPanel) comp).alignmentChanged();
129       }
130
131       comp.repaint();
132     }
133   }
134
135   static void validateSequences(AlignmentI source, AlignmentI comp)
136   {
137     SequenceI[] a1;
138     if (source.getHiddenSequences().getSize() > 0)
139     {
140       a1 = source.getHiddenSequences().getFullAlignment()
141               .getSequencesArray();
142     }
143     else
144     {
145       a1 = source.getSequencesArray();
146     }
147
148     SequenceI[] a2;
149     if (comp.getHiddenSequences().getSize() > 0)
150     {
151       a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray();
152     }
153     else
154     {
155       a2 = comp.getSequencesArray();
156     }
157
158     int i, iSize = a1.length, j, jSize = a2.length;
159
160     if (iSize == jSize)
161     {
162       return;
163     }
164
165     boolean exists = false;
166     for (i = 0; i < iSize; i++)
167     {
168       exists = false;
169
170       for (j = 0; j < jSize; j++)
171       {
172         if (a2[j] == a1[i])
173         {
174           exists = true;
175           break;
176         }
177       }
178
179       if (!exists)
180       {
181         if (i < comp.getHeight())
182         {
183           comp.getSequences().insertElementAt(a1[i], i);
184         }
185         else
186         {
187           comp.addSequence(a1[i]);
188         }
189
190         if (comp.getHiddenSequences().getSize() > 0)
191         {
192           a2 = comp.getHiddenSequences().getFullAlignment()
193                   .getSequencesArray();
194         }
195         else
196         {
197           a2 = comp.getSequencesArray();
198         }
199
200         jSize = a2.length;
201       }
202     }
203
204     iSize = a1.length;
205     jSize = a2.length;
206
207     for (j = 0; j < jSize; j++)
208     {
209       exists = false;
210       for (i = 0; i < iSize; i++)
211       {
212         if (a2[j] == a1[i])
213         {
214           exists = true;
215           break;
216         }
217       }
218
219       if (!exists)
220       {
221         comp.deleteSequence(a2[j]);
222       }
223     }
224   }
225
226   static AlignmentPanel[] getAssociatedPanels(String id)
227   {
228     Vector comps = (Vector) components.get(id);
229     Vector tmp = new Vector();
230     int i, iSize = comps.size();
231     for (i = 0; i < iSize; i++)
232     {
233       if (comps.elementAt(i) instanceof AlignmentPanel)
234       {
235         tmp.addElement(((AlignmentPanel) comps.elementAt(i)));
236       }
237     }
238     AlignmentPanel[] result = new AlignmentPanel[tmp.size()];
239     tmp.toArray(result);
240
241     return result;
242   }
243
244 }