/* MetalIconFactory.java --
Copyright (C) 2005, 2006, Free Software Foundation, Inc.
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath 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
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library. Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module. An independent module is a module which is not derived from
or based on this library. If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so. If you do not wish to do so, delete this
exception statement from your version. */
package javax.swing.plaf.metal;
import java.awt.Color;
import java.awt.Component;
import java.awt.Graphics;
import java.io.Serializable;
import javax.swing.AbstractButton;
import javax.swing.Icon;
import javax.swing.JCheckBox;
import javax.swing.JCheckBoxMenuItem;
import javax.swing.JFileChooser;
import javax.swing.JInternalFrame;
import javax.swing.JRadioButton;
import javax.swing.JRadioButtonMenuItem;
import javax.swing.JSlider;
import javax.swing.SwingConstants;
import javax.swing.UIManager;
import javax.swing.plaf.UIResource;
/**
* Creates icons for the {@link MetalLookAndFeel}.
*/
public class MetalIconFactory implements Serializable
{
/** A constant representing "dark". */
public static final boolean DARK = false;
/** A constant representing "light". */
public static final boolean LIGHT = true;
/** A shared instance of the MenuArrowIcon. */
private static Icon menuArrow;
/** A shared instance of the MenuItemArrowIcon. */
private static Icon menuItemArrow;
/**
* An icon displayed for {@link JCheckBoxMenuItem} components.
*/
private static class CheckBoxMenuItemIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon instance.
*/
public CheckBoxMenuItemIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon (10 pixels).
*/
public int getIconWidth()
{
return 10;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon (10 pixels).
*/
public int getIconHeight()
{
return 10;
}
/**
* Paints the icon.
*
* @param c the component.
* @param g the graphics device.
* @param x the x-coordinate.
* @param y the y-coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
JCheckBoxMenuItem item = (JCheckBoxMenuItem) c;
if (item.isArmed())
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getControlDarkShadow());
g.drawLine(x, y, x + 8, y);
g.drawLine(x, y + 1, x, y + 8);
g.drawLine(x + 2, y + 8, x + 8, y + 8);
g.drawLine(x + 8, y + 2, x + 8, y + 7);
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 1, y + 1, x + 7, y + 1);
g.drawLine(x + 1, y + 2, x + 1, y + 7);
g.drawLine(x + 1, y + 9, x + 9, y + 9);
g.drawLine(x + 9, y + 1, x + 9, y + 8);
// if the item is selected, we should draw a tick
if (item.isSelected())
{
g.setColor(MetalLookAndFeel.getBlack());
g.fillRect(x + 2, y + 2, 2, 5);
for (int i = 0; i < 6; i++)
g.drawLine(x + 8 - i, y + i, x + 9 - i, y + i);
}
}
}
/**
* An icon used for the "detail view" button on a {@link JFileChooser} under
* the {@link MetalLookAndFeel}.
*
* @see MetalIconFactory#getFileChooserDetailViewIcon()
*/
private static class FileChooserDetailViewIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon.
*/
public FileChooserDetailViewIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 18;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 18;
}
/**
* Paints the icon using colors from the {@link MetalLookAndFeel}.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
// file 1 outline
g.drawLine(x + 2, y + 2, x + 5, y + 2);
g.drawLine(x + 6, y + 3, x + 6, y + 7);
g.drawLine(x + 2, y + 7, x + 6, y + 7);
g.drawLine(x + 2, y + 2, x + 2, y + 7);
// file 2 outline
g.drawLine(x + 2, y + 10, x + 5, y + 10);
g.drawLine(x + 6, y + 11, x + 6, y + 15);
g.drawLine(x + 2, y + 15, x + 6, y + 15);
g.drawLine(x + 2, y + 10, x + 2, y + 15);
// detail lines
g.drawLine(x + 8, y + 5, x + 15, y + 5);
g.drawLine(x + 8, y + 13, x + 15, y + 13);
// fill files
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 3, y + 3, 3, 4);
g.fillRect(x + 3, y + 11, 3, 4);
// highlight files
g.setColor(MetalLookAndFeel.getPrimaryControlHighlight());
g.drawLine(x + 4, y + 4, x + 4, y + 5);
g.drawLine(x + 4, y + 12, x + 4, y + 13);
g.setColor(savedColor);
}
}
/**
* An icon used for the "home folder" button on a {@link JFileChooser} under
* the {@link MetalLookAndFeel}.
*
* @see MetalIconFactory#getFileChooserHomeFolderIcon()
*/
private static class FileChooserHomeFolderIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon.
*/
public FileChooserHomeFolderIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 18;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 18;
}
/**
* Paints the icon using colors from the {@link MetalLookAndFeel}.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
// roof
g.drawLine(x + 1, y + 8, x + 8, y + 1);
g.drawLine(x + 8, y + 1, x + 15, y + 8);
// base of house
g.drawLine(x + 3, y + 6, x + 3, y + 15);
g.drawLine(x + 3, y + 15, x + 13, y + 15);
g.drawLine(x + 13, y + 6, x + 13, y + 15);
// door frame
g.drawLine(x + 6, y + 9, x + 6, y + 15);
g.drawLine(x + 6, y + 9, x + 10, y + 9);
g.drawLine(x + 10, y + 9, x + 10, y + 15);
// chimney
g.drawLine(x + 11, y + 2, x + 11, y + 4);
g.drawLine(x + 12, y + 2, x + 12, y + 5);
g.setColor(MetalLookAndFeel.getControlDarkShadow());
// roof paint
int xx = x + 8;
for (int i = 0; i < 4; i++)
g.drawLine(xx - i, y + 2 + i, xx + i, y + 2 + i);
g.fillRect(x + 4, y + 6, 9, 2);
// door knob
g.drawLine(x + 9, y + 12, x + 9, y + 12);
// house paint
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.drawLine(x + 4, y + 8, x + 12, y + 8);
g.fillRect(x + 4, y + 9, 2, 6);
g.fillRect(x + 11, y + 9, 2, 6);
g.setColor(savedColor);
}
}
/**
* An icon used for the "list view" button on a {@link JFileChooser} under
* the {@link MetalLookAndFeel}.
*
* @see MetalIconFactory#getFileChooserListViewIcon()
*/
private static class FileChooserListViewIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon.
*/
public FileChooserListViewIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 18;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 18;
}
/**
* Paints the icon using colors from the {@link MetalLookAndFeel}.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
// file 1 outline
g.drawLine(x + 2, y + 2, x + 5, y + 2);
g.drawLine(x + 6, y + 3, x + 6, y + 7);
g.drawLine(x + 2, y + 7, x + 6, y + 7);
g.drawLine(x + 2, y + 2, x + 2, y + 7);
// file 2 outline
g.drawLine(x + 2, y + 10, x + 5, y + 10);
g.drawLine(x + 6, y + 11, x + 6, y + 15);
g.drawLine(x + 2, y + 15, x + 6, y + 15);
g.drawLine(x + 2, y + 10, x + 2, y + 15);
// file 3 outline
g.drawLine(x + 10, y + 2, x + 13, y + 2);
g.drawLine(x + 14, y + 3, x + 14, y + 7);
g.drawLine(x + 10, y + 7, x + 14, y + 7);
g.drawLine(x + 10, y + 2, x + 10, y + 7);
// file 4 outline
g.drawLine(x + 10, y + 10, x + 13, y + 10);
g.drawLine(x + 14, y + 11, x + 14, y + 15);
g.drawLine(x + 10, y + 15, x + 14, y + 15);
g.drawLine(x + 10, y + 10, x + 10, y + 15);
g.drawLine(x + 8, y + 5, x + 8, y + 5);
g.drawLine(x + 8, y + 13, x + 8, y + 13);
g.drawLine(x + 16, y + 5, x + 16, y + 5);
g.drawLine(x + 16, y + 13, x + 16, y + 13);
// fill files
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 3, y + 3, 3, 4);
g.fillRect(x + 3, y + 11, 3, 4);
g.fillRect(x + 11, y + 3, 3, 4);
g.fillRect(x + 11, y + 11, 3, 4);
// highlight files
g.setColor(MetalLookAndFeel.getPrimaryControlHighlight());
g.drawLine(x + 4, y + 4, x + 4, y + 5);
g.drawLine(x + 4, y + 12, x + 4, y + 13);
g.drawLine(x + 12, y + 4, x + 12, y + 5);
g.drawLine(x + 12, y + 12, x + 12, y + 13);
g.setColor(savedColor);
}
}
/**
* An icon used for the "new folder" button on a {@link JFileChooser} under
* the {@link MetalLookAndFeel}.
*
* @see MetalIconFactory#getFileChooserNewFolderIcon()
*/
private static class FileChooserNewFolderIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon.
*/
public FileChooserNewFolderIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 18;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 18;
}
/**
* Paints the icon using colors from the {@link MetalLookAndFeel}.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 2, y + 5, x + 9, y + 5);
g.drawLine(x + 10, y + 6, x + 15, y + 6);
g.drawLine(x + 15, y + 5, x + 15, y + 14);
g.drawLine(x + 2, y + 14, x + 15, y + 14);
g.drawLine(x + 1, y + 6, x + 1, y + 14);
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.drawLine(x + 11, y + 3, x + 15, y + 3);
g.drawLine(x + 10, y + 4, x + 15, y + 4);
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 3, y + 7, 7, 7);
g.fillRect(x + 10, y + 8, 5, 6);
g.drawLine(x + 10, y + 5, x + 14, y + 5);
g.setColor(MetalLookAndFeel.getPrimaryControlHighlight());
g.drawLine(x + 10, y + 7, x + 14, y + 7);
g.drawLine(x + 2, y + 6, x + 9, y + 6);
g.drawLine(x + 2, y + 6, x + 2, y + 13);
g.setColor(savedColor);
}
}
/**
* An icon used for the "up folder" button on a {@link JFileChooser} under
* the {@link MetalLookAndFeel}.
*
* @see MetalIconFactory#getFileChooserNewFolderIcon()
*/
private static class FileChooserUpFolderIcon extends FileChooserNewFolderIcon
{
/**
* Creates a new icon.
*/
public FileChooserUpFolderIcon()
{
// Nothing to do here.
}
/**
* Paints the icon using colors from the {@link MetalLookAndFeel}.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
// draw the folder
super.paintIcon(c, g, x, y);
// now draw the up arrow
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 8, y + 9, x + 8, y + 16);
int xx = x + 8;
for (int i = 0; i < 4; i++)
g.drawLine(xx - i, y + 9 + i, xx + i, y + 9 + i);
g.setColor(savedColor);
}
}
/**
* An icon representing a file (drawn as a piece of paper with the top-right
* corner turned down).
*/
public static class FileIcon16 implements Icon, Serializable
{
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels. The height returned is
* 16
plus the value returned by
* {@link #getAdditionalHeight()}.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 16 + getAdditionalHeight();
}
/**
* Paints the icon at the location (x, y).
*
* @param c the component.
* @param g the graphics context.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
y = y + getShift();
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x, y, x + 9, y);
g.drawLine(x, y + 1, x, y + 15);
g.drawLine(x, y + 15, x + 12, y + 15);
g.drawLine(x + 12, y + 15, x + 12, y + 6);
g.drawLine(x + 12, y + 6, x + 9, y);
g.drawLine(x + 7, y + 2, x + 11, y + 6);
g.drawLine(x + 8, y + 1, x + 9, y + 1);
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.drawLine(x + 1, y + 1, x + 7, y + 1);
g.drawLine(x + 1, y + 1, x + 1, y + 14);
g.drawLine(x + 1, y + 14, x + 11, y + 14);
g.drawLine(x + 11, y + 14, x + 11, y + 7);
g.drawLine(x + 8, y + 2, x + 10, y + 4);
}
/**
* Returns the additional height for the icon. The
* {@link #getIconHeight()} method adds this value to the icon height it
* returns. Subclasses can override this method to adjust the icon height.
*
* @return The additional height (0
unless overridden).
*/
public int getAdditionalHeight()
{
return 0;
}
/**
* Returns the vertical shift, in pixels, applied when painting the icon.
* The default value is zero, but subclasses may override this (for
* example, see {@link TreeLeafIcon}).
*
* @return The shift.
*/
public int getShift()
{
return 0;
}
}
/**
* An icon representing a folder.
*/
public static class FolderIcon16 implements Icon, Serializable
{
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels. The height returned is
* 16
plus the value returned by
* {@link #getAdditionalHeight()}.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 16 + getAdditionalHeight();
}
/**
* Paints the icon at the location (x, y).
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
y = y + getShift();
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x, y + 6, x, y + 15);
g.drawLine(x, y + 15, x + 15, y + 15);
g.drawLine(x + 15, y + 15, x + 15, y + 5);
g.drawLine(x + 14, y + 6, x + 9, y + 6);
g.drawLine(x + 8, y + 5, x + 1, y + 5);
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 2, y + 7, 7, 8);
g.fillRect(x + 9, y + 8, 6, 7);
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
g.drawLine(x + 9, y + 5, x + 14, y + 5);
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.drawLine(x + 9, y + 4, x + 15, y + 4);
g.drawLine(x + 10, y + 3, x + 15, y + 3);
}
/**
* Returns the additional height for the icon. The
* {@link #getIconHeight()} method adds this value to the icon height it
* returns. Subclasses can override this method to adjust the icon height.
*
* @return The additional height (0
unless overridden).
*/
public int getAdditionalHeight()
{
return 0;
}
/**
* Returns the vertical shift, in pixels, applied when painting the icon.
* The default value is zero, but subclasses may override this (for
* example, see {@link TreeFolderIcon}).
*
* @return The shift.
*/
public int getShift()
{
return 0;
}
}
/**
* An icon used by the {@link MetalInternalFrameUI} class when the frame
* is displayed as a palette.
*
* @since 1.3
*/
public static class PaletteCloseIcon
implements Icon, Serializable, UIResource
{
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 7;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 7;
}
/**
* Paints the icon using colors from the {@link MetalLookAndFeel}.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
AbstractButton button = (AbstractButton) c;
if (button.getModel().isPressed())
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getControlDarkShadow());
g.fillRect(x + 2, y + 2, 3, 3);
g.drawLine(x + 1, y, x + 1, y + 2);
g.drawLine(x, y + 1, x + 2, y + 1);
g.drawLine(x + 5, y, x + 5, y + 2);
g.drawLine(x + 4, y + 1, x + 6, y + 1);
g.drawLine(x + 1, y + 4, x + 1, y + 6);
g.drawLine(x, y + 5, x + 2, y + 5);
g.drawLine(x + 5, y + 4, x + 5, y + 6);
g.drawLine(x + 4, y + 5, x + 6, y + 5);
g.setColor(MetalLookAndFeel.getControlHighlight());
g.drawLine(x + 2, y + 6, x + 3, y + 5);
g.drawLine(x + 5, y + 3, x + 6, y + 2);
g.drawLine(x + 6, y + 6, x + 6, y + 6);
g.setColor(savedColor);
}
}
/**
* An {@link Icon} implementation for {@link JCheckBox}es in the
* Metal Look & Feel.
*
* @author Roman Kennke (roman@kennke.org)
*/
static class RadioButtonIcon implements Icon, UIResource, Serializable
{
/**
* This is used as a mask when painting the gradient. See
* {@link MetalUtils#paintGradient(java.awt.Graphics, int, int, int, int,
* float, float, java.awt.Color, java.awt.Color, java.awt.Color, int,
* int[][])} for details.
*/
private static int[][] gradientMask = new int[][] {{3, 7}, {1, 9}, {1, 9},
{0, 10}, {0, 10}, {0, 10},
{0, 10}, {1, 9}, {1, 9},
{3, 7}};
/**
* Returns the width of the icon in pixels.
*
* @return the width of the icon in pixels
*/
public int getIconWidth()
{
return 13;
}
/**
* Returns the height of the icon in pixels.
*
* @return the height of the icon in pixels
*/
public int getIconHeight()
{
return 13;
}
/**
* Paints the icon, taking into account whether or not the component is
* enabled, selected and/or armed.
*
* @param c the Component to draw on (must be an instance of
* {@link JRadioButton})
* @param g the Graphics context to draw with
* @param x the X position
* @param y the Y position
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
if (UIManager.get("RadioButton.gradient") != null)
MetalUtils.paintGradient(g, x + 2, y + 2, 8, 8,
SwingConstants.VERTICAL, "RadioButton.gradient",
gradientMask);
Color savedColor = g.getColor();
JRadioButton b = (JRadioButton) c;
// draw outer circle
if (b.isEnabled())
g.setColor(MetalLookAndFeel.getControlDarkShadow());
else
g.setColor(MetalLookAndFeel.getControlDisabled());
g.drawLine(x + 2, y + 1, x + 3, y + 1);
g.drawLine(x + 4, y, x + 7, y);
g.drawLine(x + 8, y + 1, x + 9, y + 1);
g.drawLine(x + 10, y + 2, x + 10, y + 3);
g.drawLine(x + 11, y + 4, x + 11, y + 7);
g.drawLine(x + 10, y + 8, x + 10, y + 9);
g.drawLine(x + 8, y + 10, x + 9, y + 10);
g.drawLine(x + 4, y + 11, x + 7, y + 11);
g.drawLine(x + 2, y + 10, x + 3, y + 10);
g.drawLine(x + 1, y + 9, x + 1, y + 8);
g.drawLine(x, y + 7, x, y + 4);
g.drawLine(x + 1, y + 2, x + 1, y + 3);
if (b.getModel().isArmed())
{
g.setColor(MetalLookAndFeel.getControlShadow());
g.drawLine(x + 4, y + 1, x + 7, y + 1);
g.drawLine(x + 4, y + 10, x + 7, y + 10);
g.drawLine(x + 1, y + 4, x + 1, y + 7);
g.drawLine(x + 10, y + 4, x + 10, y + 7);
g.fillRect(x + 2, y + 2, 8, 8);
}
else
{
// only draw inner highlight if not filled
if (b.isEnabled())
{
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 2, y + 8, x + 2, y + 9);
g.drawLine(x + 1, y + 4, x + 1, y + 7);
g.drawLine(x + 2, y + 2, x + 2, y + 3);
g.drawLine(x + 3, y + 2, x + 3, y + 2);
g.drawLine(x + 4, y + 1, x + 7, y + 1);
g.drawLine(x + 8, y + 2, x + 9, y + 2);
}
}
// draw outer highlight
if (b.isEnabled())
{
g.setColor(MetalLookAndFeel.getWhite());
// outer
g.drawLine(x + 10, y + 1, x + 10, y + 1);
g.drawLine(x + 11, y + 2, x + 11, y + 3);
g.drawLine(x + 12, y + 4, x + 12, y + 7);
g.drawLine(x + 11, y + 8, x + 11, y + 9);
g.drawLine(x + 10, y + 10, x + 10, y + 10);
g.drawLine(x + 8, y + 11, x + 9, y + 11);
g.drawLine(x + 4, y + 12, x + 7, y + 12);
g.drawLine(x + 2, y + 11, x + 3, y + 11);
}
if (b.isSelected())
{
if (b.isEnabled())
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getControlDisabled());
g.drawLine(x + 4, y + 3, x + 7, y + 3);
g.fillRect(x + 3, y + 4, 6, 4);
g.drawLine(x + 4, y + 8, x + 7, y + 8);
}
g.setColor(savedColor);
}
}
/**
* An icon displayed for {@link JRadioButtonMenuItem} components.
*/
private static class RadioButtonMenuItemIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon instance.
*/
public RadioButtonMenuItemIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 10;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 10;
}
/**
* Paints the icon.
*
* @param c the component.
* @param g the graphics device.
* @param x the x-coordinate.
* @param y the y-coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
JRadioButtonMenuItem item = (JRadioButtonMenuItem) c;
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 2, y, x + 6, y);
g.drawLine(x + 7, y + 1, x + 7, y + 1);
g.drawLine(x + 8, y + 2, x + 8, y + 6);
g.drawLine(x + 7, y + 7, x + 7, y + 7);
g.drawLine(x + 2, y + 8, x + 6, y + 8);
g.drawLine(x + 1, y + 7, x + 1, y + 7);
g.drawLine(x, y + 2, x, y + 6);
g.drawLine(x + 1, y + 1, x + 1, y + 1);
if (item.isSelected())
{
g.drawLine(x + 3, y + 2, x + 5, y + 2);
g.fillRect(x + 2, y + 3, 5, 3);
g.drawLine(x + 3, y + 6, x + 5, y + 6);
}
// highlight
g.setColor(MetalLookAndFeel.getControlHighlight());
g.drawLine(x + 3, y + 1, x + 6, y + 1);
g.drawLine(x + 8, y + 1, x + 8, y + 1);
g.drawLine(x + 9, y + 2, x + 9, y + 7);
g.drawLine(x + 8, y + 8, x + 8, y + 8);
g.drawLine(x + 2, y + 9, x + 7, y + 9);
g.drawLine(x + 1, y + 8, x + 1, y + 8);
g.drawLine(x + 1, y + 3, x + 1, y + 6);
g.drawLine(x + 2, y + 2, x + 2, y + 2);
g.setColor(savedColor);
}
}
/**
* The icon used to display the thumb control on a horizontally oriented
* {@link JSlider} component.
*/
private static class HorizontalSliderThumbIcon
implements Icon, UIResource, Serializable
{
/**
* This mask is used to paint the gradient in the shape of the thumb.
*/
int[][] gradientMask = new int[][] { {0, 12}, {0, 12}, {0, 12}, {0, 12},
{0, 12}, {0, 12}, {0, 12}, {1, 11},
{2, 10}, {3, 9}, {4, 8}, {5, 7},
{6, 6}};
/**
* Creates a new instance.
*/
public HorizontalSliderThumbIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 15;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon, taking into account whether or not the component has
* the focus.
*
* @param c the component.
* @param g the graphics device.
* @param x the x-coordinate.
* @param y the y-coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
boolean enabled = false;
boolean focus = false;
if (c != null)
{
enabled = c.isEnabled();
focus = c.hasFocus();
}
// draw the outline
if (enabled)
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getControlDarkShadow());
g.drawLine(x + 1, y, x + 13, y);
g.drawLine(x + 14, y + 1, x + 14, y + 7);
g.drawLine(x + 14, y + 8, x + 7, y + 15);
g.drawLine(x + 6, y + 14, x, y + 8);
g.drawLine(x, y + 7, x, y + 1);
// The following is commented out until the masking for the gradient painting
// is working correctly
// // Fill the icon.
// if (MetalLookAndFeel.getCurrentTheme() instanceof OceanTheme
// && enabled)
// {
// String gradient;
// if (focus)
// gradient = "Slider.focusGradient";
// else
// gradient = "Slider.gradient";
// MetalUtils.paintGradient(g, x + 1, y + 2, 12, 13,
// SwingConstants.VERTICAL, gradient,
// gradientMask);
// }
// else
{
if (focus)
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
else
g.setColor(MetalLookAndFeel.getControl());
g.fillRect(x + 1, y + 2, 13, 7);
g.drawLine(x + 2, y + 9, x + 12, y + 9);
g.drawLine(x + 3, y + 10, x + 11, y + 10);
g.drawLine(x + 4, y + 11, x + 10, y + 11);
g.drawLine(x + 5, y + 12, x + 9, y + 12);
g.drawLine(x + 6, y + 13, x + 8, y + 13);
g.drawLine(x + 7, y + 14, x + 7, y + 14);
}
// If the slider is enabled, draw dots and highlights.
if (c.isEnabled()
&& !(MetalLookAndFeel.getCurrentTheme() instanceof OceanTheme))
{
if (focus)
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
else
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 3, y + 3, x + 3, y + 3);
g.drawLine(x + 7, y + 3, x + 7, y + 3);
g.drawLine(x + 11, y + 3, x + 11, y + 3);
g.drawLine(x + 5, y + 5, x + 5, y + 5);
g.drawLine(x + 9, y + 5, x + 9, y + 5);
g.drawLine(x + 3, y + 7, x + 3, y + 7);
g.drawLine(x + 7, y + 7, x + 7, y + 7);
g.drawLine(x + 11, y + 7, x + 11, y + 7);
// Draw highlights
if (focus)
g.setColor(MetalLookAndFeel.getPrimaryControl());
else
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 1, y + 1, x + 13, y + 1);
g.drawLine(x + 1, y + 2, x + 1, y + 8);
g.drawLine(x + 2, y + 2, x + 2, y + 2);
g.drawLine(x + 6, y + 2, x + 6, y + 2);
g.drawLine(x + 10, y + 2, x + 10, y + 2);
g.drawLine(x + 4, y + 4, x + 4, y + 4);
g.drawLine(x + 8, y + 4, x + 8, y + 4);
g.drawLine(x + 2, y + 6, x + 2, y + 6);
g.drawLine(x + 6, y + 6, x + 6, y + 6);
g.drawLine(x + 10, y + 6, x + 10, y + 6);
}
}
}
/**
* An icon used for the 'close' button in the title frame of a
* {@link JInternalFrame}.
*/
private static class InternalFrameCloseIcon
implements Icon, UIResource, Serializable
{
/** The icon size in pixels. */
private int size;
/**
* Creates a new icon.
*
* @param size the icon size (width and height) in pixels.
*/
public InternalFrameCloseIcon(int size)
{
this.size = size;
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return size;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return size;
}
/**
* Paints the icon.
*
* @param c the component (an {@link JInternalFrame} is expected).
* @param g the graphics device.
* @param x the x-coordinate.
* @param y the y-coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
AbstractButton b = (AbstractButton) c;
// fill the interior
if (b.getModel().isPressed())
// FIXME: also need to take into account whether the internal frame is
// selected
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
else
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 2, y + 2, 10, 10);
// draw the outline box and the cross
if (b.getModel().isPressed())
g.setColor(MetalLookAndFeel.getBlack());
else
{
// FIXME: also need to take into account whether the internal frame is
// selected
boolean selected = true;
if (selected)
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
else
g.setColor(MetalLookAndFeel.getControlDarkShadow());
}
g.drawLine(x + 1, y + 1, x + 13, y + 1);
g.drawLine(x + 1, y + 2, x + 1, y + 12);
g.drawLine(x + 1, y + 13, x + 13, y + 13);
g.drawLine(x + 13, y + 2, x + 13, y + 12);
g.drawLine(x + 2, y + 12, x + 2, y + 12);
g.drawLine(x + 12, y + 2, x + 12, y + 2);
g.fillRect(x + 4, y + 4, 2, 2);
g.fillRect(x + 5, y + 5, 4, 4);
g.drawLine(x + 9, y + 4, x + 10, y + 4);
g.drawLine(x + 9, y + 4, x + 9, y + 5);
g.drawLine(x + 4, y + 9, x + 4, y + 10);
g.drawLine(x + 4, y + 9, x + 5, y + 9);
g.drawLine(x + 9, y + 8, x + 9, y + 10);
g.drawLine(x + 8, y + 9, x + 10, y + 9);
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x, y, x + 13, y);
g.drawLine(x, y + 1, x, y + 13);
g.drawLine(x + 3, y + 4, x + 4, y + 3);
g.drawLine(x + 3, y + 9, x + 5, y + 7);
g.drawLine(x + 7, y + 5, x + 9, y + 3);
g.drawLine(x + 12, y + 3, x + 12, y + 11);
g.drawLine(x + 3, y + 12, x + 12, y + 12);
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 1, y + 14, x + 14, y + 14);
g.drawLine(x + 14, y + 1, x + 14, y + 14);
if (!b.getModel().isPressed())
{
g.drawLine(x + 5, y + 10, x + 5, y + 10);
g.drawLine(x + 6, y + 9, x + 7, y + 9);
g.drawLine(x + 10, y + 5, x + 10, y + 5);
g.drawLine(x + 9, y + 6, x + 9, y + 7);
g.drawLine(x + 10, y + 10, x + 11, y + 10);
g.drawLine(x + 10, y + 11, x + 10, y + 11);
}
g.setColor(savedColor);
}
}
/**
* The icon displayed at the top-left corner of a {@link JInternalFrame}.
*/
private static class InternalFrameDefaultMenuIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new instance.
*/
public InternalFrameDefaultMenuIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon at the specified location.
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.fillRect(x + 1, y, 14, 2);
g.fillRect(x, y + 1, 2, 14);
g.fillRect(x + 1, y + 14, 14, 2);
g.fillRect(x + 14, y + 1, 2, 14);
g.drawLine(x + 2, y + 5, x + 14, y + 5);
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 2, y + 2, 12, 3);
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.drawLine(x + 3, y + 3, x + 3, y + 3);
g.drawLine(x + 6, y + 3, x + 6, y + 3);
g.drawLine(x + 9, y + 3, x + 9, y + 3);
g.drawLine(x + 12, y + 3, x + 12, y + 3);
g.setColor(MetalLookAndFeel.getWhite());
g.fillRect(x + 2, y + 6, 12, 8);
g.drawLine(x + 2, y + 2, x + 2, y + 2);
g.drawLine(x + 5, y + 2, x + 5, y + 2);
g.drawLine(x + 8, y + 2, x + 8, y + 2);
g.drawLine(x + 11, y + 2, x + 11, y + 2);
}
}
/**
* An icon used in the title frame of a {@link JInternalFrame}. When you
* maximise an internal frame, this icon will replace the 'maximise' icon to
* provide a 'restore' option.
*/
private static class InternalFrameAltMaximizeIcon
implements Icon, UIResource, Serializable
{
/** The icon size in pixels. */
private int size;
/**
* Creates a new icon.
*
* @param size the icon size in pixels.
*/
public InternalFrameAltMaximizeIcon(int size)
{
this.size = size;
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return size;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return size;
}
/**
* Paints the icon at the specified location.
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
AbstractButton b = (AbstractButton) c;
// fill the small box interior
if (b.getModel().isPressed())
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
else
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 2, y + 6, 7, 7);
if (b.getModel().isPressed())
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.drawLine(x + 12, y + 1, x + 13, y + 1);
g.drawLine(x + 11, y + 2, x + 12, y + 2);
g.drawLine(x + 10, y + 3, x + 11, y + 3);
g.drawLine(x + 8, y + 2, x + 8, y + 3);
g.fillRect(x + 8, y + 4, 3, 3);
g.drawLine(x + 11, y + 6, x + 12, y + 6);
g.drawLine(x + 1, y + 5, x + 5, y + 5);
g.drawLine(x + 1, y + 6, x + 1, y + 12);
g.drawLine(x + 9, y + 9, x + 9, y + 12);
g.drawLine(x + 1, y + 13, x + 9, y + 13);
g.drawLine(x + 2, y + 12, x + 2, y + 12);
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 12, y, x + 9, y + 3);
g.drawLine(x + 7, y + 1, x + 8, y + 1);
g.drawLine(x + 7, y + 2, x + 7, y + 6);
g.drawLine(x + 11, y + 5, x + 12, y + 5);
g.drawLine(x, y + 4, x + 5, y + 4);
g.drawLine(x, y + 5, x, y + 13);
g.drawLine(x + 3, y + 12, x + 8, y + 12);
g.drawLine(x + 8, y + 8, x + 8, y + 11);
g.drawLine(x + 9, y + 8, x + 9, y + 8);
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 9, y + 2, x + 9, y + 2);
g.drawLine(x + 11, y + 4, x + 13, y + 2);
g.drawLine(x + 13, y + 6, x + 13, y + 6);
g.drawLine(x + 8, y + 7, x + 13, y + 7);
g.drawLine(x + 6, y + 5, x + 6, y + 5);
g.drawLine(x + 10, y + 8, x + 10, y + 13);
g.drawLine(x + 1, y + 14, x + 10, y + 14);
if (!b.getModel().isPressed())
{
g.drawLine(x + 2, y + 6, x + 6, y + 6);
g.drawLine(x + 2, y + 6, x + 2, y + 11);
}
g.setColor(savedColor);
}
}
/**
* An icon used for the 'maximize' button in the title frame of a
* {@link JInternalFrame}.
*/
private static class InternalFrameMaximizeIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new instance.
*/
public InternalFrameMaximizeIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon at the specified location.
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
AbstractButton b = (AbstractButton) c;
// fill the interior
if (b.getModel().isPressed())
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
else
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 2, y + 6, 7, 7);
if (b.getModel().isPressed())
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.drawLine(x + 9, y + 1, x + 10, y + 1);
g.fillRect(x + 11, y + 1, 3, 3);
g.fillRect(x + 12, y + 4, 2, 2);
g.drawLine(x + 10, y + 3, x + 10, y + 3);
g.drawLine(x + 9, y + 4, x + 10, y + 4);
g.drawLine(x + 1, y + 5, x + 9, y + 5);
g.drawLine(x + 1, y + 6, x + 1, y + 12);
g.drawLine(x + 9, y + 6, x + 9, y + 12);
g.drawLine(x + 1, y + 13, x + 9, y + 13);
// fill
g.drawLine(x + 7, y + 6, x + 8, y + 6);
g.drawLine(x + 6, y + 7, x + 8, y + 7);
g.drawLine(x + 5, y + 8, x + 6, y + 8);
g.drawLine(x + 4, y + 9, x + 5, y + 9);
g.drawLine(x + 3, y + 10, x + 4, y + 10);
g.drawLine(x + 2, y + 11, x + 3, y + 11);
g.drawLine(x + 2, y + 12, x + 4, y + 12);
g.drawLine(x + 8, y + 8, x + 8, y + 8);
// draw black
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 8, y, x + 13, y);
g.drawLine(x + 8, y + 1, x + 8, y + 1);
g.drawLine(x + 10, y + 2, x + 9, y + 3);
g.drawLine(x, y + 4, x + 8, y + 4);
g.drawLine(x, y + 5, x, y + 13);
g.drawLine(x + 2, y + 10, x + 6, y + 6);
g.drawLine(x + 8, y + 9, x + 8, y + 11);
g.drawLine(x + 5, y + 12, x + 8, y + 12);
// draw white
g.setColor(MetalLookAndFeel.getWhite());
if (!b.getModel().isPressed())
{
g.drawLine(x + 2, y + 6, x + 5, y + 6);
g.drawLine(x + 2, y + 7, x + 2, y + 9);
g.drawLine(x + 4, y + 11, x + 7, y + 8);
}
g.drawLine(x + 1, y + 14, x + 10, y + 14);
g.drawLine(x + 10, y + 5, x + 10, y + 13);
g.drawLine(x + 9, y + 2, x + 9, y + 2);
g.drawLine(x + 11, y + 4, x + 11, y + 5);
g.drawLine(x + 13, y + 6, x + 14, y + 6);
g.drawLine(x + 14, y + 1, x + 14, y + 5);
g.setColor(savedColor);
}
}
/**
* An icon used in the title frame of a {@link JInternalFrame}.
*/
private static class InternalFrameMinimizeIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new instance.
*/
public InternalFrameMinimizeIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon at the specified location.
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color savedColor = g.getColor();
AbstractButton b = (AbstractButton) c;
if (b.getModel().isPressed())
g.setColor(MetalLookAndFeel.getBlack());
else
// FIXME: here the color depends on whether or not the internal frame
// is selected
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
g.drawLine(x + 12, y + 1, x + 13, y + 1);
g.drawLine(x + 11, y + 2, x + 12, y + 2);
g.drawLine(x + 10, y + 3, x + 11, y + 3);
g.drawLine(x + 8, y + 2, x + 8, y + 3);
g.fillRect(x + 8, y + 4, 3, 3);
g.drawLine(x + 11, y + 6, x + 12, y + 6);
g.drawLine(x + 1, y + 8, x + 6, y + 8);
g.drawLine(x + 1, y + 9, x + 1, y + 12);
g.drawLine(x + 6, y + 9, x + 6, y + 12);
g.drawLine(x + 1, y + 13, x + 6, y + 13);
g.drawLine(x + 5, y + 9, x + 5, y + 9);
g.drawLine(x + 2, y + 12, x + 2, y + 12);
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 12, y, x + 9, y + 3);
g.drawLine(x + 7, y + 1, x + 8, y + 1);
g.drawLine(x + 7, y + 2, x + 7, y + 6);
g.drawLine(x, y + 7, x + 6, y + 7);
g.drawLine(x, y + 8, x, y + 13);
g.drawLine(x + 3, y + 12, x + 5, y + 12);
g.drawLine(x + 5, y + 10, x + 5, y + 11);
g.drawLine(x + 11, y + 5, x + 12, y + 5);
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 9, y + 2, x + 9, y + 2);
g.drawLine(x + 11, y + 4, x + 13, y + 2);
g.drawLine(x + 13, y + 6, x + 13, y + 6);
g.drawLine(x + 8, y + 7, x + 13, y + 7);
g.drawLine(x + 7, y + 9, x + 7, y + 13);
g.drawLine(x + 1, y + 14, x + 7, y + 14);
if (b.getModel().isPressed())
{
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
g.fillRect(x + 2, y + 9, 3, 3);
}
else
{
g.drawLine(x + 2, y + 9, x + 4, y + 9);
g.drawLine(x + 2, y + 10, x + 2, y + 11);
}
g.setColor(savedColor);
}
}
/**
* The icon used to display the thumb control on a horizontally oriented
* {@link JSlider} component.
*/
private static class VerticalSliderThumbIcon
implements Icon, UIResource, Serializable
{
/**
* This mask is used to paint the gradient in the shape of the thumb.
*/
int[][] gradientMask = new int[][] { {0, 12}, {0, 12}, {0, 12}, {0, 12},
{0, 12}, {0, 12}, {0, 12}, {1, 11},
{2, 10}, {3, 9}, {4, 8}, {5, 7},
{6, 6}};
/**
* Creates a new instance.
*/
public VerticalSliderThumbIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 15;
}
/**
* Paints the icon taking into account whether the slider control has the
* focus or not.
*
* @param c the slider (must be a non-null
instance of
* {@link JSlider}.
* @param g the graphics device.
* @param x the x-coordinate.
* @param y the y-coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
boolean enabled = false;
boolean focus = false;
if (c != null)
{
enabled = c.isEnabled();
focus = c.hasFocus();
}
// draw the outline
if (enabled)
g.setColor(MetalLookAndFeel.getBlack());
else
g.setColor(MetalLookAndFeel.getControlDarkShadow());
g.drawLine(x + 1, y, x + 7, y);
g.drawLine(x + 8, y, x + 15, y + 7);
g.drawLine(x + 14, y + 8, x + 8, y + 14);
g.drawLine(x + 8, y + 14, x + 1, y + 14);
g.drawLine(x, y + 13, x, y + 1);
// The following is commented out until the masking for the gradient painting
// is working correctly
// // Fill the icon.
// if (MetalLookAndFeel.getCurrentTheme() instanceof OceanTheme
// && enabled)
// {
// String gradient;
// if (focus)
// gradient = "Slider.focusGradient";
// else
// gradient = "Slider.gradient";
// MetalUtils.paintGradient(g, x + 2, y + 1, 13, 12,
// SwingConstants.HORIZONTAL, gradient,
// gradientMask);
// }
// else
{
if (focus)
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
else
g.setColor(MetalLookAndFeel.getControl());
g.fillRect(x + 2, y + 1, 7, 13);
g.drawLine(x + 9, y + 2, x + 9, y + 12);
g.drawLine(x + 10, y + 3, x + 10, y + 11);
g.drawLine(x + 11, y + 4, x + 11, y + 10);
g.drawLine(x + 12, y + 5, x + 12, y + 9);
g.drawLine(x + 13, y + 6, x + 13, y + 8);
g.drawLine(x + 14, y + 7, x + 14, y + 7);
}
// if the slider is enabled, draw dots and highlights
if (enabled
&& ! (MetalLookAndFeel.getCurrentTheme() instanceof OceanTheme))
{
if (focus)
g.setColor(MetalLookAndFeel.getPrimaryControlDarkShadow());
else
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 3, y + 3, x + 3, y + 3);
g.drawLine(x + 3, y + 7, x + 3, y + 7);
g.drawLine(x + 3, y + 11, x + 3, y + 11);
g.drawLine(x + 5, y + 5, x + 5, y + 5);
g.drawLine(x + 5, y + 9, x + 5, y + 9);
g.drawLine(x + 7, y + 3, x + 7, y + 3);
g.drawLine(x + 7, y + 7, x + 7, y + 7);
g.drawLine(x + 7, y + 11, x + 7, y + 11);
// draw highlights
if (focus)
g.setColor(MetalLookAndFeel.getPrimaryControl());
else
g.setColor(MetalLookAndFeel.getWhite());
g.drawLine(x + 1, y + 1, x + 8, y + 1);
g.drawLine(x + 1, y + 2, x + 1, y + 13);
g.drawLine(x + 2, y + 2, x + 2, y + 2);
g.drawLine(x + 2, y + 6, x + 2, y + 6);
g.drawLine(x + 2, y + 10, x + 2, y + 10);
g.drawLine(x + 4, y + 4, x + 4, y + 4);
g.drawLine(x + 4, y + 8, x + 4, y + 8);
g.drawLine(x + 6, y + 2, x + 6, y + 2);
g.drawLine(x + 6, y + 6, x + 6, y + 6);
g.drawLine(x + 6, y + 10, x + 6, y + 10);
}
}
}
/**
* A tree control icon. This icon can be in one of two states: expanded and
* collapsed.
*/
public static class TreeControlIcon implements Icon, Serializable
{
/** ???. */
protected boolean isLight;
/** A flag that controls whether or not the icon is collapsed. */
private boolean collapsed;
/**
* Creates a new icon.
*
* @param isCollapsed a flag that controls whether the icon is in the
* collapsed state or the expanded state.
*/
public TreeControlIcon(boolean isCollapsed)
{
collapsed = isCollapsed;
}
/**
* Returns the width of the icon, in pixels.
*
* @return The width of the icon.
*/
public int getIconWidth()
{
return 18;
}
/**
* Returns the height of the icon, in pixels.
*
* @return The height of the icon.
*/
public int getIconHeight()
{
return 18;
}
/**
* Paints the icon at the location (x, y).
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
// TODO: pick up appropriate UI colors
Color dark = new Color(99, 130, 191);
Color light = new Color(163, 184, 204);
Color white = Color.white;
x += 8;
y += 6;
final int w = 6;
final int wHalf = (w >> 2);
g.setColor(light);
g.drawOval(x, y, w, w);
g.setColor(dark);
g.fillOval(x + 1, y + 1, w - 1, w - 1);
if (collapsed)
g.fillRect(x + w, y + wHalf + 1, w, 2);
else
g.fillRect(x + wHalf + 1, y + w, 2, w);
g.setColor(white);
g.fillRect(x + wHalf + 1, y + wHalf + 1, 2, 2);
}
/**
* Simply calls {@link #paintIcon(Component, Graphics, int, int)}.
*
* @param c the component.
* @param g the graphics device.
* @param x the x coordinate.
* @param y the y coordinate.
*/
public void paintMe(Component c, Graphics g, int x, int y)
{
paintIcon(c, g, x, y);
}
}
/**
* A tree folder icon.
*/
public static class TreeFolderIcon extends FolderIcon16
{
/**
* Creates a new instance.
*/
public TreeFolderIcon()
{
// Nothing to do here.
}
/**
* Returns the additional height for this icon, in this case 2
* pixels.
*
* @return 2
.
*/
public int getAdditionalHeight()
{
return 2;
}
/**
* Returns the vertical shift, in pixels, applied when painting the icon.
* This overridden method returns -1
.
*
* @return The shift.
*/
public int getShift()
{
return -1;
}
}
/**
* A tree leaf icon.
*/
public static class TreeLeafIcon extends FileIcon16
{
/**
* Creates a new instance.
*/
public TreeLeafIcon()
{
// Nothing to do here.
}
/**
* Returns the additional height for this icon, in this case 4
* pixels.
*
* @return 4
.
*/
public int getAdditionalHeight()
{
return 4;
}
/**
* Returns the vertical shift, in pixels, applied when painting the icon.
* This overridden method returns 2
.
*
* @return The shift.
*/
public int getShift()
{
return 2;
}
}
/**
* An icon representing a hard disk.
*
* @see MetalIconFactory#getTreeHardDriveIcon()
*/
private static class TreeHardDriveIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon instance.
*/
public TreeHardDriveIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return 16
.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return 16
.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon at the specified location, using colors from the
* current theme.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color saved = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 1, y + 4, x + 1, y + 5);
g.drawLine(x + 14, y + 4, x + 14, y + 5);
g.drawLine(x + 1, y + 7, x + 1, y + 8);
g.drawLine(x + 14, y + 7, x + 14, y + 8);
g.drawLine(x + 1, y + 10, x + 1, y + 11);
g.drawLine(x + 14, y + 10, x + 14, y + 11);
g.drawLine(x + 2, y + 3, x + 3, y + 3);
g.drawLine(x + 12, y + 3, x + 13, y + 3);
g.drawLine(x + 2, y + 6, x + 3, y + 6);
g.drawLine(x + 12, y + 6, x + 13, y + 6);
g.drawLine(x + 2, y + 9, x + 3, y + 9);
g.drawLine(x + 12, y + 9, x + 13, y + 9);
g.drawLine(x + 2, y + 12, x + 3, y + 12);
g.drawLine(x + 12, y + 12, x + 13, y + 12);
g.drawLine(x + 4, y + 2, x + 11, y + 2);
g.drawLine(x + 4, y + 7, x + 11, y + 7);
g.drawLine(x + 4, y + 10, x + 11, y + 10);
g.drawLine(x + 4, y + 13, x + 11, y + 13);
g.setColor(MetalLookAndFeel.getWhite());
g.fillRect(x + 4, y + 3, 2, 2);
g.drawLine(x + 6, y + 4, x + 6, y + 4);
g.drawLine(x + 7, y + 3, x + 9, y + 3);
g.drawLine(x + 8, y + 4, x + 8, y + 4);
g.drawLine(x + 11, y + 3, x + 11, y + 3);
g.fillRect(x + 2, y + 4, 2, 2);
g.fillRect(x + 2, y + 7, 2, 2);
g.fillRect(x + 2, y + 10, 2, 2);
g.drawLine(x + 4, y + 6, x + 4, y + 6);
g.drawLine(x + 4, y + 9, x + 4, y + 9);
g.drawLine(x + 4, y + 12, x + 4, y + 12);
g.setColor(MetalLookAndFeel.getControlShadow());
g.drawLine(x + 13, y + 4, x + 13, y + 4);
g.drawLine(x + 12, y + 5, x + 13, y + 5);
g.drawLine(x + 13, y + 7, x + 13, y + 7);
g.drawLine(x + 12, y + 8, x + 13, y + 8);
g.drawLine(x + 13, y + 10, x + 13, y + 10);
g.drawLine(x + 12, y + 11, x + 13, y + 11);
g.drawLine(x + 10, y + 5, x + 10, y + 5);
g.drawLine(x + 7, y + 6, x + 7, y + 6);
g.drawLine(x + 9, y + 6, x + 9, y + 6);
g.drawLine(x + 11, y + 6, x + 11, y + 6);
g.drawLine(x + 10, y + 8, x + 10, y + 8);
g.drawLine(x + 7, y + 9, x + 7, y + 9);
g.drawLine(x + 9, y + 9, x + 9, y + 9);
g.drawLine(x + 11, y + 9, x + 11, y + 9);
g.drawLine(x + 10, y + 11, x + 10, y + 11);
g.drawLine(x + 7, y + 12, x + 7, y + 12);
g.drawLine(x + 9, y + 12, x + 9, y + 12);
g.drawLine(x + 11, y + 12, x + 11, y + 12);
g.setColor(saved);
}
}
/**
* An icon representing a floppy disk.
*
* @see MetalIconFactory#getTreeFloppyDriveIcon()
*/
private static class TreeFloppyDriveIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon instance.
*/
public TreeFloppyDriveIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return 16
.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return 16
.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon at the specified location, using colors from the
* current theme.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color saved = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 1, y + 1, x + 13, y + 1);
g.drawLine(x + 1, y + 1, x + 1, y + 14);
g.drawLine(x + 1, y + 14, x + 14, y + 14);
g.drawLine(x + 14, y + 2, x + 14, y + 14);
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 2, y + 2, 12, 12);
g.setColor(MetalLookAndFeel.getControlShadow());
g.fillRect(x + 5, y + 2, 6, 5);
g.drawLine(x + 4, y + 8, x + 11, y + 8);
g.drawLine(x + 3, y + 9, x + 3, y + 13);
g.drawLine(x + 12, y + 9, x + 12, y + 13);
g.setColor(MetalLookAndFeel.getWhite());
g.fillRect(x + 8, y + 3, 2, 3);
g.fillRect(x + 4, y + 9, 8, 5);
g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
g.drawLine(x + 5, y + 10, x + 9, y + 10);
g.drawLine(x + 5, y + 12, x + 8, y + 12);
g.setColor(saved);
}
}
/**
* An icon representing a computer.
*
* @see MetalIconFactory#getTreeComputerIcon()
*/
private static class TreeComputerIcon
implements Icon, UIResource, Serializable
{
/**
* Creates a new icon instance.
*/
public TreeComputerIcon()
{
// Nothing to do here.
}
/**
* Returns the width of the icon, in pixels.
*
* @return 16
.
*/
public int getIconWidth()
{
return 16;
}
/**
* Returns the height of the icon, in pixels.
*
* @return 16
.
*/
public int getIconHeight()
{
return 16;
}
/**
* Paints the icon at the specified location, using colors from the
* current theme.
*
* @param c the component (ignored).
* @param g the graphics device.
* @param x the x-coordinate for the top-left of the icon.
* @param y the y-coordinate for the top-left of the icon.
*/
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color saved = g.getColor();
g.setColor(MetalLookAndFeel.getBlack());
g.drawLine(x + 3, y + 1, x + 12, y + 1);
g.drawLine(x + 2, y + 2, x + 2, y + 8);
g.drawLine(x + 13, y + 2, x + 13, y + 8);
g.drawLine(x + 3, y + 9, x + 3, y + 9);
g.drawLine(x + 12, y + 9, x + 12, y + 9);
g.drawRect(x + 1, y + 10, 13, 4);
g.drawLine(x + 5, y + 3, x + 10, y + 3);
g.drawLine(x + 5, y + 8, x + 10, y + 8);
g.drawLine(x + 4, y + 4, x + 4, y + 7);
g.drawLine(x + 11, y + 4, x + 11, y + 7);
g.setColor(MetalLookAndFeel.getPrimaryControl());
g.fillRect(x + 5, y + 4, 6, 4);
g.setColor(MetalLookAndFeel.getControlShadow());
g.drawLine(x + 6, y + 12, x + 8, y + 12);
g.drawLine(x + 10, y + 12, x + 12, y + 12);
g.setColor(saved);
}
}
/** The icon returned by {@link #getCheckBoxIcon()}. */
private static Icon checkBoxIcon;
/** The icon returned by {@link #getCheckBoxMenuItemIcon()}. */
private static Icon checkBoxMenuItemIcon;
/** The icon returned by {@link #getFileChooserDetailViewIcon()}. */
private static Icon fileChooserDetailViewIcon;
/** The icon returned by {@link #getFileChooserHomeFolderIcon()}. */
private static Icon fileChooserHomeFolderIcon;
/** The icon returned by {@link #getFileChooserListViewIcon()}. */
private static Icon fileChooserListViewIcon;
/** The icon returned by {@link #getFileChooserNewFolderIcon()}. */
private static Icon fileChooserNewFolderIcon;
/** The icon returned by {@link #getFileChooserUpFolderIcon()}. */
private static Icon fileChooserUpFolderIcon;
/** The cached RadioButtonIcon instance. */
private static RadioButtonIcon radioButtonIcon;
/** The icon returned by {@link #getRadioButtonMenuItemIcon()}. */
private static Icon radioButtonMenuItemIcon;
/** The icon returned by {@link #getInternalFrameDefaultMenuIcon()}. */
private static Icon internalFrameDefaultMenuIcon;
/** The icon returned by {@link #getTreeComputerIcon()}. */
private static Icon treeComputerIcon;
/** The icon instance returned by {@link #getTreeFloppyDriveIcon()}. */
private static Icon treeFloppyDriveIcon;
/** The icon instance returned by {@link #getTreeHardDriveIcon()}. */
private static Icon treeHardDriveIcon;
/** The icon instance returned by {@link #getHorizontalSliderThumbIcon()}. */
private static Icon horizontalSliderThumbIcon;
/** The icon instance returned by {@link #getVerticalSliderThumbIcon()}. */
private static Icon verticalSliderThumbIcon;
/**
* Creates a new instance. All the methods are static, so creating an
* instance isn't necessary.
*/
public MetalIconFactory()
{
// Nothing to do here.
}
/**
* Returns an icon for use when rendering the {@link JCheckBox} component.
*
* @return A check box icon.
*
* @since 1.3
*/
public static Icon getCheckBoxIcon()
{
if (checkBoxIcon == null)
checkBoxIcon = new MetalCheckBoxIcon();
return checkBoxIcon;
}
/**
* Returns an icon for use when rendering the {@link JCheckBoxMenuItem}
* component.
*
* @return An icon.
*/
public static Icon getCheckBoxMenuItemIcon()
{
if (checkBoxMenuItemIcon == null)
checkBoxMenuItemIcon = new CheckBoxMenuItemIcon();
return checkBoxMenuItemIcon;
}
/**
* Returns an icon for use by the {@link JFileChooser} component.
*
* @return An icon.
*/
public static Icon getFileChooserDetailViewIcon()
{
if (fileChooserDetailViewIcon == null)
fileChooserDetailViewIcon = new FileChooserDetailViewIcon();
return fileChooserDetailViewIcon;
}
/**
* Returns an icon for use by the {@link JFileChooser} component.
*
* @return An icon.
*/
public static Icon getFileChooserHomeFolderIcon()
{
if (fileChooserHomeFolderIcon == null)
fileChooserHomeFolderIcon = new FileChooserHomeFolderIcon();
return fileChooserHomeFolderIcon;
}
/**
* Returns an icon for use by the {@link JFileChooser} component.
*
* @return An icon.
*/
public static Icon getFileChooserListViewIcon()
{
if (fileChooserListViewIcon == null)
fileChooserListViewIcon = new FileChooserListViewIcon();
return fileChooserListViewIcon;
}
/**
* Returns an icon for use by the {@link JFileChooser} component.
*
* @return An icon.
*/
public static Icon getFileChooserNewFolderIcon()
{
if (fileChooserNewFolderIcon == null)
fileChooserNewFolderIcon = new FileChooserNewFolderIcon();
return fileChooserNewFolderIcon;
}
/**
* Returns an icon for use by the {@link JFileChooser} component.
*
* @return An icon.
*/
public static Icon getFileChooserUpFolderIcon()
{
if (fileChooserUpFolderIcon == null)
fileChooserUpFolderIcon = new FileChooserUpFolderIcon();
return fileChooserUpFolderIcon;
}
/**
* Returns an icon for RadioButtons in the Metal L&F.
*
* @return an icon for RadioButtons in the Metal L&F
*/
public static Icon getRadioButtonIcon()
{
if (radioButtonIcon == null)
radioButtonIcon = new RadioButtonIcon();
return radioButtonIcon;
}
/**
* Creates a new instance of the icon used in a {@link JRadioButtonMenuItem}.
*
* @return A new icon instance.
*/
public static Icon getRadioButtonMenuItemIcon()
{
if (radioButtonMenuItemIcon == null)
radioButtonMenuItemIcon = new RadioButtonMenuItemIcon();
return radioButtonMenuItemIcon;
}
/**
* Returns the icon used to display the thumb for a horizontally oriented
* {@link JSlider}.
*
* @return The icon.
*/
public static Icon getHorizontalSliderThumbIcon()
{
if (horizontalSliderThumbIcon == null)
horizontalSliderThumbIcon = new HorizontalSliderThumbIcon();
return horizontalSliderThumbIcon;
}
/**
* Creates a new icon used to represent the 'close' button in the title
* pane of a {@link JInternalFrame}.
*
* @param size the icon size.
*
* @return A close icon.
*/
public static Icon getInternalFrameCloseIcon(int size)
{
return new InternalFrameCloseIcon(size);
}
/**
* Creates a new icon for the menu in a {@link JInternalFrame}. This is the
* icon displayed at the top left of the frame.
*
* @return A menu icon.
*/
public static Icon getInternalFrameDefaultMenuIcon()
{
if (internalFrameDefaultMenuIcon == null)
internalFrameDefaultMenuIcon = new InternalFrameDefaultMenuIcon();
return internalFrameDefaultMenuIcon;
}
/**
* Creates a new icon for the 'maximize' button in a {@link JInternalFrame}.
*
* @param size the icon size in pixels.
*
* @return The icon.
*
* @see #getInternalFrameAltMaximizeIcon(int)
*/
public static Icon getInternalFrameMaximizeIcon(int size)
{
return new InternalFrameMaximizeIcon();
}
/**
* Returns the icon used for the minimize button in the frame title for a
* {@link JInternalFrame}.
*
* @param size the icon size in pixels (ignored by this implementation).
*
* @return The icon.
*/
public static Icon getInternalFrameMinimizeIcon(int size)
{
return new InternalFrameMinimizeIcon();
}
/**
* Creates a new icon for the 'restore' button in a {@link JInternalFrame}
* that has been maximised.
*
* @param size the icon size in pixels.
*
* @return The icon.
*
* @see #getInternalFrameMaximizeIcon(int)
*/
public static Icon getInternalFrameAltMaximizeIcon(int size)
{
return new InternalFrameAltMaximizeIcon(size);
}
/**
* Returns the icon used to display the thumb for a vertically oriented
* {@link JSlider}.
*
* @return The icon.
*/
public static Icon getVerticalSliderThumbIcon()
{
if (verticalSliderThumbIcon == null)
verticalSliderThumbIcon = new VerticalSliderThumbIcon();
return verticalSliderThumbIcon;
}
/**
* Creates and returns a new tree folder icon.
*
* @return A new tree folder icon.
*/
public static Icon getTreeFolderIcon()
{
return new TreeFolderIcon();
}
/**
* Creates and returns a new tree leaf icon.
*
* @return A new tree leaf icon.
*/
public static Icon getTreeLeafIcon()
{
return new TreeLeafIcon();
}
/**
* Creates and returns a tree control icon.
*
* @param isCollapsed a flag that controls whether the icon is in the
* collapsed or expanded state.
*
* @return A tree control icon.
*/
public static Icon getTreeControlIcon(boolean isCollapsed)
{
return new TreeControlIcon(isCollapsed);
}
/**
* Returns a 16x16
icon representing a computer.
*
* @return The icon.
*/
public static Icon getTreeComputerIcon()
{
if (treeComputerIcon == null)
treeComputerIcon = new TreeComputerIcon();
return treeComputerIcon;
}
/**
* Returns a 16x16
icon representing a floppy disk.
*
* @return The icon.
*/
public static Icon getTreeFloppyDriveIcon()
{
if (treeFloppyDriveIcon == null)
treeFloppyDriveIcon = new TreeFloppyDriveIcon();
return treeFloppyDriveIcon;
}
/**
* Returns a 16x16
icon representing a hard disk.
*
* @return The icon.
*/
public static Icon getTreeHardDriveIcon()
{
if (treeHardDriveIcon == null)
treeHardDriveIcon = new TreeHardDriveIcon();
return treeHardDriveIcon;
}
/**
* Returns a new instance of a 4 x 8 icon showing a small black triangle that
* points to the right. This is displayed in menu items that have a
* sub menu.
*
* @return The icon.
*/
public static Icon getMenuArrowIcon()
{
if (menuArrow == null)
menuArrow = new Icon()
{
public int getIconHeight()
{
return 8;
}
public int getIconWidth()
{
return 4;
}
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color saved = g.getColor();
g.setColor(Color.BLACK);
for (int i = 0; i < 4; i++)
g.drawLine(x + i, y + i, x + i, y + 7 - i);
g.setColor(saved);
}
};
return menuArrow;
}
/**
* Returns a new instance of a 4 x 8 icon showing a small black triangle that
* points to the right. This is displayed in menu items that have a sub menu.
*
* @return The icon.
*/
public static Icon getMenuItemArrowIcon()
{
if (menuItemArrow == null)
menuItemArrow = new Icon()
{
public int getIconHeight()
{
return 8;
}
public int getIconWidth()
{
return 4;
}
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color saved = g.getColor();
g.setColor(Color.BLACK);
for (int i = 0; i < 4; i++)
g.drawLine(x + i, y + i, x + i, y + 7 - i);
g.setColor(saved);
}
};
return menuItemArrow;
}
/**
* Returns a new instance of a 13 x 13 icon showing a small black check mark.
*
* @return The icon.
*/
public static Icon getMenuItemCheckIcon()
{
return new Icon()
{
public int getIconHeight()
{
return 13;
}
public int getIconWidth()
{
return 13;
}
public void paintIcon(Component c, Graphics g, int x, int y)
{
Color saved = g.getColor();
g.setColor(Color.BLACK);
g.drawLine(3 + x, 5 + y, 3 + x, 9 + y);
g.drawLine(4 + x, 5 + y, 4 + x, 9 + y);
g.drawLine(5 + x, 7 + y, 9 + x, 3 + y);
g.drawLine(5 + x, 8 + y, 9 + x, 4 + y);
g.setColor(saved);
}
};
}
}