nextapp.echo2.app.button.AbstractButton Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ibis-echo2 Show documentation
Show all versions of ibis-echo2 Show documentation
Echo2 bundled with Echo2_Extras, Echo2_FileTransfer and echopointing and various improvements/bugfixes
/*
* This file is part of the Echo Web Application Framework (hereinafter "Echo").
* Copyright (C) 2002-2009 NextApp, Inc.
*
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (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.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*/
package nextapp.echo2.app.button;
import java.util.EventListener;
import nextapp.echo2.app.Alignment;
import nextapp.echo2.app.Border;
import nextapp.echo2.app.Color;
import nextapp.echo2.app.Component;
import nextapp.echo2.app.Extent;
import nextapp.echo2.app.FillImage;
import nextapp.echo2.app.Font;
import nextapp.echo2.app.ImageReference;
import nextapp.echo2.app.Insets;
import nextapp.echo2.app.event.ActionEvent;
import nextapp.echo2.app.event.ActionListener;
/**
* An abstract base class for button components. Provides basic properties, a
* model, and event handling facilities.
*/
public abstract class AbstractButton extends Component {
public static final String ACTION_LISTENERS_CHANGED_PROPERTY = "actionListeners";
public static final String INPUT_CLICK = "input_click";
public static final String PROPERTY_BACKGROUND_IMAGE = "backgroundImage";
public static final String PROPERTY_BORDER = "border";
public static final String PROPERTY_DISABLED_BACKGROUND = "disabledBackground";
public static final String PROPERTY_DISABLED_BACKGROUND_IMAGE = "disabledBackgroundImage";
public static final String PROPERTY_DISABLED_BORDER = "disabledBorder";
public static final String PROPERTY_DISABLED_FONT = "disabledFont";
public static final String PROPERTY_DISABLED_FOREGROUND = "disabledForeground";
public static final String PROPERTY_DISABLED_ICON = "disabledIcon";
public static final String PROPERTY_HEIGHT = "height";
public static final String PROPERTY_ICON = "icon";
public static final String PROPERTY_ALIGNMENT = "alignment";
public static final String PROPERTY_ICON_TEXT_MARGIN = "iconTextMargin";
public static final String PROPERTY_INSETS = "insets";
public static final String PROPERTY_LINE_WRAP = "lineWrap";
public static final String PROPERTY_MODEL = "model";
public static final String PROPERTY_PRESSED_BACKGROUND = "pressedBackground";
public static final String PROPERTY_PRESSED_BACKGROUND_IMAGE = "pressedBackgroundImage";
public static final String PROPERTY_PRESSED_BORDER = "pressedBorder";
public static final String PROPERTY_PRESSED_ENABLED = "pressedEnabled";
public static final String PROPERTY_PRESSED_FONT = "pressedFont";
public static final String PROPERTY_PRESSED_FOREGROUND = "pressedForeground";
public static final String PROPERTY_PRESSED_ICON = "pressedIcon";
public static final String PROPERTY_ROLLOVER_BACKGROUND = "rolloverBackground";
public static final String PROPERTY_ROLLOVER_BACKGROUND_IMAGE = "rolloverBackgroundImage";
public static final String PROPERTY_ROLLOVER_BORDER = "rolloverBorder";
public static final String PROPERTY_ROLLOVER_ENABLED = "rolloverEnabled";
public static final String PROPERTY_ROLLOVER_FONT = "rolloverFont";
public static final String PROPERTY_ROLLOVER_FOREGROUND = "rolloverForeground";
public static final String PROPERTY_ROLLOVER_ICON = "rolloverIcon";
public static final String PROPERTY_TEXT = "text";
public static final String PROPERTY_TEXT_ALIGNMENT = "textAlignment";
public static final String PROPERTY_TEXT_POSITION = "textPosition";
public static final String PROPERTY_TOOL_TIP_TEXT = "toolTipText";
public static final String PROPERTY_WIDTH = "width";
/**
* Forwards events generated by the model to listeners registered with the
* component instance.
*/
private ActionListener actionForwarder = new ActionListener() {
/**
* @see nextapp.echo2.app.event.ActionListener#actionPerformed(nextapp.echo2.app.event.ActionEvent)
*/
public void actionPerformed(ActionEvent modelEvent) {
ActionEvent buttonEvent = new ActionEvent(AbstractButton.this, modelEvent.getActionCommand());
fireActionPerformed(buttonEvent);
}
};
/**
* Adds an ActionListener
to receive notification of user
* actions, i.e., button presses.
*
* @param l the listener to add
*/
public void addActionListener(ActionListener l) {
getEventListenerList().addListener(ActionListener.class, l);
// Notification of action listener changes is provided due to
// existence of hasActionListeners() method.
firePropertyChange(ACTION_LISTENERS_CHANGED_PROPERTY, null, l);
}
/**
* Programmatically performs a click/activation of the button.
*/
public void doAction() {
getModel().doAction();
}
/**
* Notifies all listeners that have registered for this event type.
*
* @param e the ActionEvent
to send
*/
public void fireActionPerformed(ActionEvent e) {
if (!hasEventListenerList()) {
return;
}
EventListener[] listeners = getEventListenerList().getListeners(ActionListener.class);
for (int index = 0; index < listeners.length; ++index) {
((ActionListener) listeners[index]).actionPerformed(e);
}
}
/**
* Retrieves the action command from the ButtonModel
.
*
* @return the action command
* @see nextapp.echo2.app.button.ButtonModel#getActionCommand()
*/
public String getActionCommand() {
return getModel().getActionCommand();
}
/**
* Returns the alignment of the button's content.
* Only horizontal alignments are supported.
*
* @return the alignment
*/
public Alignment getAlignment() {
return (Alignment) getProperty(PROPERTY_ALIGNMENT);
}
/**
* Returns the background image of the button.
*
* @return the background image
*/
public FillImage getBackgroundImage() {
return (FillImage) getProperty(PROPERTY_BACKGROUND_IMAGE);
}
/**
* Returns the border displayed around the button.
*
* @return the border
*/
public Border getBorder() {
return (Border) getProperty(PROPERTY_BORDER);
}
/**
* Returns the background color of the button when the button is disabled.
*
* @return the color
*/
public Color getDisabledBackground() {
return (Color) getProperty(PROPERTY_DISABLED_BACKGROUND);
}
/**
* Returns the background image displayed when the button is disabled.
*
* @return the background image
*/
public FillImage getDisabledBackgroundImage() {
return (FillImage) getProperty(PROPERTY_DISABLED_BACKGROUND_IMAGE);
}
/**
* Returns the border displayed around the button when the button is
* disabled.
*
* @return the border
*/
public Border getDisabledBorder() {
return (Border) getProperty(PROPERTY_DISABLED_BORDER);
}
/**
* Returns the font of the button when the button is disabled.
*
* @return the font
*/
public Font getDisabledFont() {
return (Font) getProperty(PROPERTY_DISABLED_FONT);
}
/**
* Returns the foreground color of the button when the button is disabled.
*
* @return the color
*/
public Color getDisabledForeground() {
return (Color) getProperty(PROPERTY_DISABLED_FOREGROUND);
}
/**
* Returns the icon of the button that is displayed when the button is
* disabled.
*
* @return the icon
*/
public ImageReference getDisabledIcon() {
return (ImageReference) getProperty(PROPERTY_DISABLED_ICON);
}
/**
* Returns the height of the button.
* This property only supports Extent
s with
* fixed (i.e., not percent) units.
*
* @return the height
*/
public Extent getHeight() {
return (Extent) getProperty(PROPERTY_HEIGHT);
}
/**
* Returns the icon displayed in the button.
*
* @return the icon
*/
public ImageReference getIcon() {
return (ImageReference) getProperty(PROPERTY_ICON);
}
/**
* Returns the margin size between the icon and the text.
* The margin will only be displayed if the button has both
* icon and text properties set.
* This property only supports Extent
s with
* fixed (i.e., not percent) units.
*
* @return the margin size
*/
public Extent getIconTextMargin() {
return (Extent) getProperty(PROPERTY_ICON_TEXT_MARGIN);
}
/**
* Returns the margin between the buttons edge and its content.
*
* @return the margin
*/
public Insets getInsets() {
return (Insets) getProperty(PROPERTY_INSETS);
}
/**
* Returns the model that this button represents.
*
* @return the model
*/
public ButtonModel getModel() {
return (ButtonModel) getProperty(PROPERTY_MODEL);
}
/**
* Returns the background color of the button when the button is pressed.
*
* @return the color
*/
public Color getPressedBackground() {
return (Color) getProperty(PROPERTY_PRESSED_BACKGROUND);
}
/**
* Returns the background image displayed when the button is pressed.
*
* @return the background image
*/
public FillImage getPressedBackgroundImage() {
return (FillImage) getProperty(PROPERTY_PRESSED_BACKGROUND_IMAGE);
}
/**
* Returns the border displayed around the button when the button is
* pressed.
*
* @return the border
*/
public Border getPressedBorder() {
return (Border) getProperty(PROPERTY_PRESSED_BORDER);
}
/**
* Returns the font of the button when the button is pressed.
*
* @return the font
*/
public Font getPressedFont() {
return (Font) getProperty(PROPERTY_PRESSED_FONT);
}
/**
* Returns the foreground color of the button when the button is pressed.
*
* @return the color
*/
public Color getPressedForeground() {
return (Color) getProperty(PROPERTY_PRESSED_FOREGROUND);
}
/**
* Returns the icon of the button that is displayed when the button is
* pressed.
*
* @return the icon
*/
public ImageReference getPressedIcon() {
return (ImageReference) getProperty(PROPERTY_PRESSED_ICON);
}
/**
* Returns the background color of the button when the mouse cursor is
* inside its bounds.
*
* @return the color
*/
public Color getRolloverBackground() {
return (Color) getProperty(PROPERTY_ROLLOVER_BACKGROUND);
}
/**
* Returns the background image displayed when the mouse cursor is inside
* the button's bounds.
*
* @return the background image
*/
public FillImage getRolloverBackgroundImage() {
return (FillImage) getProperty(PROPERTY_ROLLOVER_BACKGROUND_IMAGE);
}
/**
* Returns the border displayed around the button when the mouse cursor is
* inside its bounds.
*
* @return the border
*/
public Border getRolloverBorder() {
return (Border) getProperty(PROPERTY_ROLLOVER_BORDER);
}
/**
* Returns the font of the button when the mouse cursor is inside its
* bounds.
*
* @return the font
*/
public Font getRolloverFont() {
return (Font) getProperty(PROPERTY_ROLLOVER_FONT);
}
/**
* Returns the foreground color of the button when the mouse cursor is
* inside its bounds.
*
* @return the color
*/
public Color getRolloverForeground() {
return (Color) getProperty(PROPERTY_ROLLOVER_FOREGROUND);
}
/**
* Returns the icon of the button that is displayed when the mouse cursor is
* inside its bounds.
*
* @return the icon
*/
public ImageReference getRolloverIcon() {
return (ImageReference) getProperty(PROPERTY_ROLLOVER_ICON);
}
/**
* Returns the text label of the button.
*
* @return the text label
*/
public String getText() {
return (String) getProperty(PROPERTY_TEXT);
}
/**
* Returns the alignment of the text relative to the icon.
*
* @return the text alignment
*/
public Alignment getTextAlignment() {
return (Alignment) getProperty(PROPERTY_TEXT_ALIGNMENT);
}
/**
* Returns the position of the text relative to the icon.
*
* @return the text position
*/
public Alignment getTextPosition() {
return (Alignment) getProperty(PROPERTY_TEXT_POSITION);
}
/**
* Returns the tool tip text (displayed when the mouse cursor is hovered
* over the component).
*
* @return the tool tip text
*/
public String getToolTipText() {
return (String) getProperty(PROPERTY_TOOL_TIP_TEXT);
}
/**
* Returns the width of the button.
* This property supports Extent
s with
* fixed or percentile units.
*
* @return the width
*/
public Extent getWidth() {
return (Extent) getProperty(PROPERTY_WIDTH);
}
/**
* Determines if the button has any ActionListener
s
* registered.
*
* @return true if any action listeners are registered
*/
public boolean hasActionListeners() {
return hasEventListenerList() && getEventListenerList().getListenerCount(ActionListener.class) != 0;
}
/**
* Determines if the text of the button should wrap in the event that
* horizontal space is limited. Default value is true.
*
* @return the line wrap state
*/
public boolean isLineWrap() {
Boolean value = (Boolean) getProperty(PROPERTY_LINE_WRAP);
return value == null ? true : value.booleanValue();
}
/**
* Determines if pressed effects are enabled.
*
* @return true if pressed effects are enabled
* @see #setPressedEnabled(boolean)
*/
public boolean isPressedEnabled() {
Boolean value = (Boolean) getProperty(PROPERTY_PRESSED_ENABLED);
return value == null ? false : value.booleanValue();
}
/**
* Determines if rollover effects are enabled.
*
* @return true if rollover effects are enabled
* @see #setRolloverEnabled(boolean)
*/
public boolean isRolloverEnabled() {
Boolean value = (Boolean) getProperty(PROPERTY_ROLLOVER_ENABLED);
return value == null ? false : value.booleanValue();
}
/**
* This component does not support children.
*
* @see nextapp.echo2.app.Component#isValidChild(nextapp.echo2.app.Component)
*/
public boolean isValidChild(Component component) {
return false;
}
/**
* @see nextapp.echo2.app.Component#processInput(java.lang.String, java.lang.Object)
*/
public void processInput(String name, Object value) {
super.processInput(name, value);
if (INPUT_CLICK.equals(name)) {
doAction();
}
}
/**
* Removes an ActionListener
from being notified of user
* actions, i.e., button presses.
*
* @param l the listener to remove
*/
public void removeActionListener(ActionListener l) {
if (!hasEventListenerList()) {
return;
}
getEventListenerList().removeListener(ActionListener.class, l);
// Notification of action listener changes is provided due to
// existence of hasActionListeners() method.
firePropertyChange(ACTION_LISTENERS_CHANGED_PROPERTY, l, null);
}
/**
* Sets the action command of the ButtonModel
.
*
* @param newValue the action command
* @see nextapp.echo2.app.button.ButtonModel#setActionCommand(java.lang.String)
*/
public void setActionCommand(String newValue) {
getModel().setActionCommand(newValue);
}
/**
* Sets the alignment of the button's content.
* Only horizontal alignments are supported.
*
* @param newValue the new alignment
*/
public void setAlignment(Alignment newValue) {
setProperty(PROPERTY_ALIGNMENT, newValue);
}
/**
* Sets the background image of the button.
*
* @param newValue the new background image
*/
public void setBackgroundImage(FillImage newValue) {
setProperty(PROPERTY_BACKGROUND_IMAGE, newValue);
}
/**
* Sets the border displayed around the button.
*
* @param newValue the new border
*/
public void setBorder(Border newValue) {
setProperty(PROPERTY_BORDER, newValue);
}
/**
* Sets the background color of the button when the button is disabled.
*
* @param newValue the new Color
*/
public void setDisabledBackground(Color newValue) {
setProperty(PROPERTY_DISABLED_BACKGROUND, newValue);
}
/**
* Sets the background image displayed when the button is disabled.
*
* @param newValue the new background image
*/
public void setDisabledBackgroundImage(FillImage newValue) {
setProperty(PROPERTY_DISABLED_BACKGROUND_IMAGE, newValue);
}
/**
* Sets the border displayed around the button when the button is disabled.
*
* @param newValue the new border
*/
public void setDisabledBorder(Border newValue) {
setProperty(PROPERTY_DISABLED_BORDER, newValue);
}
/**
* Sets the font of the button when the button is disabled.
*
* @param newValue the new Font
*/
public void setDisabledFont(Font newValue) {
setProperty(PROPERTY_DISABLED_FONT, newValue);
}
/**
* Sets the foreground color of the button when the button is disabled.
*
* @param newValue the new Color
*/
public void setDisabledForeground(Color newValue) {
setProperty(PROPERTY_DISABLED_FOREGROUND, newValue);
}
/**
* Sets the icon of the button that is displayed when the button is
* disabled.
*
* @param newValue the new icon
*/
public void setDisabledIcon(ImageReference newValue) {
setProperty(PROPERTY_DISABLED_ICON, newValue);
}
/**
* Sets the height of the button.
* This property only supports Extent
s with
* fixed (i.e., not percent) units.
*
* @param newValue the new height
*/
public void setHeight(Extent newValue) {
setProperty(PROPERTY_HEIGHT, newValue);
}
/**
* Sets the icon displayed in the button.
*
* @param newValue the new icon
*/
public void setIcon(ImageReference newValue) {
setProperty(PROPERTY_ICON, newValue);
}
/**
* Sets the margin size between the icon and the text.
* The margin will only be displayed if the button has both
* icon and text properties set.
* This property only supports Extent
s with
* fixed (i.e., not percent) units.
*
* @param newValue the margin size
*/
public void setIconTextMargin(Extent newValue) {
setProperty(PROPERTY_ICON_TEXT_MARGIN, newValue);
}
/**
* Sets the margin between the buttons edge and its content.
*
* @param newValue the new margin
*/
public void setInsets(Insets newValue) {
setProperty(PROPERTY_INSETS, newValue);
}
/**
* Sets whether the text of the button should wrap in the event that
* horizontal space is limited. Default value is true.
*
* @param newValue the new line wrap state
*/
public void setLineWrap(boolean newValue) {
setProperty(PROPERTY_LINE_WRAP, new Boolean(newValue));
}
/**
* Sets the model that this button represents. The model may not be null.
*
* @param newValue the new ButtonModel
*/
public void setModel(ButtonModel newValue) {
if (newValue == null) {
throw new IllegalArgumentException("Model may not be null.");
}
ButtonModel oldValue = getModel();
if (oldValue != null) {
oldValue.removeActionListener(actionForwarder);
}
newValue.addActionListener(actionForwarder);
setProperty(PROPERTY_MODEL, newValue);
}
/**
* Sets the background color of the button when the button is pressed.
*
* @param newValue the new Color
*/
public void setPressedBackground(Color newValue) {
setProperty(PROPERTY_PRESSED_BACKGROUND, newValue);
}
/**
* Sets the background image displayed when the button is pressed.
*
* @param newValue the new background image
*/
public void setPressedBackgroundImage(FillImage newValue) {
setProperty(PROPERTY_PRESSED_BACKGROUND_IMAGE, newValue);
}
/**
* Sets the border displayed around the button when the button is pressed.
*
* @param newValue the new border
*/
public void setPressedBorder(Border newValue) {
setProperty(PROPERTY_PRESSED_BORDER, newValue);
}
/**
* Sets whether pressed effects are enabled when the button is pressed.
* Pressed properties have no effect unless this property is set to true.
* The default value is false.
*
* @param newValue true if pressed effects should be enabled
*/
public void setPressedEnabled(boolean newValue) {
setProperty(PROPERTY_PRESSED_ENABLED, new Boolean(newValue));
}
/**
* Sets the font of the button when the button is pressed.
*
* @param newValue the new Font
*/
public void setPressedFont(Font newValue) {
setProperty(PROPERTY_PRESSED_FONT, newValue);
}
/**
* Sets the foreground color of the button when the button is pressed.
*
* @param newValue the new Color
*/
public void setPressedForeground(Color newValue) {
setProperty(PROPERTY_PRESSED_FOREGROUND, newValue);
}
/**
* Sets the icon of the button that is displayed when the button is pressed.
*
* @param newValue the new icon
*/
public void setPressedIcon(ImageReference newValue) {
setProperty(PROPERTY_PRESSED_ICON, newValue);
}
/**
* Sets the background color of the button when the mouse cursor is inside
* its bounds.
*
* @param newValue the new Color
*/
public void setRolloverBackground(Color newValue) {
setProperty(PROPERTY_ROLLOVER_BACKGROUND, newValue);
}
/**
* Sets the background image displayed when the mouse cursor is inside the
* button's bounds
*
* @param newValue the new background image
*/
public void setRolloverBackgroundImage(FillImage newValue) {
setProperty(PROPERTY_ROLLOVER_BACKGROUND_IMAGE, newValue);
}
/**
* Sets the border displayed around the button when the mouse cursor is
* inside its bounds.
*
* @param newValue the new border
*/
public void setRolloverBorder(Border newValue) {
setProperty(PROPERTY_ROLLOVER_BORDER, newValue);
}
/**
* Sets whether rollover effects are enabled when the mouse cursor is inside
* the button's bounds. Rollover properties have no effect unless this
* property is set to true. The default value is false.
*
* @param newValue true if rollover effects should be enabled
*/
public void setRolloverEnabled(boolean newValue) {
setProperty(PROPERTY_ROLLOVER_ENABLED, new Boolean(newValue));
}
/**
* Sets the font of the button when the mouse cursor is inside its bounds.
*
* @param newValue the new Font
*/
public void setRolloverFont(Font newValue) {
setProperty(PROPERTY_ROLLOVER_FONT, newValue);
}
/**
* Sets the foreground color of the button when the mouse cursor is inside
* its bounds.
*
* @param newValue the new Color
*/
public void setRolloverForeground(Color newValue) {
setProperty(PROPERTY_ROLLOVER_FOREGROUND, newValue);
}
/**
* Sets the icon of the button that is displayed when the mouse cursor is
* inside its bounds.
*
* @param newValue the new icon
*/
public void setRolloverIcon(ImageReference newValue) {
setProperty(PROPERTY_ROLLOVER_ICON, newValue);
}
/**
* Sets the text label of the button.
*
* @param newValue the new text label
*/
public void setText(String newValue) {
setProperty(PROPERTY_TEXT, newValue);
}
/**
* Sets the alignment of the text relative to the icon.
* Note that only one of the provided Alignment
's
* settings should be non-default.
*
* @param newValue the new text alignment
*/
public void setTextAlignment(Alignment newValue) {
setProperty(PROPERTY_TEXT_ALIGNMENT, newValue);
}
/**
* Sets the position of the text relative to the icon.
* Note that only one of the provided Alignment
's
* settings should be non-default.
*
* @param newValue the new text position
*/
public void setTextPosition(Alignment newValue) {
setProperty(PROPERTY_TEXT_POSITION, newValue);
}
/**
* Sets the tool tip text (displayed when the mouse cursor is hovered
* over the component).
*
* @param newValue the new tool tip text
*/
public void setToolTipText(String newValue) {
setProperty(PROPERTY_TOOL_TIP_TEXT, newValue);
}
/**
* Sets the width of the button.
* This property supports Extent
s with
* fixed or percentile units.
*
* @param newValue the new width
*/
public void setWidth(Extent newValue) {
setProperty(PROPERTY_WIDTH, newValue);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy