X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fworkers%2FAlignmentAnnotationFactory.java;h=b0392d43dcba33e116a609df29fdd3c84f8f95d1;hb=136c0793b90b72b928c4d77dc109dd5c644e00d3;hp=37f3ca504f8601eb51cdbf4bbb1c4142108c65e6;hpb=32cb25af86f1710205b6fdca0df00aed0a0211bb;p=jalview.git diff --git a/src/jalview/workers/AlignmentAnnotationFactory.java b/src/jalview/workers/AlignmentAnnotationFactory.java index 37f3ca5..b0392d4 100644 --- a/src/jalview/workers/AlignmentAnnotationFactory.java +++ b/src/jalview/workers/AlignmentAnnotationFactory.java @@ -1,9 +1,31 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors + * + * This file is part of Jalview. + * + * Jalview 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 3 + * of the License, or (at your option) any later version. + * + * Jalview 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 Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. + */ package jalview.workers; +import jalview.api.AlignViewportI; +import jalview.api.AlignmentViewPanel; +import jalview.bin.Jalview; import jalview.datamodel.AlignmentAnnotation; import jalview.datamodel.Annotation; import jalview.gui.AlignFrame; -import jalview.gui.Desktop; import java.awt.Color; @@ -12,9 +34,9 @@ import java.awt.Color; * such as Groovy) to 'register and forget' an alignment annotation calculator.
* Currently supports two flavours of calculator: * */ @@ -26,30 +48,17 @@ public class AlignmentAnnotationFactory * @param counter * provider of feature counts per alignment position */ - public static void newCalculator(FeatureCounterI counter) + public static void newCalculator(FeatureSetCounterI counter) { - if (Desktop.getCurrentAlignFrame() != null) - { - newCalculator(Desktop.getCurrentAlignFrame(), counter); - } - else + AlignmentViewPanel currentAlignFrame = Jalview.getCurrentAlignFrame().alignPanel; + if (currentAlignFrame == null) { System.err .println("Can't register calculator as no alignment window has focus"); + return; } - } - - /** - * Constructs and registers a new alignment annotation worker - * - * @param af - * the AlignFrame for which the annotation is to be calculated - * @param counter - * provider of feature counts per alignment position - */ - public static void newCalculator(AlignFrame af, FeatureCounterI counter) - { - new ColumnCounterWorker(af, counter); + new ColumnCounterSetWorker(currentAlignFrame.getAlignViewport(), + currentAlignFrame, counter); } /** @@ -60,9 +69,13 @@ public class AlignmentAnnotationFactory */ public static void newCalculator(AnnotationProviderI calculator) { - if (Desktop.getCurrentAlignFrame() != null) + // TODO need an interface for AlignFrame by which to access + // its AlignViewportI and AlignmentViewPanel + AlignFrame currentAlignFrame = Jalview.getCurrentAlignFrame(); + if (currentAlignFrame != null) { - newCalculator(Desktop.getCurrentAlignFrame(), calculator); + new AnnotationWorker(currentAlignFrame.getViewport(), + currentAlignFrame.getAlignPanels().get(0), calculator); } else { @@ -74,15 +87,15 @@ public class AlignmentAnnotationFactory /** * Constructs and registers a new alignment annotation worker * - * @param af - * the AlignFrame for which the annotation is to be calculated + * @param viewport + * @param panel * @param calculator * provider of AlignmentAnnotation for the alignment */ - public static void newCalculator(AlignFrame af, - AnnotationProviderI calculator) + public static void newCalculator(AlignViewportI viewport, + AlignmentViewPanel panel, AnnotationProviderI calculator) { - new AnnotationWorker(af, calculator); + new AnnotationWorker(viewport, panel, calculator); } /**