X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FOverviewCanvas.java;fp=src%2Fjalview%2Fgui%2FOverviewCanvas.java;h=6f9fbbfddaf4e55afaf457dcb3fa7a26f159582b;hb=e54e2eee927260cd650ffe17b1422b29b8b2f122;hp=0000000000000000000000000000000000000000;hpb=7f56aef9e977c7e67499deae903c5d34f697d2ae;p=jalview.git diff --git a/src/jalview/gui/OverviewCanvas.java b/src/jalview/gui/OverviewCanvas.java new file mode 100644 index 0000000..6f9fbbf --- /dev/null +++ b/src/jalview/gui/OverviewCanvas.java @@ -0,0 +1,182 @@ +/* + * 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.gui; + +import jalview.api.AlignViewportI; +import jalview.renderer.OverviewRenderer; +import jalview.viewmodel.OverviewDimensions; + +import java.awt.Color; +import java.awt.Dimension; +import java.awt.Graphics; +import java.awt.image.BufferedImage; + +import javax.swing.JComponent; + +public class OverviewCanvas extends JComponent +{ + private static final Color TRANS_GREY = new Color(100, 100, 100, 25); + + // This is set true if the alignment view changes whilst + // the overview is being calculated + private volatile boolean restart = false; + + private volatile boolean updaterunning = false; + + private BufferedImage miniMe; + + private BufferedImage lastMiniMe = null; + + // Can set different properties in this seqCanvas than + // main visible SeqCanvas + private SequenceRenderer sr; + + private jalview.renderer.seqfeatures.FeatureRenderer fr; + + private OverviewDimensions od; + + private AlignViewportI av; + + public OverviewCanvas(OverviewDimensions overviewDims, + AlignViewportI alignvp) + { + od = overviewDims; + av = alignvp; + + sr = new SequenceRenderer(av); + sr.renderGaps = false; + sr.forOverview = true; + fr = new jalview.renderer.seqfeatures.FeatureRenderer(av); + } + + /** + * Update the overview dimensions object used by the canvas (e.g. if we change + * from showing hidden columns to hiding them or vice versa) + * + * @param overviewDims + */ + public void resetOviewDims(OverviewDimensions overviewDims) + { + od = overviewDims; + } + + /** + * Signals to drawing code that the associated alignment viewport has changed + * and a redraw will be required + */ + public boolean restartDraw() + { + synchronized (this) + { + if (updaterunning) + { + restart = true; + } + else + { + updaterunning = true; + } + return restart; + } + } + + /** + * Draw the overview sequences + * + * @param showSequenceFeatures + * true if sequence features are to be shown + * @param showAnnotation + * true if the annotation is to be shown + * @param transferRenderer + * the renderer to transfer feature colouring from + */ + public void draw(boolean showSequenceFeatures, boolean showAnnotation, + FeatureRenderer transferRenderer) + { + miniMe = null; + + if (showSequenceFeatures) + { + fr.transferSettings(transferRenderer); + } + + setPreferredSize(new Dimension(od.getWidth(), od.getHeight())); + + OverviewRenderer or = new OverviewRenderer(sr, fr, od); + miniMe = or.draw(od.getRows(av.getAlignment()), + od.getColumns(av.getAlignment())); + + Graphics mg = miniMe.getGraphics(); + + if (showAnnotation) + { + mg.translate(0, od.getSequencesHeight()); + or.drawGraph(mg, av.getAlignmentConservationAnnotation(), + av.getCharWidth(), od.getGraphHeight(), + od.getColumns(av.getAlignment())); + mg.translate(0, -od.getSequencesHeight()); + } + System.gc(); + + if (restart) + { + restart = false; + draw(showSequenceFeatures, showAnnotation, transferRenderer); + } + else + { + updaterunning = false; + lastMiniMe = miniMe; + } + } + + @Override + public void paintComponent(Graphics g) + { + if (restart) + { + if (lastMiniMe == null) + { + g.setColor(Color.white); + g.fillRect(0, 0, getWidth(), getHeight()); + } + else + { + g.drawImage(lastMiniMe, 0, 0, getWidth(), getHeight(), this); + } + g.setColor(TRANS_GREY); + g.fillRect(0, 0, getWidth(), getHeight()); + } + else if (lastMiniMe != null) + { + g.drawImage(lastMiniMe, 0, 0, this); + if (lastMiniMe != miniMe) + { + g.setColor(TRANS_GREY); + g.fillRect(0, 0, getWidth(), getHeight()); + } + } + + g.setColor(Color.red); + od.drawBox(g); + } + +}