X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fdatamodel%2FSequence.java;h=48057b8401c00221761871deb7cf2fe2e12a0015;hb=01cc9bf86a687fa7c8a741128264b23eb7feba9b;hp=65537ae5b79cb5a7f4204e48c0cb4397b13afbe0;hpb=8e73c98073451713e9094a80feafd9b9e8bfd917;p=jalview.git diff --git a/src/jalview/datamodel/Sequence.java b/src/jalview/datamodel/Sequence.java index 65537ae..48057b8 100755 --- a/src/jalview/datamodel/Sequence.java +++ b/src/jalview/datamodel/Sequence.java @@ -42,9 +42,12 @@ public class Sequence implements SequenceI String vamsasId; Vector dbrefs; + /** This annotation is displayed below the alignment but the + * positions are tied to the residues of this sequence */ + Vector annotation; /** DOCUMENT ME!! */ - public Vector sequenceFeatures; + public SequenceFeature [] sequenceFeatures; /** * Creates a new Sequence object. @@ -133,25 +136,40 @@ public class Sequence implements SequenceI * * @param v DOCUMENT ME! */ - public void setSequenceFeatures(Vector v) + public void setSequenceFeatures(SequenceFeature [] features) { - sequenceFeatures = v; + sequenceFeatures = features; } public void addSequenceFeature(SequenceFeature sf) { if(sequenceFeatures==null) - sequenceFeatures = new Vector(); + { + sequenceFeatures = new SequenceFeature[0]; + } + + SequenceFeature [] temp = new SequenceFeature[sequenceFeatures.length+1]; + System.arraycopy(sequenceFeatures, 0, temp, 0, sequenceFeatures.length); + temp[sequenceFeatures.length] = sf; - sequenceFeatures.addElement(sf); + + sequenceFeatures = temp; } + SequenceFeature [] sfarray; + + public SequenceFeature[] getsfarray() + { + return sfarray; + } + + /** * DOCUMENT ME! * * @return DOCUMENT ME! */ - public Vector getSequenceFeatures() + public SequenceFeature [] getSequenceFeatures() { return sequenceFeatures; } @@ -574,4 +592,24 @@ public class Sequence implements SequenceI return datasetSequence; } + public AlignmentAnnotation [] getAnnotation() + { + if(annotation==null) + return null; + + AlignmentAnnotation [] ret = new AlignmentAnnotation[annotation.size()]; + for(int r = 0; r