findSeq in SeqPanel is used
authoramwaterhouse <Andrew Waterhouse>
Fri, 28 Jul 2006 16:06:33 +0000 (16:06 +0000)
committeramwaterhouse <Andrew Waterhouse>
Fri, 28 Jul 2006 16:06:33 +0000 (16:06 +0000)
src/jalview/gui/IdPanel.java
src/jalview/gui/SeqPanel.java

index f5e0f2f..47f43d5 100755 (executable)
@@ -69,15 +69,8 @@ public class IdPanel extends JPanel implements MouseListener,
      */\r
     public void mouseMoved(MouseEvent e)\r
     {\r
-      int y = e.getY();\r
-\r
-      if (av.getWrapAlignment())\r
-      {\r
-        y = getWrappedY(y);\r
-      }\r
-\r
-      final int seq = av.getIndex(y);\r
-      if(seq!=-1)\r
+      int seq = Math.max(0, alignPanel.seqPanel.findSeq(e));\r
+      if(seq>-1 && seq<av.alignment.getHeight())\r
       {\r
         SequenceI sequence = av.alignment.getSequenceAt(seq);\r
         StringBuffer tip = new StringBuffer("<html>");\r
@@ -122,16 +115,6 @@ public class IdPanel extends JPanel implements MouseListener,
     }\r
 \r
 \r
-    int getWrappedY(int y)\r
-    {\r
-      int hgap = av.charHeight;\r
-      if (av.scaleAboveWrapped)\r
-        hgap += av.charHeight;\r
-\r
-      return y - hgap;\r
-    }\r
-\r
-\r
     /**\r
      * DOCUMENT ME!\r
      *\r
@@ -141,19 +124,7 @@ public class IdPanel extends JPanel implements MouseListener,
     {\r
         mouseDragging = true;\r
 \r
-        int y = e.getY();\r
-\r
-        if (av.getWrapAlignment())\r
-        {\r
-            y = getWrappedY(y);\r
-        }\r
-\r
-        int seq = av.getIndex(y);\r
-\r
-        if (seq < 0)\r
-        {\r
-            return;\r
-        }\r
+        int seq = Math.max(0, alignPanel.seqPanel.findSeq(e));\r
 \r
         if (seq < lastid)\r
         {\r
@@ -183,17 +154,9 @@ public class IdPanel extends JPanel implements MouseListener,
       if (links == null || links.size() < 1)\r
         return;\r
 \r
-      int y = e.getY();\r
-\r
-      if (av.getWrapAlignment())\r
-      {\r
-         y = getWrappedY(y);\r
-      }\r
+      int seq = alignPanel.seqPanel.findSeq(e);\r
 \r
       //DEFAULT LINK IS FIRST IN THE LINK LIST\r
-      int seq = av.getIndex(y);\r
-      if(seq==-1)\r
-        return;\r
 \r
       String id = av.getAlignment().getSequenceAt(seq).getName();\r
       if (id.indexOf("|") > -1)\r
@@ -269,49 +232,20 @@ public class IdPanel extends JPanel implements MouseListener,
             return;\r
         }\r
 \r
-        int y = e.getY();\r
-\r
-        if (av.getWrapAlignment())\r
-        {\r
-            y = getWrappedY(y);\r
-        }\r
-\r
-        int seq = av.getIndex(y);\r
+        int seq = alignPanel.seqPanel.findSeq(e);\r
 \r
-        if (seq == -1)\r
-        {\r
-            return;\r
-        }\r
 \r
         if (javax.swing.SwingUtilities.isRightMouseButton(e))\r
         {\r
             jalview.gui.PopupMenu pop = new jalview.gui.PopupMenu(alignPanel,\r
                     (Sequence) av.getAlignment().getSequenceAt(seq),\r
                     Preferences.sequenceURLLinks);\r
-            pop.show(this, e.getX(), y);\r
+            pop.show(this, e.getX(), e.getY());\r
 \r
             return;\r
         }\r
 \r
-      /*  if (!e.isControlDown() && !e.isShiftDown() &&\r
-                (av.alignment.findGroup(av.alignment.getSequenceAt(seq)) != null))\r
-        {\r
-          System.out.println("no modifiers");\r
-            SequenceGroup selection = new SequenceGroup();\r
-            SequenceGroup sg = av.alignment.findGroup(av.alignment.getSequenceAt(\r
-                        seq));\r
-            selection.setStartRes(0);\r
-            selection.setEndRes(av.alignment.getWidth() - 1);\r
-\r
-            for (int i = 0; i < sg.getSize(); i++)\r
-            {\r
-                selection.addSequence(sg.getSequenceAt(i), true);\r
-            }\r
-\r
-            av.setSelectionGroup(selection);\r
 \r
-            return;\r
-        }*/\r
 \r
         if ((av.getSelectionGroup() == null) ||\r
                 ((!e.isControlDown() && !e.isShiftDown()) && av.getSelectionGroup() != null))\r
@@ -322,7 +256,6 @@ public class IdPanel extends JPanel implements MouseListener,
         }\r
 \r
 \r
-\r
         if (e.isShiftDown() && (lastid != -1))\r
         {\r
             selectSeqs(lastid, seq);\r
index 9ea087e..d47d89d 100755 (executable)
@@ -147,7 +147,6 @@ public class SeqPanel extends JPanel implements MouseListener,
 \r
    int findSeq(MouseEvent evt)\r
    {\r
-\r
      int seq = 0;\r
      int y = evt.getY();\r
 \r
@@ -162,11 +161,13 @@ public class SeqPanel extends JPanel implements MouseListener,
 \r
          y -= hgap;\r
 \r
-       seq = ( (y % cHeight) / av.getCharHeight());\r
+       seq = Math.min( (y % cHeight) / av.getCharHeight(),\r
+                       av.alignment.getHeight() -1);\r
      }\r
      else\r
      {\r
-       seq = (y / av.getCharHeight()) + av.getStartSeq();\r
+       seq = Math.min( (y / av.getCharHeight()) + av.getStartSeq(),\r
+                       av.alignment.getHeight() -1);\r
      }\r
 \r
      return seq;\r
@@ -1373,11 +1374,6 @@ public class SeqPanel extends JPanel implements MouseListener,
             return;\r
        }\r
 \r
-\r
-        if(y > av.alignment.getHeight())\r
-        {\r
-          y = av.alignment.getHeight() -1;\r
-        }\r
         if(res> av.alignment.getWidth())\r
         {\r
           res = av.alignment.getWidth()-1;\r