Merge branch 'develop' into bug/JAL-2934proportionalScrolling
[jalview.git] / src / jalview / schemes / ClustalxColourScheme.java
index 5a2d5dc..04097a8 100755 (executable)
@@ -21,6 +21,7 @@
 package jalview.schemes;
 
 import java.awt.Color;
+import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
@@ -28,6 +29,7 @@ import jalview.api.AlignViewportI;
 import jalview.datamodel.AnnotatedCollectionI;
 import jalview.datamodel.SequenceCollectionI;
 import jalview.datamodel.SequenceI;
+import jalview.util.ColorUtils;
 import jalview.util.Comparison;
 
 public class ClustalxColourScheme extends ResidueColourScheme
@@ -362,4 +364,63 @@ public class ClustalxColourScheme extends ResidueColourScheme
   {
     return false;
   }
+  public String toRuleRep()
+  {
+    makeColours();
+    HashMap<String, String> cols=new HashMap();
+    for (String res:ResidueProperties.aa) {
+      StringBuilder sb = new StringBuilder();
+      
+      int rnum=ResidueProperties.aaIndex[res.charAt(0)];
+      if (rnum<0 || rnum>=residueColour.length)
+      {
+        continue;
+      }
+      
+      ConsensusColour cc = residueColour[rnum];
+      if (cc==null)
+      {
+        continue;
+      }
+      //sb.append("Residue "+res+" ("+rnum+")");
+      //sb.append("\t");
+      sb.append(cc.c.toString());
+      double f=0;
+      sb.append("\t");
+      for (Consensus cons: cc.cons) {
+        if (cons.threshold==0 || f!=cons.threshold)
+        {
+          if (f!=0)
+          {
+
+              sb.append("}, {");
+          } else {
+          sb.append("{");
+          }
+        sb.append(cons.threshold);
+        sb.append(",");
+        f=cons.threshold;
+        } else {
+          sb.append(",");
+        }
+        sb.append(cons.maskstr);
+      }
+      sb.append("}");
+      String clxrep=sb.toString();
+      String xres = cols.get(clxrep);
+      if (xres==null) { xres = "";}
+      xres+=res;
+      cols.put(clxrep, xres);
+    }
+    StringBuilder sb = new StringBuilder();
+    for (String clxrep:cols.keySet())
+    {
+      sb.append(cols.get(clxrep));
+      sb.append("\t");
+      sb.append(clxrep);
+      sb.append("\n");
+      
+    }
+    return sb.toString();
+  }
 }