01: /**
02: * L2FProd.com Common Components 7.3 License.
03: *
04: * Copyright 2005-2007 L2FProd.com
05: *
06: * Licensed under the Apache License, Version 2.0 (the "License");
07: * you may not use this file except in compliance with the License.
08: * You may obtain a copy of the License at
09: *
10: * http://www.apache.org/licenses/LICENSE-2.0
11: *
12: * Unless required by applicable law or agreed to in writing, software
13: * distributed under the License is distributed on an "AS IS" BASIS,
14: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15: * See the License for the specific language governing permissions and
16: * limitations under the License.
17: */package com.l2fprod.common.swing.plaf;
18:
19: /**
20: * Each new component type of the library will contribute an addon to
21: * the LookAndFeelAddons. A <code>ComponentAddon</code> is the
22: * equivalent of a {@link javax.swing.LookAndFeel}but focused on one
23: * component. <br>
24: *
25: * @author <a href="mailto:fred@L2FProd.com">Frederic Lavigne</a>
26: */
27: public interface ComponentAddon {
28:
29: /**
30: * @return the name of this addon
31: */
32: String getName();
33:
34: /**
35: * Initializes this addon (i.e register UI classes, colors, fonts,
36: * borders, any UIResource used by the component class). When
37: * initializing, the addon can register different resources based on
38: * the addon or the current look and feel.
39: *
40: * @param addon the current addon
41: */
42: void initialize(LookAndFeelAddons addon);
43:
44: /**
45: * Uninitializes this addon.
46: *
47: * @param addon
48: */
49: void uninitialize(LookAndFeelAddons addon);
50:
51: }
|