Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-4280900

MOUSE_MOVED events between MOUSE_PRESSED and MOUSE_DRAGGED events

XMLWordPrintable

    • Icon: Bug Bug
    • Resolution: Cannot Reproduce
    • Icon: P4 P4
    • None
    • 1.1.8, 1.3.0
    • client-libs
    • sparc
    • solaris_7



      Name: krT82822 Date: 10/13/99


      10/13/99 eval1127@eng -- our mouse-movement sensitivity is high, and the (distance) tolerance low. Given this source code example, it's pretty easy to avoid
      the intervening mouseMoved events. However, "normal" human hands are likely to move the mouse a bit "before" the beginning of the drag is detected.
      Thus, the "mouse moved" events.

      I'm not sure what we can do about this, but this has been the subject of a few recent reports (citing older bugs), so am filing a new reference bug for consideration.

      This report was filed against 1.1.8, but the behavior is identical in 1.3.0 build "I" (a/k/a kestrel RA release).

      ------------

      import javax.swing.*;
      import java.awt.event.*;

      /**
       * The following bug was observed on Solaris and hp-ux with jdk1.1.8 and swing swing-1.1.1fcs, but not on Windows NT.
       * To reproduce: Start program,
       * press left or right mouse button in window and move the mouse immediately.
       * most likely one gets output like that
       * mouse pressed
       * mouse moved !!!!!! false
       * mouse moved !!!!!! false
       * mouse dragged
       * mouse dragged
       * mouse dragged and so on.
       *
       * This bug increases the possibility of an occurence of a popup freeze. Another bug which I submit separately.
       */
      public class EventTest
      {
          
          public static final void main ( String[] args ) {
             
             JFrame f = new JFrame();
             f.setSize(200,200);
             java.awt.Container c = f.getContentPane();
             c.addMouseListener(new MouseListener() {
      public void mouseEntered ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse entered");
                 }
              
      public void mouseExited ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse exited");
      }
       
      public void mouseClicked ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse clicked");
      }

      public void mousePressed ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse pressed");
      }
      public void mouseReleased ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse released");
      }

              });

              c.addMouseMotionListener(new MouseMotionListener() {
      public void mouseDragged ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse dragged");
                 }
              
      public void mouseMoved ( java.awt.event.MouseEvent e ) {
                     System.out.println("mouse moved");
      }
             });
            
             f.show();
          }
      }
      (Review ID: 96482)
      ======================================================================

      Name: rlT66838 Date: 11/11/99


      jdk1.1.8, swing-1.1.1.fcs
      This problem is related to bug 4280900, which I submitted a few weeks before.

      I do not have a source code for that, because the problem does not occur very
      often. Instead I describe the problem.

      Invoke the popup with right mouse button pressed (hold down), and drag ....

      When the first MOUSE_DRAGGED Event occurs, the mouseEventTarget will be set.
      It should be the invoker, but if you assume bug 4280900 there
      can be some MOUSE_MOVED events between the MOUSE_PRESSED and the first
      MOUSE_DRAGGED event. Therefore the mouseEventTarget can be something else
      than the invoker. In the worst case it is the JPopupMenu.
      Let's say one uses
         popup.show(invoker,event.getX(), event.getY());
      to show a popup, then it is pretty likely that the mouse pointer
      is at the edge of the popup, when the first MOUSE_DRAGGED event occur.
      In this case JPopupMenu will be the mouseEventTarget and then
      gets all the MOUSE_EVENTS. But the UI of the Popup does not grab the JPopupMenu.
      Therefore the UI is not updated, so that the popup looks like it is freezed.

      How to fix it?
      May be fix bug 4280900 or set the mouseEventTarget if the MOUSE_PRESSED
      arrives ....

      (Dragging makes it very complicated for popups. Why not shut of the
      dragging-mode during a popup is there. OK, the one is in AWT, the other in
      swing. Then add a little functionality to AWT :-) )
      (Review ID: 97404)
      ======================================================================

            ehawkessunw Eric Hawkes (Inactive)
            kryansunw Kevin Ryan (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            0 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: