Statistics
| Revision:

svn-gvsig-desktop / tags / v1_0_2_Build_903 / frameworks / _fwAndami / src / com / iver / andami / plugins / IExtension.java @ 10704

History | View | Annotate | Download (4.86 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 *
19
 * For more information, contact:
20
 *
21
 *  Generalitat Valenciana
22
 *   Conselleria d'Infraestructures i Transport
23
 *   Av. Blasco Ib??ez, 50
24
 *   46010 VALENCIA
25
 *   SPAIN
26
 *
27
 *      +34 963862235
28
 *   gvsig@gva.es
29
 *      www.gvsig.gva.es
30
 *
31
 *    or
32
 *
33
 *   IVER T.I. S.A
34
 *   Salamanca 50
35
 *   46005 Valencia
36
 *   Spain
37
 *
38
 *   +34 963163400
39
 *   dac@iver.es
40
 */
41
package com.iver.andami.plugins;
42

    
43
/**
44
 * <p>
45
 * Una extensi?n es el mecanismo en la que los plugins pueden extender Andami.
46
 * En la aplicaci?n habr? una instancia de cada extensi?n, las cuales tienen
47
 * unos m?todos que ser?n ejecutados en respuesta a acciones del usuario. Las
48
 * extensiones pueden a?adir controles a la interfaz de usuario.  Pueden
49
 * a?adir men?s y herramientas de la barra de herramientas, de forma que al
50
 * ser seleccionadas se ejecute c?digo de la extensi?n. Adem?s de implementar esta
51
 * interfaz, una extensi?n ha de tener un constructor vac?o, el cual ser? invocado
52
 * para crear la instancia de la interfaz
53
 * </p>
54
 *
55
 * <p>
56
 * En un plugin correctamente implementado se crear? una instancia de cada
57
 * extensi?n. Tras la creaci?n se invocar? al m?todo inicializar y luego con
58
 * la aplicaci?n en marcha se invocar? a los m?todos isEnabled(), isVisible(),
59
 * repetidas veces para controlar la activaci?n y visualizaci?n de los
60
 * controles relacionados con la  extensi?n. Cuando se ejecuta una extensi?n
61
 * se ejecuta el metodo execute. Dicho m?todo se ejecuta en el thread de la
62
 * interfaz de usuario, por lo que dejar? la interfaz bloqueada. Si se quiere
63
 * dejar activa la interfaz se deber? lanzar un thread a parte. Al finalizar la
64
 * extensi?n, se ejecutar? el m?todo finalize.
65
 * </p>
66
 *
67
 * <p>
68
 * Esta clase est? "deprecated". En un futuro de deben sustituir las apariciones
69
 * de esta interfaz por la clase abstracta Extension
70
 * </p>
71
 */
72
public interface IExtension {
73
        /**
74
     * C?digo de inicializaci?n de la extension.
75
     */
76
    public void initialize();
77

    
78
    /**
79
     * M?todo que se ejecuta al finalizar la inicializaci?n de todas las extensiones
80
     *
81
     */
82
    public void postInitialize();
83
    /**
84
     * M?todo que se ejecuta al finalizar la extensi?n
85
     *
86
     */
87
    public void terminate();
88

    
89
    /**
90
     * M?todo que se ejecuta cuando el usuario acciona un control de la
91
     * extensi?n
92
     *
93
     * @param status DOCUMENT ME!
94
     * @param actionCommand DOCUMENT ME!
95
     *
96
     * @throws Throwable DOCUMENT ME!
97
     */
98
    public void execute(String actionCommand);
99

    
100
    /**
101
     * Este m?todo es invocado por la aplicaci?n para habilitar o desabilitar
102
     * el estado de los controles (men?s y botones de la barra de
103
     * herramientas) que ejecutan el c?digo de la extensi?n.
104
     *
105
     * @return true si el c?digo debe estar habilitado y false en caso
106
     *         contrario
107
     */
108
    public boolean isEnabled();
109

    
110
    /**
111
     * Este m?todo es invocado por la aplicaci?n para mostrar o esconder los
112
     * controles (men?s y botones de la barra de herramientas)  que ejecutan
113
     * el c?digo de la extensi?n.
114
     *
115
     * @return true si el c?digo debe estar visibles y false en caso contrario
116
     */
117
    public boolean isVisible();
118
    
119
    /**
120
     * Este m?todo es invocado por la aplicaci?n para habilitar o desabilitar los
121
     * controles (men?s y botones de la barra de herramientas) de la extensi?n
122
     * 'extension'. Este metodo es utilizado cuando la extesion actual esta
123
     * especificada en el par?metro de linea de comando 'exclusiveUI'
124
     *
125
     * @return true si el c?digo debe estar habilitado y false en caso
126
     *         contrario
127
     */
128
    public boolean isEnabled(IExtension extension);
129

    
130
    /**
131
     * Este m?todo es invocado por la aplicaci?n para mostrar o esconder los
132
     * controles (men?s y botones de la barra de herramientas) de la extensi?n
133
     * 'extension'. Este metodo es utilizado cuando la extesion actual esta
134
     * especificada en el par?metro de linea de comando 'exclusiveUI'
135
     *
136
     * @return true si el c?digo debe estar visibles y false en caso contrario
137
     */
138
    public boolean isVisible(IExtension extension);
139
}