X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FAnnotationPanel.java;h=74505554f45fe802fc4677c2aee01cacd3d7105b;hb=37e1fa33b20cd2fb68cb7f72c15784897cb8a6b1;hp=04590ba816bfd0ea4b39c4aff3045110a86d24af;hpb=99e8c69c6a6f4ea5e63d61b40376bb98fb1ae9a7;p=jalview.git diff --git a/src/jalview/gui/AnnotationPanel.java b/src/jalview/gui/AnnotationPanel.java index 04590ba..7450555 100755 --- a/src/jalview/gui/AnnotationPanel.java +++ b/src/jalview/gui/AnnotationPanel.java @@ -49,6 +49,7 @@ import java.awt.event.MouseMotionListener; import java.awt.event.MouseWheelEvent; import java.awt.event.MouseWheelListener; import java.awt.image.BufferedImage; +import java.util.ArrayList; import java.util.Collections; import java.util.List; @@ -445,8 +446,12 @@ public class AnnotationPanel extends JPanel implements AwtRenderPanelI, StringBuilder collatedInput = new StringBuilder(64); String last = ""; ColumnSelection viscols = av.getColumnSelection(); - // TODO: refactor and save av.getColumnSelection for efficiency - List selected = viscols.getSelected(); + + /* + * the selection list (read-only view) is in selection order, not + * column order; make a copy so we can sort it + */ + List selected = new ArrayList(viscols.getSelected()); Collections.sort(selected); for (int index : selected) { @@ -543,7 +548,6 @@ public class AnnotationPanel extends JPanel implements AwtRenderPanelI, } ap.getScalePanel().mousePressed(evt); - } /** @@ -607,6 +611,10 @@ public class AnnotationPanel extends JPanel implements AwtRenderPanelI, mouseDragging = false; ap.getScalePanel().mouseReleased(evt); + /* + * isPopupTrigger is set in mouseReleased on Windows + * (in mousePressed on Mac) + */ if (evt.isPopupTrigger() && activeRow != -1) { showPopupMenu(evt.getY(), evt.getX());