All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jidesoft.swing.JideButton Maven / Gradle / Ivy

/*
 * @(#)JideButton.java
 *
 * Copyright 2002-2003 JIDE Software Inc. All rights reserved.
 */
package com.jidesoft.swing;

import com.jidesoft.plaf.LookAndFeelFactory;
import com.jidesoft.plaf.UIDefaultsLookup;
import com.jidesoft.plaf.basic.ThemePainter;
import com.jidesoft.utils.ColorUtils;

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

/**
 * JideButton is a replacement for JButton when it is used on toolbar (or command bar in the case of JIDE Action
 * Framework).
 */
public class JideButton extends JButton implements Alignable, ButtonStyle, ComponentStateSupport, AlignmentSupport {

    private static final String uiClassID = "JideButtonUI";

    /**
     * Bound property name for always show hyperlink property.
     */
    public static final String PROPERTY_ALWAYS_SHOW_HYPERLINK = "alwaysShowHyperlink";

    private boolean _alwaysShowHyperlink = false;

    private int _buttonStyle = TOOLBAR_STYLE;
    private Cursor _savedCursor;

    /**
     * By default, if a JideButton is added to a popup menu, clicking on the button will dismiss the popup menu. However
     * if you change the default behavior, you can use this client property and set it to Boolean.FALSE.
     */
    public static final String CLIENT_PROPERTY_HIDE_POPUPMENU = "JideButton.hidePopupMenu";

    /**
     * Creates a button with no set text or icon.
     */
    public JideButton() {
        this(null, null);
    }

    /**
     * Creates a button with an icon.
     *
     * @param icon the Icon image to display on the button
     */
    public JideButton(Icon icon) {
        this(null, icon);
    }

    /**
     * Creates a button with text.
     *
     * @param text the text of the button
     */
    public JideButton(String text) {
        this(text, null);
    }

    /**
     * Creates a button where properties are taken from the Action supplied.
     *
     * @param a the Action used to specify the new button
     * @since 1.3
     */
    public JideButton(Action a) {
        this();
        setAction(a);
    }

    /**
     * Creates a button with initial text and an icon.
     *
     * @param text the text of the button
     * @param icon the Icon image to display on the button
     */
    public JideButton(String text, Icon icon) {
        // Create the model
        setModel(new DefaultButtonModel());
        // initialize
        init(text, icon);
        setRolloverEnabled(true);
        setFocusable(true);
        setRequestFocusEnabled(false);
    }

    /**
     * Resets the UI property to a value from the current look and feel.
     *
     * @see JComponent#updateUI
     */
    @Override
    public void updateUI() {
        if (UIDefaultsLookup.get(uiClassID) == null) {
            LookAndFeelFactory.installJideExtension();
        }
        setUI(UIManager.getUI(this));
    }


    /**
     * Returns a string that specifies the name of the L&F class that renders this component.
     *
     * @return the string "ButtonUI"
     *
     * @see JComponent#getUIClassID
     * @see UIDefaults#getUI
     */
    @Override
    public String getUIClassID() {
        return uiClassID;
    }

    private int _orientation;

    /**
     * The button orientation.
     *
     * @return the orientation.
     */
    public int getOrientation() {
        return _orientation;
    }

    public void setOrientation(int orientation) {
        if (_orientation != orientation) {
            int old = _orientation;
            _orientation = orientation;
            firePropertyChange(PROPERTY_ORIENTATION, old, orientation);
        }
    }

    /**
     * return true if it supports vertical orientation.
     *
     * @return true if it supports vertical orientation
     */
    public boolean supportVerticalOrientation() {
        return true;
    }

    /**
     * return true if it supports horizontal orientation.
     *
     * @return true if it supports horizontal orientation
     */
    public boolean supportHorizontalOrientation() {
        return true;
    }

    /**
     * Gets the button style.
     *
     * @return the button style.
     */
    public int getButtonStyle() {
        return _buttonStyle;
    }

