X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FIdwidthAdjuster.java;h=eef5bfb0866d126684bdfb6b8a15c87fc22e7969;hb=bab8878fb12f99051cdc622fe6a9767b3109bc70;hp=99792c6a2167b19677813a9d13d1d640f4e502c9;hpb=673150e058ad2a7649093c0c4afde99e1ac5e6e3;p=jalview.git diff --git a/src/jalview/gui/IdwidthAdjuster.java b/src/jalview/gui/IdwidthAdjuster.java index 99792c6..eef5bfb 100755 --- a/src/jalview/gui/IdwidthAdjuster.java +++ b/src/jalview/gui/IdwidthAdjuster.java @@ -20,18 +20,17 @@ */ package jalview.gui; -import jalview.api.AlignViewportI; - import java.awt.Color; import java.awt.Cursor; import java.awt.Graphics; -import java.awt.Image; import java.awt.event.MouseEvent; import java.awt.event.MouseListener; import java.awt.event.MouseMotionListener; import javax.swing.JPanel; +import jalview.api.AlignViewportI; + /** * DOCUMENT ME! * @@ -41,14 +40,14 @@ import javax.swing.JPanel; public class IdwidthAdjuster extends JPanel implements MouseListener, MouseMotionListener { - boolean active = false; + public static final int MIN_ID_WIDTH = 20; int oldX = 0; - Image image; - AlignmentPanel ap; + private boolean manuallyAdjusted = false; + /** * Creates a new IdwidthAdjuster object. * @@ -58,23 +57,15 @@ public class IdwidthAdjuster extends JPanel public IdwidthAdjuster(AlignmentPanel ap) { this.ap = ap; - - java.net.URL url = getClass().getResource("/images/idwidth.gif"); - - if (url != null) - { - image = java.awt.Toolkit.getDefaultToolkit().createImage(url); - } - + setBackground(Color.white); addMouseListener(this); addMouseMotionListener(this); } /** - * DOCUMENT ME! + * Action on mouse pressed is to save the start position for any drag * * @param evt - * DOCUMENT ME! */ @Override public void mousePressed(MouseEvent evt) @@ -83,129 +74,122 @@ public class IdwidthAdjuster extends JPanel } /** - * DOCUMENT ME! + * On release of mouse drag to resize the width, if there is a complementary + * alignment in a split frame, sets the complement to the same id width and + * repaints the split frame. Note this is done whether or not the protein + * characters are scaled to codon width. * * @param evt - * DOCUMENT ME! */ @Override public void mouseReleased(MouseEvent evt) { - active = false; repaint(); /* - * If in a SplitFrame with co-scaled alignments, set the other's id width to - * match + * If in a SplitFrame, set the other's id width to match */ final AlignViewportI viewport = ap.getAlignViewport(); - if (viewport.getCodingComplement() != null - && viewport.isScaleProteinAsCdna()) + if (viewport.getCodingComplement() != null) { viewport.getCodingComplement().setIdWidth(viewport.getIdWidth()); SplitFrame sf = (SplitFrame) ap.alignFrame.getSplitViewContainer(); sf.repaint(); } - } /** - * DOCUMENT ME! + * When this region is entered, repaints to show a left-right move cursor * * @param evt - * DOCUMENT ME! */ @Override public void mouseEntered(MouseEvent evt) { - active = true; repaint(); } - /** - * DOCUMENT ME! - * - * @param evt - * DOCUMENT ME! - */ @Override public void mouseExited(MouseEvent evt) { - active = false; - repaint(); } /** - * DOCUMENT ME! + * Adjusts the id panel width for a mouse drag left or right (subject to a + * minimum of 20 pixels) and repaints the alignment * * @param evt - * DOCUMENT ME! */ @Override public void mouseDragged(MouseEvent evt) { - active = true; - + int mouseX = evt.getX(); final AlignViewportI viewport = ap.getAlignViewport(); int curwidth = viewport.getIdWidth(); - int dif = evt.getX() - oldX; + int dif = mouseX - oldX; final int newWidth = curwidth + dif; - if ((newWidth > 20) || (dif > 0)) - { - viewport.setIdWidth(newWidth); - ap.paintAlignment(true, false); + /* + * don't drag below minimum width + */ + if (newWidth < MIN_ID_WIDTH) + { + return; } oldX = evt.getX(); + + /* + * don't drag right if mouse is to the left of the region + */ + if (dif > 0 && mouseX < 0) + { + return; + } + viewport.setIdWidth(newWidth); + ap.validateAnnotationDimensions(false); + ap.paintAlignment(true, false); + + manuallyAdjusted = true; + } + + public void setWidth(int newWidth) + { + if (newWidth < MIN_ID_WIDTH) + { + return; + } + final AlignViewportI viewport = ap.getAlignViewport(); + viewport.setIdWidth(newWidth); + ap.paintAlignment(true, false); + } + + public boolean manuallyAdjusted() + { + return manuallyAdjusted; } - /** - * DOCUMENT ME! - * - * @param evt - * DOCUMENT ME! - */ @Override public void mouseMoved(MouseEvent evt) { } - /** - * DOCUMENT ME! - * - * @param evt - * DOCUMENT ME! - */ @Override public void mouseClicked(MouseEvent evt) { } /** - * DOCUMENT ME! + * Paints this region, showing a left-right move cursor if currently 'active' * * @param g - * DOCUMENT ME! */ @Override public void paintComponent(Graphics g) { g.setColor(Color.white); g.fillRect(0, 0, getWidth(), getHeight()); - - if (active) - { - if (image != null) - { - // g.drawImage(image, getWidth() - 20, 2, this); - setCursor(Cursor.getPredefinedCursor(Cursor.W_RESIZE_CURSOR)); - } - else - { - setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR)); - } - } + setCursor(Cursor.getPredefinedCursor(Cursor.W_RESIZE_CURSOR)); } }