org.jfree.ui.FloatingButtonEnabler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jtstand-common Show documentation
Show all versions of jtstand-common Show documentation
jtstand-common is a library derived from jcommon, used by jtstand-chart, which is derived from jfreechart
/*
* Copyright (c) 2009 Albert Kurucz.
*
* This file, FloatingButtonEnabler.java is part of JTStand.
*
* JTStand is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* JTStand is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with GTStand. If not, see .
*/
package org.jfree.ui;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javax.swing.AbstractButton;
/**
* Enables a button to have a simple floating effect. The border of the button is only visible,
* when the mouse pointer is floating over the button.
*
* @author Thomas Morgner
*/
public final class FloatingButtonEnabler extends MouseAdapter {
/** A single instance. */
private static FloatingButtonEnabler singleton;
/**
* Default constructor.
*/
private FloatingButtonEnabler() {
// nothing required
}
/**
* Returns a default instance of this enabler.
*
* @return a shared instance of this class.
*/
public static FloatingButtonEnabler getInstance() {
if (singleton == null) {
singleton = new FloatingButtonEnabler();
}
return singleton;
}
/**
* Adds a button to this enabler.
*
* @param button the button.
*/
public void addButton(final AbstractButton button) {
button.addMouseListener(this);
button.setBorderPainted(false);
}
/**
* Removes a button from the enabler.
*
* @param button the button.
*/
public void removeButton(final AbstractButton button) {
button.addMouseListener(this);
button.setBorderPainted(true);
}
/**
* Triggers the drawing of the border when the mouse entered the button area.
*
* @param e the mouse event.
*/
public void mouseEntered(final MouseEvent e) {
if (e.getSource() instanceof AbstractButton) {
final AbstractButton button = (AbstractButton) e.getSource();
if (button.isEnabled()) {
button.setBorderPainted(true);
}
}
}
/**
* Disables the drawing of the border when the mouse leaves the button area.
*
* @param e the mouse event.
*/
public void mouseExited(final MouseEvent e) {
if (e.getSource() instanceof AbstractButton) {
final AbstractButton button = (AbstractButton) e.getSource();
button.setBorderPainted(false);
if (button.getParent() != null)
{
// button.getParent().repaint(button.getX(), button.getY(),
// button.getWidth(), button.getHeight());
button.getParent().repaint();
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy