org.apache.batik.swing.gvt.AbstractPanInteractor Maven / Gradle / Ivy
/*
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.apache.batik.swing.gvt;
import java.awt.Cursor;
import java.awt.event.MouseEvent;
import java.awt.geom.AffineTransform;
/**
* This class represents a pan interactor.
* To use it, just redefine the {@link
* InteractorAdapter#startInteraction(java.awt.event.InputEvent)} method.
*
* @author Stephane Hillion
* @version $Id: AbstractPanInteractor.java 1808975 2017-09-20 08:59:36Z ssteiner $
*/
public abstract class AbstractPanInteractor extends InteractorAdapter {
/**
* The cursor for panning.
*/
public static final Cursor PAN_CURSOR = new Cursor(Cursor.MOVE_CURSOR);
/**
* Whether the interactor has finished.
*/
protected boolean finished = true;
/**
* The mouse x start position.
*/
protected int xStart;
/**
* The mouse y start position.
*/
protected int yStart;
/**
* The mouse x current position.
*/
protected int xCurrent;
/**
* The mouse y current position.
*/
protected int yCurrent;
/**
* To store the previous cursor.
*/
protected Cursor previousCursor;
/**
* Tells whether the interactor has finished.
*/
public boolean endInteraction() {
return finished;
}
// MouseListener ///////////////////////////////////////////////////////
/**
* Invoked when a mouse button has been pressed on a component.
*/
public void mousePressed(MouseEvent e) {
if (!finished) {
mouseExited(e);
return;
}
finished = false;
xStart = e.getX();
yStart = e.getY();
JGVTComponent c = (JGVTComponent)e.getSource();
previousCursor = c.getCursor();
c.setCursor(PAN_CURSOR);
}
/**
* Invoked when a mouse button has been released on a component.
*/
public void mouseReleased(MouseEvent e) {
if (finished) {
return;
}
finished = true;
JGVTComponent c = (JGVTComponent)e.getSource();
xCurrent = e.getX();
yCurrent = e.getY();
AffineTransform at =
AffineTransform.getTranslateInstance(xCurrent - xStart,
yCurrent - yStart);
AffineTransform rt =
(AffineTransform)c.getRenderingTransform().clone();
rt.preConcatenate(at);
c.setRenderingTransform(rt);
if (c.getCursor() == PAN_CURSOR) {
c.setCursor(previousCursor);
}
}
/**
* Invoked when the mouse exits a component.
*/
public void mouseExited(MouseEvent e) {
finished = true;
JGVTComponent c = (JGVTComponent)e.getSource();
c.setPaintingTransform(null);
if (c.getCursor() == PAN_CURSOR) {
c.setCursor(previousCursor);
}
}
// MouseMotionListener /////////////////////////////////////////////////
/**
* Invoked when a mouse button is pressed on a component and then
* dragged. Mouse drag events will continue to be delivered to
* the component where the first originated until the mouse button is
* released (regardless of whether the mouse position is within the
* bounds of the component).
*/
public void mouseDragged(MouseEvent e) {
JGVTComponent c = (JGVTComponent)e.getSource();
xCurrent = e.getX();
yCurrent = e.getY();
AffineTransform at =
AffineTransform.getTranslateInstance(xCurrent - xStart,
yCurrent - yStart);
c.setPaintingTransform(at);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy