X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fschemes%2FClustalxColourScheme.java;h=04097a8f592a189cff08a3cfd071de2e562b2f96;hb=aa08cfe91eda60027de76aafb0bcdbfc6481a1d9;hp=3a9f8f7fb9d5d7f8c311711e4918b2ad84cceea9;hpb=1d0f5219658cdf6ad5e1a1cbe6e1bb8cd12e6d85;p=jalview.git diff --git a/src/jalview/schemes/ClustalxColourScheme.java b/src/jalview/schemes/ClustalxColourScheme.java index 3a9f8f7..04097a8 100755 --- a/src/jalview/schemes/ClustalxColourScheme.java +++ b/src/jalview/schemes/ClustalxColourScheme.java @@ -20,16 +20,18 @@ */ package jalview.schemes; +import java.awt.Color; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + import jalview.api.AlignViewportI; import jalview.datamodel.AnnotatedCollectionI; import jalview.datamodel.SequenceCollectionI; import jalview.datamodel.SequenceI; +import jalview.util.ColorUtils; import jalview.util.Comparison; -import java.awt.Color; -import java.util.List; -import java.util.Map; - public class ClustalxColourScheme extends ResidueColourScheme { private static final int EIGHTY_FIVE = 85; @@ -95,7 +97,7 @@ public class ClustalxColourScheme extends ResidueColourScheme } @Override - public void alignmentChanged(AnnotatedCollectionI alignment, + public synchronized void alignmentChanged(AnnotatedCollectionI alignment, Map hiddenReps) { int maxWidth = alignment.getWidth(); @@ -278,7 +280,7 @@ public class ClustalxColourScheme extends ResidueColourScheme } @Override - protected Color findColour(char c, int j, SequenceI seq) + protected synchronized Color findColour(char c, int j, SequenceI seq) { // TODO why the test for includeGaps here? if (cons2.length <= j || Comparison.isGap(c) @@ -337,11 +339,10 @@ public class ClustalxColourScheme extends ResidueColourScheme @Override public ColourSchemeI getInstance(AlignViewportI view, - AnnotatedCollectionI sg, - Map hiddenRepSequences) + AnnotatedCollectionI sg) { ClustalxColourScheme css = new ClustalxColourScheme(sg, - hiddenRepSequences); + view == null ? null : view.getHiddenRepSequences()); css.includeGaps = includeGaps; return css; } @@ -363,4 +364,63 @@ public class ClustalxColourScheme extends ResidueColourScheme { return false; } + public String toRuleRep() + { + makeColours(); + HashMap 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(); + } }