X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fdatamodel%2FSequenceGroup.java;h=0944c3465bad8d23900a57ceac74543f0d1d1649;hb=ab43013b7e357b84b4abade0dba949668dfb2a0e;hp=f3cf291d1371d0d9299fd267f72d587086100777;hpb=47168f025aefdaa044802bd5f8f510ffe43a4808;p=jalview.git diff --git a/src/jalview/datamodel/SequenceGroup.java b/src/jalview/datamodel/SequenceGroup.java index f3cf291..0944c34 100755 --- a/src/jalview/datamodel/SequenceGroup.java +++ b/src/jalview/datamodel/SequenceGroup.java @@ -1,5 +1,5 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2) + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2b1) * Copyright (C) 2014 The Jalview Authors * * This file is part of Jalview. @@ -20,13 +20,18 @@ */ package jalview.datamodel; -import java.util.*; -import java.util.List; - -import java.awt.*; +import jalview.analysis.AAFrequency; +import jalview.analysis.Conservation; +import jalview.schemes.ColourSchemeI; +import jalview.schemes.ResidueProperties; -import jalview.analysis.*; -import jalview.schemes.*; +import java.awt.Color; +import java.util.ArrayList; +import java.util.Enumeration; +import java.util.Hashtable; +import java.util.List; +import java.util.Map; +import java.util.Vector; /** * Collects a set contiguous ranges on a set of sequences @@ -173,7 +178,9 @@ public class SequenceGroup implements AnnotatedCollectionI endRes = seqsel.endRes; cs = seqsel.cs; if (seqsel.description != null) + { description = new String(seqsel.description); + } hidecols = seqsel.hidecols; hidereps = seqsel.hidereps; idColour = seqsel.idColour; @@ -233,7 +240,9 @@ public class SequenceGroup implements AnnotatedCollectionI } } if (!found) + { continue; + } } AlignmentAnnotation newannot = new AlignmentAnnotation( seq.getAnnotation()[a]); @@ -289,11 +298,13 @@ public class SequenceGroup implements AnnotatedCollectionI return eres; } + @Override public List getSequences() { return sequences; } + @Override public List getSequences( Map hiddenReps) { @@ -307,7 +318,7 @@ public class SequenceGroup implements AnnotatedCollectionI SequenceI seq; for (int i = 0; i < sequences.size(); i++) { - seq = (SequenceI) sequences.elementAt(i); + seq = sequences.elementAt(i); allSequences.addElement(seq); if (hiddenReps.containsKey(seq)) { @@ -472,7 +483,7 @@ public class SequenceGroup implements AnnotatedCollectionI } /** - * Max Gaps Threshold (percent) for performing a conservation calculation + * Max Gaps Threshold (percent) for performing a conservation calculation */ private int consPercGaps = 25; @@ -486,7 +497,8 @@ public class SequenceGroup implements AnnotatedCollectionI /** * set Max Gaps Threshold (percent) for performing a conservation calculation - * @param consPercGaps + * + * @param consPercGaps */ public void setConsPercGaps(int consPercGaps) { @@ -537,7 +549,7 @@ public class SequenceGroup implements AnnotatedCollectionI } if (cs != null) { - cs.alignmentChanged(context!=null ? context : this, null); + cs.alignmentChanged(context != null ? context : this, null); } } catch (java.lang.OutOfMemoryError err) { @@ -586,9 +598,10 @@ public class SequenceGroup implements AnnotatedCollectionI consensus.annotations = new Annotation[aWidth]; // should be alignment width AAFrequency.completeConsensus(consensus, cnsns, startRes, endRes + 1, - ignoreGapsInConsensus, showSequenceLogo, nseq); // TODO: setting container - // for - // ignoreGapsInConsensusCalculation); + ignoreGapsInConsensus, showSequenceLogo, nseq); // TODO: setting + // container + // for + // ignoreGapsInConsensusCalculation); } /** @@ -633,6 +646,7 @@ public class SequenceGroup implements AnnotatedCollectionI * * @return the first column selected by this group. Runs from 0<=i 0) { - width = ((SequenceI) sequences.elementAt(0)).getLength(); + width = sequences.elementAt(0).getLength(); } for (int i = 1; i < sequences.size(); i++) { - SequenceI seq = (SequenceI) sequences.elementAt(i); + SequenceI seq = sequences.elementAt(i); if (seq.getLength() > width) { @@ -1209,7 +1225,7 @@ public class SequenceGroup implements AnnotatedCollectionI // TODO add in other methods like 'getAlignmentAnnotation(String label), // etc' ArrayList annot = new ArrayList(); - for (SequenceI seq : (Vector) sequences) + for (SequenceI seq : sequences) { AlignmentAnnotation[] aa = seq.getAnnotation(); if (aa != null) @@ -1248,20 +1264,70 @@ public class SequenceGroup implements AnnotatedCollectionI return aa; } + /** + * Returns a list of annotations that match the specified sequenceRef, calcId + * and label, ignoring null values. + * + * @return list of AlignmentAnnotation objects + */ + @Override + public Iterable findAnnotations(SequenceI seq, + String calcId, String label) + { + ArrayList aa = new ArrayList(); + for (AlignmentAnnotation ann : getAlignmentAnnotation()) + { + if (ann.getCalcId() != null && ann.getCalcId().equals(calcId) + && ann.sequenceRef != null && ann.sequenceRef == seq + && ann.label != null && ann.label.equals(label)) + { + aa.add(ann); + } + } + return aa; + } + + /** + * Answer true if any annotation matches the calcId passed in (if not null). + * + * @param calcId + * @return + */ + public boolean hasAnnotation(String calcId) + { + if (calcId != null && !"".equals(calcId)) + { + for (AlignmentAnnotation a : getAlignmentAnnotation()) + { + if (a.getCalcId() == calcId) + { + return true; + } + } + } + return false; + } + public void clear() { sequences.clear(); } + private AnnotatedCollectionI context; + /** * set the alignment or group context for this group + * * @param context */ public void setContext(AnnotatedCollectionI context) { - this.context = context; + this.context = context; } - /* (non-Javadoc) + + /* + * (non-Javadoc) + * * @see jalview.datamodel.AnnotatedCollectionI#getContext() */ @Override