Skip to content
Snippets Groups Projects
BaseAlgorithm.java 7.09 KiB
Newer Older
  • Learn to ignore specific revisions
  • tjc's avatar
    tjc committed
    /* BaseAlgorithm.java
     *
     * created: Wed Dec 16 1998
     *
     * This file is part of Artemis
     * 
     * Copyright (C) 1998,1999,2000  Genome Research Limited
     * 
     * This program 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 2
     * of the License, or (at your option) any later version.
     * 
     * This program 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 this program; if not, write to the Free Software
     * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
     *
    
     * $Header: //tmp/pathsoft/artemis/uk/ac/sanger/artemis/plot/BaseAlgorithm.java,v 1.9 2009-06-26 15:52:48 tjc Exp $
    
    tjc's avatar
    tjc committed
     */
    
    package uk.ac.sanger.artemis.plot;
    
    import uk.ac.sanger.artemis.sequence.*;
    
    import java.awt.Graphics;
    import java.awt.Graphics2D;
    import java.awt.FontMetrics;
    import java.awt.Color;
    import java.awt.BasicStroke;
    
    tjc's avatar
    tjc committed
    
    /**
     *  The BaseAlgorithm class is the base class for algorithms that work
     *  directly on bases.  A BaseAlgorithm has a name and is specific to one
     *  Strand of DNA, meaning the algorithm can't change strand part way along.
     *
     *  @author Kim Rutherford
    
     *  @version $Id: BaseAlgorithm.java,v 1.9 2009-06-26 15:52:48 tjc Exp $
    
    tjc's avatar
    tjc committed
     **/
    
    
    public abstract class BaseAlgorithm extends Algorithm 
    {
      private Strand strand;
    
    
    tjc's avatar
    tjc committed
      /**
       *  Create a new BaseAlgorithm object.
       *  @param strand The strand to do the calculation on.
       *  @param algorithm_name A String used to identify this algorithm to the
       *    user.
       *  @param algorithm_short_name A String used to identify this algorithm
       *    internally.  See the Algorithm constructor for more details.
       **/
      public BaseAlgorithm (final Strand strand, final String algorithm_name,
    
                            final String algorithm_short_name) 
      {
    
    tjc's avatar
    tjc committed
        super (algorithm_name, algorithm_short_name);
    
        this.bases = strand.getBases();
        this.strand = strand;
    
    tjc's avatar
    tjc committed
    
        if (strand.isForwardStrand ()) {
          forward_flag = true;
        } else {
          forward_flag = false;
        }
      }
    
      /**
       *  Return the Bases object of the Strand that was passed to the
       *  constructor.
       **/
      public Bases getBases () {
        return bases;
      }
    
      /**
       *  Returns the strand we will do the calculation on.
       **/
      public Strand getStrand () {
        if (forward_flag ^ rev_comp_display) {
          return getBases ().getForwardStrand ();
        } else {
          return getBases ().getReverseStrand ();
        }
      }
      
      /**
       *  If rev_comp_display is true all calculations will be performs on the
       *  opposite Strand to the strand that was passed to the constructor.
       **/
      public void setRevCompDisplay (final boolean rev_comp_display) {
        this.rev_comp_display = rev_comp_display;
      }
    
      /**
       *  Returns true if the FeatureDisplay is reverse complemented.  All
       *  calculations should be performed on the opposite Strand to the strand
       *  that was passed to the constructor.
       **/
      public boolean isRevCompDisplay () {
        return rev_comp_display;
      }
    
    
    
      /**
      *  Draw in a legend
      */
      public void drawLegend(Graphics g, int font_height,
    
                             int font_width, LineAttributes[] lines,
    
      {
        Graphics2D g2d = (Graphics2D)g;
    
        FontMetrics fm = g2d.getFontMetrics();
        int lineHgt    = 3 * font_height/4; 
    
    
        if( (strand.isForwardStrand() && !isRevCompDisplay()) ||
            (!strand.isForwardStrand() && isRevCompDisplay()))
    
        {     
          for(int i=0; i<numPlots; i++)
          {
            g2d.setColor(Color.black);
            g2d.drawString(Integer.toString(i+1),i*5*font_width,font_height);
            
            BasicStroke stroke = (BasicStroke)g2d.getStroke();
            g2d.setStroke(new BasicStroke(3.f));
    
            g2d.setColor(lines[i].getLineColour());
    
            g2d.drawLine(font_width*(2 + (i*5)), lineHgt, font_width*(4 + (i*5)), lineHgt);
            g2d.setStroke(stroke);
          }
    
          
          /*
          int frame = strand.getSequenceLength() % 3;
    
          g2d.setColor(Color.black);
    
    tjc's avatar
    tjc committed
          g2d.drawString("4",0,font_height);
          g2d.drawString("5",font_width*5,font_height);
          g2d.drawString("6",font_width*10,font_height);
    
    
          BasicStroke stroke = (BasicStroke)g2d.getStroke();
          g2d.setStroke(new BasicStroke(3.f));
    
    tjc's avatar
    tjc committed
          g2d.setColor(frameColour[0]);
          g2d.drawLine(font_width*2, lineHgt, font_width*4, lineHgt);
    
    tjc's avatar
    tjc committed
          g2d.setColor(frameColour[2]);
          g2d.drawLine(font_width*7, lineHgt, font_width*9, lineHgt);
    
          g2d.setColor(frameColour[1]);
          g2d.drawLine(font_width*12, lineHgt, font_width*14, lineHgt);
    
          g2d.setStroke(stroke);
          */
          
          g2d.setColor(Color.black);
          g2d.drawString("4",0,font_height);
          g2d.drawString("5",font_width*5,font_height);
          g2d.drawString("6",font_width*10,font_height);
    
          BasicStroke stroke = (BasicStroke)g2d.getStroke();
          g2d.setStroke(new BasicStroke(3.f));
          int frame = strand.getSequenceLength() % 3;
          
          //System.out.println("FRAME "+frame+"  length="+strand.getSequenceLength());
          Color col4 = null;
          Color col5 = null;
          Color col6 = null;
           
          switch(frame)
          {
             case 0:
    
               col4 = lines[1].getLineColour();
               col5 = lines[2].getLineColour();
               col6 = lines[0].getLineColour();
    
               col4 = lines[2].getLineColour();
               col5 = lines[0].getLineColour();
               col6 = lines[1].getLineColour();
    
               col4 = lines[0].getLineColour();
               col5 = lines[1].getLineColour();
               col6 = lines[2].getLineColour();
    
               break;
          }
        
          g2d.setColor(col4);
          g2d.drawLine(font_width*2, lineHgt, font_width*4, lineHgt);
      
          g2d.setColor(col5);
          g2d.drawLine(font_width*7, lineHgt, font_width*9, lineHgt);
    
          g2d.setColor(col6);
          g2d.drawLine(font_width*12, lineHgt, font_width*14, lineHgt);
    
    tjc's avatar
    tjc committed
          g2d.setStroke(stroke);
    
    tjc's avatar
    tjc committed
      /**
       *  Return the value of the function between a pair of bases.
       *  @param start The start base (included in the range).
       *  @param end The end base (included in the range).
       *  @param values The results are returned in this array, hence it should be
       *    allocated at the size given by getValueCount ().
       **/
      public abstract void getValues (int start, int end, final float [] values);
    
      /**
       *  Return the number of values a call to getValues () will return.
       **/
      public abstract int getValueCount ();
      
      /**
       *  The Bases we will do the calculation on.
       **/
      private Bases bases;
    
      /**
       *  If rev_comp_display is true all calculations will be performed on the
       *  opposite Strand to the strand that was passed to the constructor.
       **/
      private boolean rev_comp_display = false;
    
      /**
       *  true if and only if the calculations should be done on the forward
       *  Strand.
       **/
      private boolean forward_flag;
    }