X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FAlignViewport.java;h=87566c609716897040c77fcb68304b7e14cd11ab;hb=4367b86b1364ac33a25024d7564ba57310b93f21;hp=cd7857ec2901401270251b6eb6a04ac86b6c9067;hpb=d438fa16745a7998c9c1d92ff9ae4d47000f8784;p=jalview.git diff --git a/src/jalview/appletgui/AlignViewport.java b/src/jalview/appletgui/AlignViewport.java index cd7857e..87566c6 100755 --- a/src/jalview/appletgui/AlignViewport.java +++ b/src/jalview/appletgui/AlignViewport.java @@ -26,8 +26,9 @@ import jalview.bin.*; import jalview.datamodel.*; import jalview.schemes.*; import jalview.structure.SelectionSource; +import jalview.structure.VamsasSource; -public class AlignViewport implements SelectionSource +public class AlignViewport implements SelectionSource, VamsasSource { int startRes; @@ -262,6 +263,19 @@ public class AlignViewport implements SelectionSource followHighlight = Boolean.valueOf(param).booleanValue(); followSelection = followHighlight; } + if ((param=applet.getParameter("showSequenceLogo"))!=null) { + showSequenceLogo=Boolean.valueOf(param).booleanValue(); + } + if ((param=applet.getParameter("showGroupConsensus"))!=null) { + showGroupConsensus=Boolean.valueOf(param).booleanValue(); + } + if ((param=applet.getParameter("showGroupConservation"))!=null) { + showGroupConservation=Boolean.valueOf(param).booleanValue(); + } + if ((param=applet.getParameter("showConsensusHistogram"))!=null) { + showConsensusHistogram=Boolean.valueOf(param).booleanValue(); + } + } if (applet != null) @@ -570,10 +584,11 @@ public class AlignViewport implements SelectionSource AAFrequency.calculate(alignment.getSequencesArray(), 0, alignment.getWidth(), hconsensus, true); // always calculate the // full profile - AAFrequency.completeConsensus(consensus, hconsensus, 0, aWidth, - ignoreGapsInConsensusCalculation, - includeAllConsensusSymbols); - + updateAnnotation(true); + //AAFrequency.completeConsensus(consensus, hconsensus, 0, aWidth, + // ignoreGapsInConsensusCalculation, + // true); + if (globalColourScheme != null) { globalColourScheme.setConsensus(hconsensus); @@ -596,6 +611,28 @@ public class AlignViewport implements SelectionSource ap.paintAlignment(true); } } + + /** + * update the consensus annotation from the sequence profile data using + * current visualization settings. + */ + public void updateAnnotation() + { + updateAnnotation(false); + } + + protected void updateAnnotation(boolean immediate) + { + // TODO: make calls thread-safe, so if another thread calls this method, + // it will either return or wait until one calculation is finished. + if (immediate + || (!updatingConsensus && consensus != null && hconsensus != null)) + { + AAFrequency.completeConsensus(consensus, hconsensus, 0, + hconsensus.length, ignoreGapsInConsensusCalculation, + showSequenceLogo); + } + } } /** @@ -608,6 +645,10 @@ public class AlignViewport implements SelectionSource { if (consensus == null) { + updateConsensus(null); + } + if (consensus == null) + { return null; } StringBuffer seqs = new StringBuffer(); @@ -1573,6 +1614,16 @@ public class AlignViewport implements SelectionSource } return false; } + public void sendSelection() + { + jalview.structure.StructureSelectionManager + .getStructureSelectionManager().sendSelection( + new SequenceGroup(getSelectionGroup()), + new ColumnSelection(getColumnSelection()), this); + } + + + /** * show non-conserved residues only @@ -1602,27 +1653,17 @@ public class AlignViewport implements SelectionSource } /** - * consensus annotation includes all percentage for all symbols in column - * DISABLED FOR 2.5 RELEASE (bug #60064 logo rendering is not AWT 1.1 - * compatible) - */ - private boolean includeAllConsensusSymbols = false; - - /** - * should conservation rows be shown for groups DISABLED FOR 2.5 RELEASE (bug - * 62446) + * should conservation rows be shown for groups */ boolean showGroupConservation = false; /** - * should consensus rows be shown for groups DISABLED FOR 2.5 RELEASE (bug - * 62446) + * should consensus rows be shown for groups */ boolean showGroupConsensus = false; /** - * should consensus profile be rendered by default DISABLED FOR 2.5 RELEASE - * (bug #60064 logo rendering is not AWT 1.1 compatible) + * should consensus profile be rendered by default */ public boolean showSequenceLogo = false; @@ -1641,24 +1682,64 @@ public class AlignViewport implements SelectionSource /** * @param showSequenceLogo - * the new value public void setShowSequenceLogo(boolean - * showSequenceLogo) { this.showSequenceLogo = showSequenceLogo; } + * the new value */ + public void setShowSequenceLogo(boolean showSequenceLogo) + { + if (showSequenceLogo != this.showSequenceLogo) + { + // TODO: decouple settings setting from calculation when refactoring + // annotation update method from alignframe to viewport + this.showSequenceLogo = showSequenceLogo; + if (consensusThread != null) + { + consensusThread.updateAnnotation(); + } + } + this.showSequenceLogo = showSequenceLogo; + } + /** - * @param showGroupConsensus - * the showGroupConsensus to set + * @param showConsensusHistogram + * the showConsensusHistogram to set */ - public void setShowGroupConsensus(boolean showGroupConsensus) + public void setShowConsensusHistogram(boolean showConsensusHistogram) { - this.showGroupConsensus = showGroupConsensus; + this.showConsensusHistogram = showConsensusHistogram; } /** - * @return the includeAllConsensusSymbols + * @return the showGroupConservation */ - public boolean isIncludeAllConsensusSymbols() + public boolean isShowGroupConservation() { - return false; + return showGroupConservation; + } + + /** + * @param showGroupConservation + * the showGroupConservation to set + */ + public void setShowGroupConservation(boolean showGroupConservation) + { + this.showGroupConservation = showGroupConservation; + } + + /** + * @return the showGroupConsensus + */ + public boolean isShowGroupConsensus() + { + return showGroupConsensus; + } + + /** + * @param showGroupConsensus + * the showGroupConsensus to set + */ + public void setShowGroupConsensus(boolean showGroupConsensus) + { + this.showGroupConsensus = showGroupConsensus; } /** @@ -1703,13 +1784,4 @@ public class AlignViewport implements SelectionSource } } } - public void sendSelection() - { - jalview.structure.StructureSelectionManager - .getStructureSelectionManager().sendSelection( - new SequenceGroup(getSelectionGroup()), - new ColumnSelection(getColumnSelection()), this); - } - - }