X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FPaintRefresher.java;h=11952104edbdcbf94c49e747a8d78b3f22a28931;hb=d5912abc02b0fd206d9705cf13a0383f09d3d951;hp=12a0040eede857e2db6b186e55886ae2595a53df;hpb=174230b4233d9ce80f94527768d2cd2f76da11ab;p=jalview.git diff --git a/src/jalview/appletgui/PaintRefresher.java b/src/jalview/appletgui/PaintRefresher.java index 12a0040..1195210 100755 --- a/src/jalview/appletgui/PaintRefresher.java +++ b/src/jalview/appletgui/PaintRefresher.java @@ -16,57 +16,188 @@ * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ - - - package jalview.appletgui; +import jalview.datamodel.*; + import java.awt.*; + import java.util.*; -import jalview.datamodel.*; + +/** + * DOCUMENT ME! + * + * @author $author$ + * @version $Revision$ + */ public class PaintRefresher { - static Hashtable components = new Hashtable(); + static Hashtable components; - public static void Register(Component comp, AlignmentI al) - { - if(components.containsKey(al)) + /** + * DOCUMENT ME! + * + * @param comp DOCUMENT ME! + * @param al DOCUMENT ME! + */ + public static void Register(Component comp, String seqSetId) { - Vector comps = (Vector)components.get(al); - comps.addElement(comp); + if (components == null) + components = new Hashtable(); + + if (components.containsKey(seqSetId)) + { + Vector comps = (Vector) components.get(seqSetId); + if(!comps.contains(comp)) + { + comps.addElement(comp); + } + } + else + { + Vector vcoms = new Vector(); + vcoms.addElement(comp); + components.put(seqSetId, vcoms); + } + } + + public static void RemoveComponent(Component comp) + { + if (components == null) + return; + + Enumeration en = components.keys(); + while(en.hasMoreElements()) + { + String id = en.nextElement().toString(); + Vector comps = (Vector) components.get(id); + comps.removeElement(comp); + if(comps.size()==0) + { + components.remove(id); + } + } } - else + + public static void Refresh(Component source, String id) { - Vector vcoms = new Vector(); - vcoms.addElement(comp); - components.put(al, vcoms); + Refresh( source, id, false, false); } - } - - public static void Refresh(AlignmentI al) - { - Refresh(null, al); - } - - public static void Refresh(Component c, AlignmentI al) - { - Component temp; - Vector coms = (Vector)components.get(al); - Enumeration e = coms.elements(); - while( e.hasMoreElements() ) + + public static void Refresh(Component source, + String id, + boolean alignmentChanged, + boolean validateSequences) { - temp = (Component)e.nextElement(); + if (components == null) + return; - if(!temp.isValid()) - coms.removeElement( temp ); - else if( temp == c ) - continue; - else - temp.repaint(); + Component comp; + Vector comps = (Vector) components.get(id); + + if(comps==null) + { + return; + } + + Enumeration e = comps.elements(); + while (e.hasMoreElements()) + { + comp = (Component) e.nextElement(); + + if(comp==source) + { + continue; + } + + if (!comp.isValid()) + { + comps.removeElement(comp); + } + else if(validateSequences + && comp instanceof AlignmentPanel + && source instanceof AlignmentPanel ) + { + validateSequences( ((AlignmentPanel)source).av.alignment, + ((AlignmentPanel)comp).av.alignment); + } + + if(comp instanceof AlignmentPanel && alignmentChanged) + { + ((AlignmentPanel)comp).alignmentChanged(); + } + + comp.repaint(); + } } - } + static void validateSequences(AlignmentI source, AlignmentI comp) + { + SequenceI[] a1; + if(source.getHiddenSequences().getSize()>0) + a1 = source.getHiddenSequences().getFullAlignment().getSequencesArray(); + else + a1 = source.getSequencesArray(); + + SequenceI[] a2; + if (comp.getHiddenSequences().getSize() > 0) + a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray(); + else + a2 = comp.getSequencesArray(); -} + int i, iSize=a1.length, j, jSize=a2.length; + + if(iSize == jSize) + return; + boolean exists = false; + for(i=0; i 0) + a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray(); + else + a2 = comp.getSequencesArray(); + } + } + + iSize=a1.length; + jSize=a2.length; + + for(j=0; j