    /**
     * Sets the button style.
     *
     * @param buttonStyle one of the following values: {@link #TOOLBAR_STYLE} (default), {@link #TOOLBOX_STYLE}, {@link
     *                    #FLAT_STYLE} and {@link #HYPERLINK_STYLE}.
     */
    public void setButtonStyle(int buttonStyle) {
        if (buttonStyle < 0 || buttonStyle > HYPERLINK_STYLE) {
            throw new IllegalArgumentException("Only TOOLBAR_STYLE, TOOLBOX_STYLE, FLAT_STYLE and HYPERLINK_STYLE are supported");
        }
        if (buttonStyle == _buttonStyle)
            return;

        int oldStyle = _buttonStyle;
        _buttonStyle = buttonStyle;

        configureCursor();
        firePropertyChange(BUTTON_STYLE_PROPERTY, oldStyle, _buttonStyle);
    }

    private void configureCursor() {
        if (getButtonStyle() == HYPERLINK_STYLE
                && isRolloverEnabled()
                && ((getText() != null && getText().length() > 0) || getIcon() != null)) {
            _savedCursor = getCursor();
            setCursor(Cursor.getPredefinedCursor(Cursor.HAND_CURSOR));
        }
        else {
            if (_savedCursor != null) {
                setCursor(_savedCursor);
                _savedCursor = null;
            }
        }
    }

    @Override
    public void setRolloverEnabled(boolean b) {
        super.setRolloverEnabled(b);
        configureCursor();
    }

    @Override
    public void setText(String text) {
        super.setText(text);
        configureCursor();
    }

    @Override
    public void setIcon(Icon defaultIcon) {
        super.setIcon(defaultIcon);
        configureCursor();
    }

    /**
     * Checks the alwaysShowHyperlink property value.
     *
     * @return true if the hyperlink is always visible. False if the hyperlink will be visible only when mouse rolls
     *         over.
     */
    public boolean isAlwaysShowHyperlink() {
        return _alwaysShowHyperlink;
    }

