{\r
Vector comps = (Vector) components.get(seqSetId);\r
if(!comps.contains(comp))\r
+ {\r
comps.addElement(comp);\r
+ }\r
}\r
else\r
{\r
\r
public static void Refresh(Component source, String id)\r
{\r
- Refresh( source, id, null, null);\r
+ Refresh( source, id, false, false);\r
}\r
\r
- public static void Refresh(Component source, String id,\r
- SequenceI removeSeq,\r
- SequenceI addSeq)\r
+ public static void Refresh(Component source,\r
+ String id,\r
+ boolean alignmentChanged,\r
+ boolean validateSequences)\r
{\r
if (components == null)\r
return;\r
comp = (Component) e.nextElement();\r
\r
if(comp==source)\r
+ {\r
continue;\r
+ }\r
\r
if (!comp.isValid())\r
{\r
comps.removeElement(comp);\r
}\r
- else if(comp instanceof AlignmentPanel)\r
+ else if(validateSequences\r
+ && comp instanceof AlignmentPanel\r
+ && source instanceof AlignmentPanel )\r
{\r
- AlignmentPanel ap = (AlignmentPanel)comp;\r
- if(addSeq!=null)\r
- ap.av.alignment.addSequence(addSeq);\r
- if(removeSeq!=null)\r
- ap.av.alignment.deleteSequence(removeSeq);\r
-\r
- // if(source instanceof AlignmentPanel)\r
- // ap.av.alignment.setGroups(\r
- // ((AlignmentPanel)source).av.alignment.getGroups() );\r
+ validateSequences( ((AlignmentPanel)source).av.alignment,\r
+ ((AlignmentPanel)comp).av.alignment);\r
+ }\r
\r
+ if(comp instanceof AlignmentPanel && alignmentChanged)\r
+ {\r
+ ((AlignmentPanel)comp).alignmentChanged();\r
}\r
+\r
comp.repaint();\r
}\r
+ }\r
+\r
+ static void validateSequences(AlignmentI source, AlignmentI comp)\r
+ {\r
+ SequenceI[] a1;\r
+ if(source.getHiddenSequences().getSize()>0)\r
+ a1 = source.getHiddenSequences().getFullAlignment().getSequencesArray();\r
+ else\r
+ a1 = source.getSequencesArray();\r
+\r
+ SequenceI[] a2;\r
+ if (comp.getHiddenSequences().getSize() > 0)\r
+ a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray();\r
+ else\r
+ a2 = comp.getSequencesArray();\r
\r
+ int i, iSize=a1.length, j, jSize=a2.length;\r
+\r
+ if(iSize == jSize)\r
+ return;\r
+\r
+ boolean exists = false;\r
+ for(i=0; i<iSize; i++)\r
+ {\r
+ exists = false;\r
+\r
+ for(j=0; j<jSize; j++)\r
+ if (a2[j]==a1[i] )\r
+ {\r
+ exists = true;\r
+ break;\r
+ }\r
+\r
+ if(!exists)\r
+ {\r
+ if (i < jSize)\r
+ comp.getSequences().insertElementAt(a1[i], i);\r
+ else\r
+ comp.addSequence(a1[i]);\r
+\r
+ jSize++;\r
+\r
+ if (comp.getHiddenSequences().getSize() > 0)\r
+ a2 = comp.getHiddenSequences().getFullAlignment().getSequencesArray();\r
+ else\r
+ a2 = comp.getSequencesArray();\r
+ }\r
+ }\r
+\r
+ iSize=a1.length;\r
+ jSize=a2.length;\r
+\r
+ for(j=0; j<jSize; j++)\r
+ {\r
+ exists = false;\r
+ for(i=0; i<iSize; i++)\r
+ {\r
+ if (a2[j]==a1[i])\r
+ {\r
+ exists = true;\r
+ break;\r
+ }\r
+ }\r
+\r
+ if(!exists)\r
+ {\r
+ comp.deleteSequence(a2[j]);\r
+ }\r
+ }\r
}\r
+\r
+ static AlignmentPanel [] getAssociatedPanels(String id)\r
+ {\r
+ Vector comps = (Vector)components.get(id);\r
+ Vector tmp = new Vector();\r
+ int i, iSize = comps.size();\r
+ for (i = 0; i < iSize; i++)\r
+ {\r
+ if (comps.elementAt(i) instanceof AlignmentPanel)\r
+ {\r
+ tmp.addElement(((AlignmentPanel)comps.elementAt(i)));\r
+ }\r
+ }\r
+ AlignmentPanel [] result = new AlignmentPanel[tmp.size()];\r
+ tmp.toArray(result);\r
+\r
+ return result;\r
+ }\r
+\r
}\r