import jalview.datamodel.AlignmentI;
import jalview.datamodel.AlignmentView;
import jalview.datamodel.Annotation;
+import jalview.datamodel.CigarArray;
import jalview.datamodel.ColumnSelection;
import jalview.datamodel.Sequence;
import jalview.datamodel.SequenceCollectionI;
import java.awt.Color;
import java.util.ArrayList;
import java.util.BitSet;
+import java.util.HashMap;
import java.util.Hashtable;
import java.util.List;
import java.util.Map;
*/
public abstract class AlignmentViewport implements AlignViewportI
{
+ /*
+ * A viewport that hosts the cDna view of this (protein), or vice versa (if
+ * set).
+ */
+ AlignViewportI codingComplement = null;
+
/**
* alignment displayed in the viewport. Please use get/setter
*/
public void setHiddenColumns(ColumnSelection colsel)
{
this.colSel = colsel;
- if (colSel.getHiddenColumns() != null)
- {
- hasHiddenColumns = true;
- }
}
@Override
this.hiddenRepSequences = hiddenRepSequences;
}
- protected boolean hasHiddenColumns = false;
+ @Override
+ public boolean hasHiddenColumns()
+ {
+ return colSel != null && colSel.hasHiddenColumns();
+ }
public void updateHiddenColumns()
{
- hasHiddenColumns = colSel.hasHiddenColumns();
+ // this method doesn't really do anything now. But - it could, since a
+ // column Selection could be in the process of modification
+ // hasHiddenColumns = colSel.hasHiddenColumns();
}
protected boolean hasHiddenRows = false;
+ @Override
public boolean hasHiddenRows()
{
return hasHiddenRows;
protected boolean showConsensus = true;
- Hashtable sequenceColours;
+ private Map<SequenceI, Color> sequenceColours = new HashMap<SequenceI, Color>();
/**
* Property change listener for changes in alignment
colSel.hideSelectedColumns();
setSelectionGroup(null);
- hasHiddenColumns = true;
}
public void hideColumns(int start, int end)
{
colSel.hideColumns(start, end);
}
-
- hasHiddenColumns = true;
}
public void showColumn(int col)
{
colSel.revealHiddenColumns(col);
- if (colSel.getHiddenColumns() == null)
- {
- hasHiddenColumns = false;
- }
+
}
public void showAllHiddenColumns()
{
colSel.revealAllHiddenColumns();
- hasHiddenColumns = false;
}
// common hide/show seq stuff
}
@Override
- public abstract void sendSelection();
-
- @Override
public void invertColumnSelection()
{
colSel.invertColumnSelection(0, alignment.getWidth());
@Override
- public jalview.datamodel.CigarArray getViewAsCigars(
+ public CigarArray getViewAsCigars(
boolean selectedRegionOnly)
{
- return new jalview.datamodel.CigarArray(alignment,
- (hasHiddenColumns ? colSel : null),
+ return new CigarArray(alignment, colSel,
(selectedRegionOnly ? selectionGroup : null));
}
boolean selectedOnly, boolean markGroups)
{
return new AlignmentView(alignment, colSel, selectionGroup,
- hasHiddenColumns, selectedOnly, markGroups);
+ colSel != null && colSel.hasHiddenColumns(), selectedOnly,
+ markGroups);
}
}
selection = new String[iSize];
- if (hasHiddenColumns)
+ if (colSel != null && colSel.hasHiddenColumns())
{
selection = colSel.getVisibleSequenceStrings(start, end, seqs);
}
do
{
- if (hasHiddenColumns)
+ if (colSel != null && colSel.hasHiddenColumns())
{
if (start == 0)
{
regions.addElement(new int[]
{ start, end });
- if (hasHiddenColumns)
+ if (colSel != null && colSel.hasHiddenColumns())
{
start = colSel.adjustForHiddenColumns(end);
start = colSel.getHiddenBoundaryLeft(start) + 1;
this.displayReferenceSeq = displayReferenceSeq;
}
+ @Override
public boolean isColourByReferenceSeq()
{
return alignment.hasSeqrep() && colourByReferenceSeq;
}
+ @Override
public void setColourByReferenceSeq(boolean colourByReferenceSeq)
{
this.colourByReferenceSeq = colourByReferenceSeq;
@Override
public Color getSequenceColour(SequenceI seq)
{
- Color sqc = Color.white;
- if (sequenceColours != null)
- {
- sqc = (Color) sequenceColours.get(seq);
- if (sqc == null)
- {
- sqc = Color.white;
- }
- }
- return sqc;
+ Color sqc = sequenceColours.get(seq);
+ return (sqc == null ? Color.white : sqc);
}
@Override
public void setSequenceColour(SequenceI seq, Color col)
{
- if (sequenceColours == null)
- {
- sequenceColours = new Hashtable();
- }
-
if (col == null)
{
sequenceColours.remove(seq);
@Override
public void updateSequenceIdColours()
{
- if (sequenceColours == null)
- {
- sequenceColours = new Hashtable();
- }
for (SequenceGroup sg : alignment.getGroups())
{
if (sg.idColour != null)
@Override
public void clearSequenceColours()
{
- sequenceColours = null;
+ sequenceColours.clear();
};
+ @Override
+ public AlignViewportI getCodingComplement()
+ {
+ return this.codingComplement;
+ }
+
+ /**
+ * Set this as the (cDna/protein) complement of the given viewport. Also
+ * ensures the reverse relationship is set on the given viewport.
+ */
+ @Override
+ public void setCodingComplement(AlignViewportI av)
+ {
+ if (this == av)
+ {
+ System.err.println("Ignoring recursive setCodingComplement request");
+ }
+ else
+ {
+ this.codingComplement = av;
+ // avoid infinite recursion!
+ if (av.getCodingComplement() != this)
+ {
+ av.setCodingComplement(this);
+ }
+ }
+ }
+
+ @Override
+ public boolean isNucleotide()
+ {
+ return getAlignment() == null ? false : getAlignment().isNucleotide();
+ }
+
FeaturesDisplayedI featuresDisplayed = null;
@Override
{
this.rightAlignIds = rightAlignIds;
}
-
}