    /**
     * Sets the property if hyperlink (the underline) should be visible all the time. By default the hyperlink is
     * visible when mouse is over the button. If set to true, the hyperlink will always be visible.
     * 

* Please notes, this is an option only available when button style is set to HYPERLINK_STYLE. * * @param alwaysShowHyperlink a boolean value. True means the button will always show hyperlink. False means it will * show hyperlink only when mouse is over the button. */ public void setAlwaysShowHyperlink(boolean alwaysShowHyperlink) { if (_alwaysShowHyperlink != alwaysShowHyperlink) { boolean old = _alwaysShowHyperlink; _alwaysShowHyperlink = alwaysShowHyperlink; firePropertyChange(PROPERTY_ALWAYS_SHOW_HYPERLINK, old, alwaysShowHyperlink); } } private Color _defaultForeground; private Color _rolloverBackground; private Color _selectedBackground; private Color _pressedBackground; private Color _rolloverForeground; private Color _selectedForeground; private Color _pressedForeground; public Color getDefaultForeground() { return _defaultForeground; } public void setDefaultForeground(Color defaultForeground) { _defaultForeground = defaultForeground; } private Color getRolloverBackground() { return _rolloverBackground; } private void setRolloverBackground(Color rolloverBackground) { _rolloverBackground = rolloverBackground; } private Color getSelectedBackground() { return _selectedBackground; } private void setSelectedBackground(Color selectedBackground) { _selectedBackground = selectedBackground; } private Color getPressedBackground() { return _pressedBackground; } private void setPressedBackground(Color pressedBackground) { _pressedBackground = pressedBackground; } private Color getRolloverForeground() { return _rolloverForeground; } private void setRolloverForeground(Color rolloverForeground) { _rolloverForeground = rolloverForeground; } private Color getSelectedForeground() { return _selectedForeground; } private void setSelectedForeground(Color selectedForeground) { _selectedForeground = selectedForeground; } private Color getPressedForeground() { return _pressedForeground; } private void setPressedForeground(Color pressedForeground) { _pressedForeground = pressedForeground; } /** * Gets the background for different states. The states are defined in ThemePainter as constants. Not all states are * supported by all components. If the state is not supported or background is never set, it will return null. *

* Please note, each L&F will have its own way to paint the different backgrounds. This method allows you to * customize it for each component to use a different background. So if you want the background to be used, don't * use a ColorUIResource because UIResource is considered as a setting set by the L&F and any L&F can choose to * ignore it. * * @param state the button state. Valid values are ThemePainter.STATE_DEFAULT, ThemePainter.STATE_ROLLOVER, * ThemePainter.STATE_SELECTED and ThemePainter.STATE_PRESSED. * @return the background for different states. */ public Color getBackgroundOfState(int state) { switch (state) { case ThemePainter.STATE_DEFAULT: return getBackground(); case ThemePainter.STATE_ROLLOVER: return getRolloverBackground(); case ThemePainter.STATE_SELECTED: return getSelectedBackground(); case ThemePainter.STATE_DISABLE_SELECTED: Color background = getSelectedBackground(); return background != null ? ColorUtils.toGrayscale(background) : background; case ThemePainter.STATE_PRESSED: return getPressedBackground(); } return null; } /** * Sets the background for different states. The states are defined in ThemePainter as constants. Not all states * are supported by all components. If the state is not supported or background is never set, it will return null. *

* Please note, each L&F will have its own way to paint the different backgrounds. This method allows you to * customize it for each component to use a different background. So if you want the background to be used, don't * use a ColorUIResource because UIResource is considered as a setting set by the L&F and any L&F can choose to * ignore it. * * @param state the button state. Valid values are ThemePainter.STATE_DEFAULT, ThemePainter.STATE_ROLLOVER, * ThemePainter.STATE_SELECTED and ThemePainter.STATE_PRESSED. * @param color the new background for the state. */ public void setBackgroundOfState(int state, Color color) { switch (state) { case ThemePainter.STATE_DEFAULT: setBackground(color); break; case ThemePainter.STATE_ROLLOVER: setRolloverBackground(color); break; case ThemePainter.STATE_SELECTED: setSelectedBackground(color); break; case ThemePainter.STATE_PRESSED: setPressedBackground(color); break; } } /** * Gets the foreground for different states. The states are defined in ThemePainter as constants. Not all states are * supported by all components. If the state is not supported or foreground is never set, it will return null. *

* Please note, each L&F will have its own way to paint the different foregrounds. This method allows you to * customize it for each component to use a different foreground. So if you want the foreground to be used, don't * use a ColorUIResource because UIResource is considered as a setting set by the L&F and any L&F can choose to * ignore it. * * @param state the button state. Valid values are ThemePainter.STATE_DEFAULT, ThemePainter.STATE_ROLLOVER, * ThemePainter.STATE_SELECTED and ThemePainter.STATE_PRESSED. * @return the foreground for different states. */ public Color getForegroundOfState(int state) { switch (state) { case ThemePainter.STATE_DEFAULT: return getDefaultForeground(); case ThemePainter.STATE_ROLLOVER: return getRolloverForeground(); case ThemePainter.STATE_SELECTED: return getSelectedForeground(); case ThemePainter.STATE_PRESSED: return getPressedForeground(); } return null; } /** * Sets the foreground for different states. The states are defined in ThemePainter as constants. Not all states * are supported by all components. If the state is not supported or foreground is never set, it will return null. *

* Please note, each L&F will have its own way to paint the different foregrounds. This method allows you to * customize it for each component to use a different foreground. So if you want the foreground to be used, don't * use a ColorUIResource because UIResource is considered as a setting set by the L&F and any L&F can choose to * ignore it. * * @param state the button state. Valid values are ThemePainter.STATE_DEFAULT, ThemePainter.STATE_ROLLOVER, * ThemePainter.STATE_SELECTED and ThemePainter.STATE_PRESSED. * @param color the new foreground for the state. */ public void setForegroundOfState(int state, Color color) { switch (state) { case ThemePainter.STATE_DEFAULT: setDefaultForeground(color); break; case ThemePainter.STATE_ROLLOVER: setRolloverForeground(color); break; case ThemePainter.STATE_SELECTED: setSelectedForeground(color); break; case ThemePainter.STATE_PRESSED: setPressedForeground(color); break; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy