鼠标拖拽组件移动的事件实现

在Swing中拖动一个组件或者图片,拖动图片和拖动组件是相同的道理,如果您打算拖动一个组件,只要给组件增加两个监听器就可以了。一个是addMouseListener(MouseListener l),另一个是:addMouseMotionListener(MouseMotionListener l) ;由于MouseListener和MouseMotionListener都继承同一个父类EventListener,所以我们给组件增加监听器时,只要增加同一个监听器就可以了。即: 

DragPicListener listener = new DragPicListener();
component.addMouseListener(listener);
component.addMouseMotionListener(listener);

对于监听器DragPicListener,我们 只要实现鼠标按下时的触发事件public void mousePressed(MouseEvent e);和鼠标拖动时的触发事件:public void mouseDragged(MouseEvent e) ,就可以完成组件的拖动了 。当鼠标按下时我们记录下鼠标的位置;当鼠标移动时,获得鼠标当前的位置,并把组件移动到当前位置。监听类程序如下: 

class DragPicListener extends MouseInputAdapter {
		/** 坐标点 */
		Point point = new Point(0, 0);

		/**
		 * 当鼠标拖动时触发该事件。 记录下鼠标按下(开始拖动)的位置。
		 */
		public void mouseDragged(MouseEvent e) {
			// 转换坐标系统
			Point newPoint = SwingUtilities.convertPoint(dragPicLabel, e
					.getPoint(), dragPicLabel.getParent());
			// 设置标签的新位置
			dragPicLabel.setLocation(dragPicLabel.getX()
					+ (newPoint.x - point.x), dragPicLabel.getY()
					+ (newPoint.y - point.y));
			// 更改坐标点
			point = newPoint;
		}

		/**
		 * 当鼠标按下时触发该事件。 记录下鼠标按下(开始拖动)的位置。
		 */
		public void mousePressed(MouseEvent e) {
			// 得到当前坐标点
			point = SwingUtilities.convertPoint(dragPicLabel, e.getPoint(),
					dragPicLabel.getParent());
		}
	}

这里还需要解释一下的是:SwingUtilities.convertPoint这个方法,

SwingUtilities类是Swing组件内部使用的实用工具,它提供了许多的涉及计算、转换、访问控制、布局等方面的方法。这里我们只讨论它的一个方法public static Point convertPoint(Component source,Point aPoint,Component destination) ;

public void mousePressed(MouseEvent event) {
			// 得到当前坐标点
			destPoint = SwingUtilities.convertPoint(dragPicLabel, event.getPoint(),
					dragPicLabel.getParent());
			// 点击source的左上角(图片上箭头指向),输出 0:0
			System.out.println(event.getPoint().x + " : " + event.getPoint().y);
			// 点击source的左上角(图片上箭头指向),输出 39 : 86
			System.out.println(destPoint.x + " : " + destPoint.y);
		}


SwingUtilities.convertPoint(Component source,Point aPoint,Component destination) 的目的就是将坐标系的原点从source转移到destination。根据原来的鼠标位置aPoint,获得坐标转以后的鼠标位置destPoint。这个方法在获得鼠标移动距离,画坐标系,划线时会经常用到。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值