Java中关于MouseWheelListener的鼠标滚轮事件详解
这篇文章主要介绍了Java中关于MouseWheelListener的鼠标滚轮事件详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
目录
关于MouseWheelListener的鼠标滚轮事件
一、MouseWheelListener接口
二、public int getWheelRotation()
Java获取鼠标滚轮按下事件
判定滚轮按下,原始的方法如下
当然可以利用SwingUtilities
关于MouseWheelListener的鼠标滚轮事件
Java中JPanel面板中对鼠标滚轮事件的处理。
一、MouseWheelListener接口
MouseWheelListener接口中只有一个void mouseWheelMoved(MouseWheelEvent e)方法,此方法是在鼠标滚轮滚动的时候调用。所以要重写这个方法。
我们使用MouseWheelEvent此类中的public int getWheelRotation()方法。
二、public int getWheelRotation()
如果鼠标滚轮向上/远离用户旋转,则为负值,如果鼠标滚轮朝向用户向下旋转,则为正值
代码演示:
主要实现对JPanel容器,和JFrame窗口的放大和缩小。
这里采用的方法就是按钮滚轮的方式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | import java.awt.*; import javax.swing.*; import java.awt.event.*; public class MouseWheelListener01 extends JFrame implements MouseWheelListener{ public static void main(String[] args) { new MouseWheelListener01(); } int h = 300 ; int w = 300 ; JPanel j = new JPanel(); // 构造器 MouseWheelListener01(){ super ( "放缩滚轮" ); this .add(j); this .setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this .setSize(h,w); this .setVisible( true ); this .addMouseWheelListener( this ); // 添加鼠标滚轮事件 } //利用滚轮事件将窗口放大和缩小 public void mouseWheelMoved(MouseWheelEvent e) { // 如果鼠标滚轮向上旋转或远离用户,则为负值,如果鼠标滚轮向下旋转或朝向用户旋转,则为正值 if (e.getWheelRotation()== 1 ){ h = h + 15 ; w = w + 15 ; this .setSize(h,w); this .validate(); System.out.println( "滑轮向前。。。。" ); } if (e.getWheelRotation()==- 1 ){ h = h - 15 ; w = w - 15 ; this .setSize(h,w); this .validate(); System.out.println( "滑轮向后...." ); } } } |
Java获取鼠标滚轮按下事件
滚轮按下的事件和鼠标点击事件都在MouseListener里面
判定滚轮按下,原始的方法如下
1 2 3 4 5 6 | public void mouseClicked(MouseEvent e) { int modifiers = e.getModifiers(); if ((modifiers & InputEvent.BUTTON2_MASK) == InputEvent.BUTTON2_MASK){ System.out.println( "middle button click" ); } } |
当然可以利用SwingUtilities
1 2 3 4 5 | public void mouseClicked(MouseEvent e) { if (SwingUtilities.isMiddleMouseButton(e)){ System.out.println( "middle button click" ); } } |
以上为个人经验,希望能给大家一个参考
原文链接:https://blog.csdn.net/weixin_54963748/article/details/120326405