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: UndockIcon.java,v 1.7 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 UndockIcon extends AbstractButtonIcon {
33: private static final long serialVersionUID = 1;
34:
35: public UndockIcon() {
36: super ();
37: }
38:
39: public UndockIcon(Color c) {
40: super (c);
41: }
42:
43: public UndockIcon(Color c, int size) {
44: super (c, size);
45: }
46:
47: public UndockIcon(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: // Top right
57: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs - 3, y1 + yOffs,
58: x2 - xOffs, y1 + yOffs);
59: GraphicsUtil.drawOptimizedLine(g, x2 - xOffs, y1 + yOffs, x2
60: - xOffs, y1 + yOffs + 3);
61:
62: // Bottom left
63: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs + 1, y2 - yOffs
64: - 2, x1 + xOffs + 1, y2 - yOffs);
65: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs + 2, y2 - yOffs
66: + 1, x1 + xOffs + 2, y2 - yOffs + 1);
67:
68: // Lines
69: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs + 1, y2 - yOffs
70: - 2, x2 - xOffs - 1, y1 + yOffs);
71: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs + 1, y2 - yOffs
72: - 1, x2 - xOffs, y1 + yOffs);
73: GraphicsUtil.drawOptimizedLine(g, x1 + xOffs + 1, y2 - yOffs,
74: x2 - xOffs, y1 + yOffs + 1);
75: }
76: }
|