Statistics
| Revision:

svn-gvsig-desktop / branches / v2_0_0_prep / libraries / org.gvsig.symbology / org.gvsig.symbology.lib / org.gvsig.symbology.lib.impl / src / main / java / org / gvsig / symbology / fmap / mapcontext / rendering / legend / impl / AbstractLegend.java @ 34978

History | View | Annotate | Download (6.65 KB)

1
/* gvSIG. Geographic Information System of the Valencian Government
2
 *
3
 * Copyright (C) 2007-2008 Infrastructures and Transports Department
4
 * of the Valencian Government (CIT)
5
 * 
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * 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., 51 Franklin Street, Fifth Floor, Boston, 
19
 * MA  02110-1301, USA.
20
 * 
21
 */
22

    
23
package org.gvsig.symbology.fmap.mapcontext.rendering.legend.impl;
24

    
25
import java.lang.ref.Reference;
26
import java.util.ArrayList;
27
import java.util.List;
28

    
29
import org.gvsig.fmap.mapcontext.MapContextLocator;
30
import org.gvsig.fmap.mapcontext.MapContextManager;
31
import org.gvsig.fmap.mapcontext.rendering.legend.ILegend;
32
import org.gvsig.fmap.mapcontext.rendering.legend.events.LegendContentsChangedListener;
33
import org.gvsig.fmap.mapcontext.rendering.legend.events.SymbolLegendEvent;
34
import org.gvsig.fmap.mapcontext.rendering.symbols.SymbolManager;
35
import org.gvsig.tools.ToolsLocator;
36
import org.gvsig.tools.dynobject.DynStruct;
37
import org.gvsig.tools.observer.Observer;
38
import org.gvsig.tools.observer.impl.BaseWeakReferencingObservable;
39
import org.gvsig.tools.persistence.PersistenceManager;
40
import org.gvsig.tools.persistence.PersistentState;
41
import org.gvsig.tools.persistence.exception.PersistenceException;
42
import org.gvsig.tools.util.Callable;
43
import org.slf4j.Logger;
44
import org.slf4j.LoggerFactory;
45

    
46
/**
47
 * Abstract class that implements the interface for legends.It is considered as
48
 * the father of all XXXLegends and will implement all the methods that these
49
 * classes had not developed.
50
 * 
51
 * @author 2005-2008 jaume dominguez faus - jaume.dominguez@iver.es
52
 * @author 2008 -    pepe vidal salvador - jose.vidal.salvador@iver.es
53
 * @author 2009-     <a href="cordinyana@gvsig.org">C?sar Ordi?ana</a> - gvSIG team
54
 */
