/*
- * Jalview - A Sequence Alignment Editor and Viewer (Version 2.5)
- * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7)
+ * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle
*
* This file is part of Jalview.
*
import java.awt.event.*;
import javax.swing.*;
+import jalview.api.RotatableCanvasI;
import jalview.datamodel.*;
import jalview.math.*;
* @version $Revision$
*/
public class RotatableCanvas extends JPanel implements MouseListener,
- MouseMotionListener, KeyListener
+ MouseMotionListener, KeyListener, RotatableCanvasI
{
RotatableMatrix idmat = new RotatableMatrix(3, 3);
repaint();
}
+ boolean first=true;
public void setPoints(Vector points, int npoint)
{
this.points = points;
this.npoint = npoint;
+ if (first) {
ToolTipManager.sharedInstance().registerComponent(this);
ToolTipManager.sharedInstance().setInitialDelay(0);
ToolTipManager.sharedInstance().setDismissDelay(10000);
-
+ }
prefsize = getPreferredSize();
orig = new float[npoint][3];
findWidth();
scale = findScale();
-
+ if (first) {
+
addMouseListener(this);
addMouseMotionListener(this);
-
+ }
+ first=false;
}
public void initAxes()
if (av.getSelectionGroup() != null)
{
- if (av.getSelectionGroup().getSequences(null).contains(
- ((SequencePoint) points.elementAt(i)).sequence))
+ if (av.getSelectionGroup().getSequences(null)
+ .contains(((SequencePoint) points.elementAt(i)).sequence))
{
g.setColor(Color.gray);
}
if (showLabels)
{
g.setColor(Color.red);
- g.drawString(((SequencePoint) points.elementAt(i)).sequence
- .getName(), x - 3, y - 4);
+ g.drawString(
+ ((SequencePoint) points.elementAt(i)).sequence.getName(),
+ x - 3, y - 4);
}
}
aps[a].av.setSelectionGroup(new SequenceGroup());
aps[a].av.getSelectionGroup().addOrRemove(found, true);
aps[a].av.getSelectionGroup().setEndRes(
- aps[a].av.alignment.getWidth() - 1);
+ aps[a].av.getAlignment().getWidth() - 1);
}
}
PaintRefresher.Refresh(this, av.getSequenceSetId());
{
if (av != null)
{
- if (!av.getSelectionGroup().getSequences(null).contains(
- sp.sequence))
+ if (!av.getSelectionGroup().getSequences(null)
+ .contains(sp.sequence))
{
av.getSelectionGroup().addSequence(sp.sequence, true);
}
{ ap };
}
}
+
+ /**
+ *
+ * @return x,y,z positions of point s (index into points) under current
+ * transform.
+ */
+ public double[] getPointPosition(int s)
+ {
+ double pts[] = new double[3];
+ float[] p = ((SequencePoint) points.elementAt(s)).coord;
+ pts[0] = p[0];
+ pts[1] = p[1];
+ pts[2] = p[2];
+ return pts;
+ }
+
}