Merge branch 'develop' into bug/JAL-147scrollWrappedView
authorgmungoc <g.m.carstairs@dundee.ac.uk>
Mon, 3 Jul 2017 14:39:09 +0000 (15:39 +0100)
committergmungoc <g.m.carstairs@dundee.ac.uk>
Mon, 3 Jul 2017 14:39:09 +0000 (15:39 +0100)
1  2 
src/jalview/viewmodel/AlignmentViewport.java

@@@ -405,7 -405,6 +405,7 @@@ public abstract class AlignmentViewpor
    public void setWrapAlignment(boolean state)
    {
      viewStyle.setWrapAlignment(state);
 +    ranges.setWrappedMode(state);
    }
  
    /**
    {
      return searchResults;
    }
+   /**
+    * get the consensus sequence as displayed under the PID consensus annotation
+    * row.
+    * 
+    * @return consensus sequence as a new sequence object
+    */
+   public SequenceI getConsensusSeq()
+   {
+     if (consensus == null)
+     {
+       updateConsensus(null);
+     }
+     if (consensus == null)
+     {
+       return null;
+     }
+     StringBuffer seqs = new StringBuffer();
+     for (int i = 0; i < consensus.annotations.length; i++)
+     {
+       Annotation annotation = consensus.annotations[i];
+       if (annotation != null)
+       {
+         String description = annotation.description;
+         if (description != null && description.startsWith("["))
+         {
+           // consensus is a tie - just pick the first one
+           seqs.append(description.charAt(1));
+         }
+         else
+         {
+           seqs.append(annotation.displayCharacter);
+         }
+       }
+     }
+   
+     SequenceI sq = new Sequence("Consensus", seqs.toString());
+     sq.setDescription("Percentage Identity Consensus "
+             + ((ignoreGapsInConsensusCalculation) ? " without gaps" : ""));
+     return sq;
+   }
  }