*/
package jalview.gui;
+import jalview.api.AlignViewportI;
+
import java.awt.Color;
-import java.awt.Graphics;
-import java.awt.Image;
+import java.awt.Cursor;
+import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
-import java.awt.event.MouseListener;
-import java.awt.event.MouseMotionListener;
import javax.swing.JPanel;
* @author $author$
* @version $Revision$
*/
-public class IdwidthAdjuster extends JPanel implements MouseListener,
- MouseMotionListener
+@SuppressWarnings("serial")
+public class IdwidthAdjuster extends JPanel
{
- boolean active = false;
int oldX = 0;
- Image image;
-
- AlignmentPanel ap;
-
/**
- * Creates a new IdwidthAdjuster object.
+ * Creates a new IdwidthAdjuster object above the id panel that can be dragged
+ * to change the panel's width
*
* @param ap
- * DOCUMENT ME!
- */
- 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);
- }
-
- addMouseListener(this);
- addMouseMotionListener(this);
- }
-
- /**
- * DOCUMENT ME!
- *
- * @param evt
- * DOCUMENT ME!
- */
- public void mousePressed(MouseEvent evt)
- {
- oldX = evt.getX();
- }
-
- /**
- * DOCUMENT ME!
+ * The associated AlignmentPanel
*
- * @param evt
- * DOCUMENT ME!
*/
- public void mouseReleased(MouseEvent evt)
- {
- active = false;
- repaint();
- }
-
- /**
- * DOCUMENT ME!
- *
- * @param evt
- * DOCUMENT ME!
- */
- public void mouseEntered(MouseEvent evt)
+ public IdwidthAdjuster(AlignmentPanel ap)
{
- active = true;
- repaint();
- }
+ // BH 2019.07.01 no need for overridden paintComponent, especially as it was
+ // overriding paint(g) so
+ // allowing strange component painting in its place.
- /**
- * DOCUMENT ME!
- *
- * @param evt
- * DOCUMENT ME!
- */
- public void mouseExited(MouseEvent evt)
- {
- active = false;
- repaint();
- }
+ setBackground(Color.white);
+ setOpaque(true);
- /**
- * DOCUMENT ME!
- *
- * @param evt
- * DOCUMENT ME!
- */
- public void mouseDragged(MouseEvent evt)
- {
- active = true;
+ setCursor(Cursor.getPredefinedCursor(Cursor.W_RESIZE_CURSOR));
- int curwidth = ap.getAlignViewport().getIdWidth();
- int dif = evt.getX() - oldX;
+ // BH 2019.07.01 MouseAdapter is cleaner - no need for fields active or ap
- if (((curwidth + dif) > 20) || (dif > 0))
+ MouseAdapter ma = (new MouseAdapter()
{
- ap.getAlignViewport().setIdWidth(curwidth + dif);
-
- ap.paintAlignment(true);
- }
+ @Override
+ public void mousePressed(MouseEvent evt)
+ {
+ oldX = evt.getX();
+ }
- oldX = evt.getX();
- }
+ @Override
+ public void mouseDragged(MouseEvent evt)
+ {
+ AlignViewportI viewport = ap.getAlignViewport();
+ int curwidth = viewport.getIdWidth();
+ int dif = evt.getX() - oldX;
+ int newWidth = curwidth + dif;
+ if ((newWidth > 20) || (dif > 0))
+ {
+ viewport.setIdWidth(newWidth);
+ ap.paintAlignment(true, false);
+ }
+ oldX = evt.getX();
+ }
- /**
- * DOCUMENT ME!
- *
- * @param evt
- * DOCUMENT ME!
- */
- public void mouseMoved(MouseEvent evt)
- {
- }
+ @Override
+ public void mouseReleased(MouseEvent evt)
+ {
- /**
- * DOCUMENT ME!
- *
- * @param evt
- * DOCUMENT ME!
- */
- public void mouseClicked(MouseEvent evt)
- {
- }
+ // If in a SplitFrame with co-scaled alignments, set the other's id
+ // width to match
- /**
- * DOCUMENT ME!
- *
- * @param g
- * DOCUMENT ME!
- */
- public void paintComponent(Graphics g)
- {
- g.setColor(Color.white);
- g.fillRect(0, 0, getWidth(), getHeight());
+ AlignViewportI viewport = ap.getAlignViewport();
+ if (viewport.getCodingComplement() != null
+ && viewport.isScaleProteinAsCdna())
+ {
+ viewport.getCodingComplement().setIdWidth(viewport.getIdWidth());
+ SplitFrame sf = (SplitFrame) ap.alignFrame
+ .getSplitViewContainer();
+ sf.repaint();
+ }
- if (active)
- {
- if (image != null)
- {
- g.drawImage(image, getWidth() - 20, 2, this);
}
- }
+
+ });
+ addMouseListener(ma);
+ addMouseMotionListener(ma);
}
}