/* * Jalview - A Sequence Alignment Editor and Viewer * Copyright (C) 2007 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ package jalview.datamodel; import java.util.Enumeration; import java.util.Hashtable; import java.util.Vector; /** * DOCUMENT ME! * * @author $author$ * @version $Revision$ */ public class AlignmentAnnotation { /** If true, this annotations is calculated every edit, * eg consensus, quality or conservation graphs */ public boolean autoCalculated = false; public String annotationId; public SequenceI sequenceRef; /** DOCUMENT ME!! */ public String label; /** DOCUMENT ME!! */ public String description; /** DOCUMENT ME!! */ public Annotation[] annotations; public java.util.Hashtable sequenceMapping; /** DOCUMENT ME!! */ public float graphMin; /** DOCUMENT ME!! */ public float graphMax; public GraphLine threshold; // Graphical hints and tips /** DOCUMENT ME!! */ public boolean editable = false; /** DOCUMENT ME!! */ public boolean hasIcons; // /** DOCUMENT ME!! */ public boolean hasText; /** DOCUMENT ME!! */ public boolean visible = true; public int graphGroup = -1; /** DOCUMENT ME!! */ public int height = 0; public int graph = 0; public int graphHeight = 40; public static final int NO_GRAPH = 0; public static final int BAR_GRAPH = 1; public static final int LINE_GRAPH = 2; public static int getGraphValueFromString(String string) { if (string.equalsIgnoreCase("BAR_GRAPH")) { return BAR_GRAPH; } else if (string.equalsIgnoreCase("LINE_GRAPH")) { return LINE_GRAPH; } else { return NO_GRAPH; } } /** * Creates a new AlignmentAnnotation object. * * @param label DOCUMENT ME! * @param description DOCUMENT ME! * @param annotations DOCUMENT ME! */ public AlignmentAnnotation(String label, String description, Annotation[] annotations) { // always editable? editable = true; this.label = label; this.description = description; this.annotations = annotations; areLabelsSecondaryStructure(); } void areLabelsSecondaryStructure() { boolean nonSSLabel = false; for (int i = 0; i < annotations.length; i++) { if (annotations[i] == null) { continue; } if (annotations[i].secondaryStructure == 'H' || annotations[i].secondaryStructure == 'E') { hasIcons = true; } if (annotations[i].displayCharacter.length() == 1 && !annotations[i].displayCharacter.equals("H") && !annotations[i].displayCharacter.equals("E") && !annotations[i].displayCharacter.equals("-") && !annotations[i].displayCharacter.equals(".")) { if (jalview.schemes.ResidueProperties.aaIndex [annotations[i].displayCharacter.charAt(0)] < 23) { nonSSLabel = true; } } if (annotations[i].displayCharacter.length() > 0) { hasText = true; } } if (nonSSLabel) { hasIcons = false; for (int j = 0; j < annotations.length; j++) { if (annotations[j] != null && annotations[j].secondaryStructure != ' ') { annotations[j].displayCharacter = String.valueOf(annotations[j].secondaryStructure); annotations[j].secondaryStructure = ' '; } } } annotationId = this.hashCode() + ""; } /** * Creates a new AlignmentAnnotation object. * * @param label DOCUMENT ME! * @param description DOCUMENT ME! * @param annotations DOCUMENT ME! * @param min DOCUMENT ME! * @param max DOCUMENT ME! * @param winLength DOCUMENT ME! */ public AlignmentAnnotation(String label, String description, Annotation[] annotations, float min, float max, int graphType) { // graphs are not editable editable = graphType==0; this.label = label; this.description = description; this.annotations = annotations; graph = graphType; graphMin = min; graphMax = max; validateRangeAndDisplay(); } /** * checks graphMin and graphMax, * secondary structure symbols, * sets graphType appropriately, * sets null labels to the empty string * if appropriate. */ private void validateRangeAndDisplay() { int graphType = graph; float min = graphMin; float max = graphMax; boolean drawValues = true; if (min == max) { min = 999999999; for (int i = 0; i < annotations.length; i++) { if (annotations[i] == null) { continue; } if (drawValues && annotations[i].displayCharacter.length() > 1) { drawValues = false; } if (annotations[i].value > max) { max = annotations[i].value; } if (annotations[i].value < min) { min = annotations[i].value; } } } graphMin = min; graphMax = max; areLabelsSecondaryStructure(); if (!drawValues && graphType != NO_GRAPH) { for (int i = 0; i < annotations.length; i++) { if (annotations[i] != null) { annotations[i].displayCharacter = ""; } } } } /** * Copy constructor * creates a new independent annotation row with the same associated sequenceRef * @param annotation */ public AlignmentAnnotation(AlignmentAnnotation annotation) { this.label = new String(annotation.label); if (annotation.description != null) this.description = new String(annotation.description); this.graphMin = annotation.graphMin; this.graphMax = annotation.graphMax; this.graph = annotation.graph; this.graphHeight = annotation.graphHeight; this.graphGroup = annotation.graphGroup; this.editable = annotation.editable; this.autoCalculated = annotation.autoCalculated; this.hasIcons = annotation.hasIcons; this.hasText = annotation.hasText; this.height = annotation.height; this.label = annotation.label; if (threshold!=null) { threshold = new GraphLine(annotation.threshold); } if (annotation.annotations!=null) { Vector anvec = new Vector(); Annotation[] ann = annotation.annotations; this.annotations = new Annotation[ann.length]; for (int i=0; i