+ }
+
+ /**
+ * enable or disable the display of Database Cross References in the sequence
+ * ID tooltip
+ */
+ public void setShowDbRefs(boolean show)
+ {
+ showdbrefs = show;
+ }
+
+ /**
+ *
+ * @return true if Database References are to be displayed on tooltips.
+ */
+ public boolean isShowDbRefs()
+ {
+ return showdbrefs;
+ }
+
+ /**
+ *
+ * @return true if Non-positional features are to be displayed on tooltips.
+ */
+ public boolean isShowNpFeats()
+ {
+ return shownpfeats;
+ }
+
+ /**
+ * enable or disable the display of Non-Positional sequence features in the
+ * sequence ID tooltip
+ *
+ * @param show
+ */
+ public void setShowNpFeats(boolean show)
+ {
+ shownpfeats = show;
+ }
+
+ /**
+ *
+ * @return true if view has hidden rows
+ */
+ public boolean hasHiddenRows()
+ {
+ return hasHiddenRows;
+ }
+
+ /**
+ *
+ * @return true if view has hidden columns
+ */
+ public boolean hasHiddenColumns()
+ {
+ return hasHiddenColumns;
+ }
+
+ /**
+ * when set, view will scroll to show the highlighted position
+ */
+ public boolean followHighlight = true;
+
+ /**
+ * @return true if view should scroll to show the highlighted region of a
+ * sequence
+ * @return
+ */
+ public boolean getFollowHighlight()
+ {
+ return followHighlight;
+ }
+
+ public boolean followSelection = true;
+
+ /**
+ * @return true if view selection should always follow the selections
+ * broadcast by other selection sources
+ */
+ public boolean getFollowSelection()
+ {
+ return followSelection;
+ }
+
+ private long sgrouphash = -1, colselhash = -1;
+
+ boolean showSeqFeaturesHeight;
+
+ /**
+ * checks current SelectionGroup against record of last hash value, and
+ * updates record.
+ *
+ * @return true if SelectionGroup changed since last call
+ */
+ boolean isSelectionGroupChanged()
+ {
+ int hc = (selectionGroup == null) ? -1 : selectionGroup.hashCode();
+ if (hc != sgrouphash)
+ {
+ sgrouphash = hc;
+ return true;
+ }
+ return false;
+ }
+
+ /**
+ * checks current colsel against record of last hash value, and updates
+ * record.
+ *
+ * @return true if colsel changed since last call
+ */
+ boolean isColSelChanged()
+ {
+ int hc = (colSel == null) ? -1 : colSel.hashCode();
+ if (hc != colselhash)
+ {
+ colselhash = hc;
+ return true;
+ }
+ return false;
+ }
+
+ public void sendSelection()
+ {
+ jalview.structure.StructureSelectionManager
+ .getStructureSelectionManager().sendSelection(
+ new SequenceGroup(getSelectionGroup()),
+ new ColumnSelection(getColumnSelection()), this);
+ }
+
+ public void setShowSequenceFeaturesHeight(boolean selected)
+ {
+ showSeqFeaturesHeight = selected;
+ }
+
+ public boolean getShowSequenceFeaturesHeight()
+ {
+ return showSeqFeaturesHeight;
+ }
+
+ boolean showUnconserved = false;
+
+ public boolean getShowUnconserved()
+ {
+ return showUnconserved;
+ }
+
+ public void setShowUnconserved(boolean showunconserved)
+ {
+ showUnconserved = showunconserved;
+ }
+
+ /**
+ * return the alignPanel containing the given viewport. Use this to get the
+ * components currently handling the given viewport.
+ *
+ * @param av
+ * @return null or an alignPanel guaranteed to have non-null alignFrame
+ * reference
+ */
+ public AlignmentPanel getAlignPanel()
+ {
+ AlignmentPanel[] aps = PaintRefresher.getAssociatedPanels(this
+ .getSequenceSetId());
+ AlignmentPanel ap = null;
+ for (int p = 0; aps != null && p < aps.length; p++)
+ {
+ if (aps[p].av == this)