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: TitledTabBorderSizePolicy.java,v 1.8 2005/02/16 11:28:15 jesper Exp $
23: package net.infonode.tabbedpanel.titledtab;
24:
25: import net.infonode.util.Enum;
26:
27: /**
28: * TitledTabBorderSizePolicy defines how the insets for the titled tab
29: * should be calculated based on the borders for the different tab states.
30: * If the states have borders with different insets titled tab can use the same
31: * insets for each state based on the maximum insets (top, left, bottom,
32: * right) for each state. The compensated insets will be added on the inside
33: * of the borders.
34: *
35: * @author $Author: jesper $
36: * @version $Revision: 1.8 $
37: * @see TitledTab
38: * @see TitledTabProperties
39: */
40: public final class TitledTabBorderSizePolicy extends Enum {
41: private static final long serialVersionUID = 5570620861429391549L;
42:
43: /**
44: * Equal size policy. This means that if the different tab states have
45: * borders with different insets titled tab will use the same insets for
46: * each state based on the maximum insets (top, left, bottom, right)
47: * for each state. The compensated insets will be added on the inside of
48: * the borders.
49: */
50: public static final TitledTabBorderSizePolicy EQUAL_SIZE = new TitledTabBorderSizePolicy(
51: 0, "Equal Size");
52:
53: /**
54: * Individual size policy. This means that titled tab will use the borders
55: * for each state as they are and not modify any insets. If the borders for
56: * the different states have different insets, then the titled tab's insets
57: * will be different depending on the state the tab is currently in.
58: */
59: public static final TitledTabBorderSizePolicy INDIVIDUAL_SIZE = new TitledTabBorderSizePolicy(
60: 1, "Individual Size");
61:
62: /**
63: * An array with all size policies
64: */
65: public static final TitledTabBorderSizePolicy[] SIZE_POLICIES = new TitledTabBorderSizePolicy[] {
66: EQUAL_SIZE, INDIVIDUAL_SIZE };
67:
68: private TitledTabBorderSizePolicy(int value, String name) {
69: super (value, name);
70: }
71:
72: /**
73: * Gets the titled tab border size policies.
74: *
75: * @return the titled tab border size policies
76: * @since ITP 1.1.0
77: */
78: public static TitledTabBorderSizePolicy[] getSizePolicies() {
79: return (TitledTabBorderSizePolicy[]) SIZE_POLICIES.clone();
80: }
81: }
|