01: /*
02: * Copyright (C) 2004 NNL Technology AB
03: * Visit www.infonode.net for information about InfoNode(R)
04: * products and how to contact NNL Technology AB.
05: *
06: * This program is free software; you can redistribute it and/or
07: * modify it under the terms of the GNU General Public License
08: * as published by the Free Software Foundation; either version 2
09: * of the License, or (at your option) any later version.
10: *
11: * This program is distributed in the hope that it will be useful,
12: * but WITHOUT ANY WARRANTY; without even the implied warranty of
13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14: * GNU General Public License for more details.
15: *
16: * You should have received a copy of the GNU General Public License
17: * along with this program; if not, write to the Free Software
18: * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
19: * MA 02111-1307, USA.
20: */
21:
22: // $Id: DockIcon.java,v 1.5 2005/12/04 13:46:03 jesper Exp $
23: package net.infonode.gui.icon.button;
24:
25: import net.infonode.gui.GraphicsUtil;
26:
27: import java.awt.*;
28:
29: /**
30: * @author johan
31: */
32: public class DockIcon extends AbstractButtonIcon {
33: private static final long serialVersionUID = 1;
34:
35: public DockIcon() {
36: super ();
37: }
38:
39: public DockIcon(Color c) {
40: super (c);
41: }
42:
43: public DockIcon(Color c, int size) {
44: super (c, size);
45: }
46:
47: public DockIcon(int size) {
48: super (size);
49: }
50:
51: protected void paintIcon(Component c, final Graphics g,
52: final int x1, final int y1, final int x2, final int y2) {
53: int xOffs = (x2 - x1) > 6 ? 1 : 0;
54: int yOffs = xOffs;
55:
56: // Bottom left
57: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs, y2 - yOffs, x1
58: + xOffs, y2 - yOffs - 3);
59: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs, y2 - yOffs, x1
60: + xOffs + 3, y2 - yOffs);
61:
62: // Top right
63: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs - 1, y1 + yOffs,
64: x2 - xOffs - 1, y1 + yOffs + 2);
65: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs - 2, y1 + yOffs
66: - 1, x2 - xOffs - 2, y1 + yOffs - 1);
67:
68: // Lines
69: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs - 1, y1 + yOffs,
70: x1 + xOffs, y2 - yOffs - 1);
71: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs - 1, y1 + yOffs
72: + 1, x1 + xOffs, y2 - yOffs);
73: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs - 1, y1 + yOffs
74: + 2, x1 + xOffs + 1, y2 - yOffs);
75: }
76: }
|