55
public abstract class AbstractLegend implements ILegend {
56

    
57
        public static final String LEGEND_PERSISTENCE_DEFINITION_NAME = "Legend";
58

    
59
//        private static final String FIELD_LISTENERS = "listeners";
60
//
61
//        private static final String FIELD_OBSERVABLE = "observable";
62

    
63
        private static final Logger LOG =
64
                        LoggerFactory.getLogger(AbstractLegend.class);
65

    
66
        /**
67
         * List of LegendContentsChangedListener.
68
         */
69
        private List<LegendContentsChangedListener> listeners =
70
                        new ArrayList<LegendContentsChangedListener>();
71

    
72
        private BaseWeakReferencingObservable delegateDrawingObservable = 
73
                        new BaseWeakReferencingObservable();
74
        
75
        private MapContextManager manager = MapContextLocator.getMapContextManager();
76

    
77
        public MapContextManager getManager() {
78
                return manager;
79
        }
80

    
81
        public SymbolManager getSymbolManager() {
82
                return manager.getSymbolManager();
83
        }
84

    
85
        public void addLegendListener(LegendContentsChangedListener listener) {
86
                if (listener != null && !listeners.contains(listener))
87
                        listeners.add(listener);
88
        }
89

    
90
        public void removeLegendListener(LegendContentsChangedListener listener) {
91
                listeners.remove(listener);
92
        }
93

    
94
        public void fireDefaultSymbolChangedEvent(SymbolLegendEvent event) {
95

    
96
                for (int i = 0; i < listeners.size(); i++) {
97
                        ((LegendContentsChangedListener) listeners.get(i))
98
                                        .symbolChanged(event);
99
                }
100
        }
101

    
102
        public LegendContentsChangedListener[] getListeners() {
103
                return (LegendContentsChangedListener[]) listeners
104
                                .toArray(new LegendContentsChangedListener[listeners.size()]);
105
        }
106
        
107
        public void addDrawingObserver(Observer observer) {
108
                delegateDrawingObservable.addObserver(observer);
109
        }
110

    
111
        public void deleteDrawingObserver(Observer observer) {
112
                delegateDrawingObservable.deleteObserver(observer);
113
        }
114

    
115
        public void deleteDrawingObservers() {
116
                delegateDrawingObservable.deleteObservers();
117
        }
118

    
119
        public void addObserver(Reference<Observer> ref) {
120
                delegateDrawingObservable.addObserver(ref);
121
        }
122

    
123
        public void beginComplexNotification() {
124
                delegateDrawingObservable.beginComplexNotification();
125
        }
126

    
127
        public int countObservers() {
128
                return delegateDrawingObservable.countObservers();
129
        }
130

    
131
        public void deleteObserver(Reference<Observer> ref) {
132
                delegateDrawingObservable.deleteObserver(ref);
133
        }
134

    
135
        public void disableNotifications() {
136
                delegateDrawingObservable.disableNotifications();
137
        }
138

    
139
        public void enableNotifications() {
140
                delegateDrawingObservable.enableNotifications();
141
        }
142

    
143
        public void endComplexNotification() {
144
                delegateDrawingObservable.endComplexNotification();
145
        }
146

    
147
        public boolean inComplex() {
148
                return delegateDrawingObservable.inComplex();
149
        }
150

    
151
        public boolean isEnabledNotifications() {
152
                return delegateDrawingObservable.isEnabledNotifications();
153
        }
154

    
155
        public void notifyObservers() {
156
                delegateDrawingObservable.notifyObservers();
157
        }
158

    
159
        public void notifyObservers(Object arg) {
160
                delegateDrawingObservable.notifyObservers(arg);
161
        }
162
        
163
        public ILegend cloneLegend() {
164
                try {
165
                        return (ILegend) clone();
166
                } catch (CloneNotSupportedException e) {
167
                        LOG.error("Error creating the clone of the legend: " + this, e);
168
                }
169
                return null;
170
    }
171

    
172
        public Object clone() throws CloneNotSupportedException {
173
                AbstractLegend legendClone = (AbstractLegend) super.clone();
174

    
175
                return legendClone;
176
        }
177

    
178
        public void loadFromState(PersistentState state)
179
                        throws PersistenceException {
180
                // Do nothing
181
        }
182

    
183
        public void saveToState(PersistentState state) throws PersistenceException {
184
                // Do nothing
185
        }
186

    
187
        public static class RegisterPersistence implements Callable {
188

    
189
                public Object call() throws Exception {
190
                        PersistenceManager manager = ToolsLocator.getPersistenceManager();
191
                        if( manager.getDefinition(LEGEND_PERSISTENCE_DEFINITION_NAME)==null ) {
192
                                @SuppressWarnings("unused")
193
                                DynStruct definition = manager.addDefinition(
194
                                                AbstractLegend.class, 
195
                                                LEGEND_PERSISTENCE_DEFINITION_NAME, 
196
                                                LEGEND_PERSISTENCE_DEFINITION_NAME + " persistence definition", 
197
                                                null, 
198
                                                null
199
                                        );
200
//                                        // Listeners
201
//                                        definition.addDynFieldList(FIELD_LISTENERS)
202
//                                                .setClassOfItems(LegendContentsChangedListener.class);
203
//                                        // Observable
204
//                                        definition.addDynFieldObject(FIELD_OBSERVABLE)
205
//                                                .setClassOfValue(BaseWeakReferencingObservable.class);
206
                        }
207
                        return Boolean.TRUE;
208
                }
209
                
210
        }
211

    
212
}