Statistics
| Revision:

gvsig-raster / org.gvsig.raster.tools / branches / org.gvsig.raster.tools_dataaccess_refactoring / org.gvsig.raster.tools.app.basic / src / main / java / org / gvsig / raster / tools / app / basic / tool / filter / regionalpha / RegionAlphaListManager.java @ 2308

History | View | Annotate | Download (5.4 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
package org.gvsig.raster.tools.app.basic.tool.filter.regionalpha;
23

    
24
import java.util.ArrayList;
25
import java.util.List;
26

    
27
import org.gvsig.fmap.dal.coverage.datastruct.Params;
28
import org.gvsig.fmap.dal.coverage.exception.FilterTypeException;
29
import org.gvsig.fmap.dal.coverage.grid.RasterFilter;
30
import org.gvsig.fmap.dal.coverage.grid.RasterFilterList;
31
import org.gvsig.fmap.dal.coverage.grid.RasterFilterListManager;
32
import org.gvsig.fmap.dal.coverage.grid.RegistrableFilterListener;
33
import org.gvsig.raster.roi.ROI;
34
import org.gvsig.tools.ToolsLocator;
35
import org.gvsig.tools.extensionpoint.ExtensionPoint;
36
import org.gvsig.tools.extensionpoint.ExtensionPointManager;
37

    
38
public class RegionAlphaListManager implements RasterFilterListManager {
39
        protected RasterFilterList        filterList = null;
40

    
41
        /**
42
         * Default constructor. Sets the filter list.
43
         * @param filterList
44
         */
45
        public RegionAlphaListManager(RasterFilterList filterList) {
46
                this.filterList = filterList;
47
        }
48

    
49
        /**
50
         * Registrar los manager en los puntos de extension
51
         */
52
        public static void register() {
53
                ExtensionPointManager extensionPoints =ToolsLocator.getExtensionPointManager();
54
                ExtensionPoint point=extensionPoints.add("RasterFilter");
55
                point.append("RegionAlpha", "", RegionAlphaListManager.class);
56
        }
57
        
58
        public boolean isDataTypeSupported(int dataType) {
59
                return true;
60
        }
61
        
62
        public Class<?> getFilterClassByID(String id) {
63
                if( id.compareTo("regionalpha") == 0)
64
                        return RegionAlphaFilter.class;
65
                return null;
66
        }
67

    
68
        public void addRegionAlphaFilter(List<ROI> rois, int alpha, Boolean inverse) throws FilterTypeException {
69
                RasterFilter filter = new RegionAlphaByteFilter();
70

    
71
                //Cuando el filtro esta creado, tomamos los valores y lo a?adimos a la pila
72
                if (filter != null) {
73
                        filter.addParam("rois", rois);
74
                        filter.addParam("inverse", inverse);
75
                        filter.addParam("alpha", Integer.valueOf(alpha));
76
                        filterList.add(filter);
77
                }
78
        }
79

    
80
        public List<Class<?>> getRasterFilterList() {
81
                List<Class<?>> filters = new ArrayList<Class<?>>();
82
                filters.add(RegionAlphaFilter.class);
83
                return filters;
84
        }
85
        
86
        @SuppressWarnings("unchecked")
87
        public RasterFilter createFilter(Params params) {
88
                List<ROI> rois = ((List<ROI>) params.getParamById("rois").getDefaultValue());
89
                Boolean inverse = ((Boolean) params.getParamById("inverse").getDefaultValue());
90
                Integer alpha = ((Integer) params.getParamById("Alpha").getDefaultValue());
91
                
92
                RasterFilter filter = new RegionAlphaByteFilter();
93
                filter.addParam("rois", rois);
94
                filter.addParam("inverse", inverse);
95
                filter.addParam("alpha", alpha);
96
                return filter;
97
        }
98
        
99
        /*
100
         * (non-Javadoc)
101
         * @see org.gvsig.fmap.dal.coverage.grid.RasterFilterListManager#addFilter(org.gvsig.fmap.dal.coverage.datastruct.Params)
102
         */
103
        public void addFilter(Params params) throws FilterTypeException {
104
                addFilter(RegionAlphaFilter.class, params);
105
        }
106

    
107
        @SuppressWarnings("unchecked")
108
        public void addFilter(Class<?> classFilter, Params params) throws FilterTypeException {
109
                if (classFilter.equals(RegionAlphaFilter.class)) {
110
                        ArrayList<ROI> rois = new ArrayList<ROI>();
111
                        Boolean inverse = new Boolean(false);
112
                        int alpha = 255;
113

    
114
                        Params paramsUI = null;
115
                        for (int i = 0; i < params.getNumParams(); i++) {
116
                                if (params.getParam(i).getId().equals("Panel") &&
117
                                        params.getParam(i).getDefaultValue() instanceof RegistrableFilterListener) {
118
                                        paramsUI = ((RegistrableFilterListener) params.getParam(i).getDefaultValue()).getParams();
119
                                }
120
                                if (params.getParam(i).getId().equals("Alpha") && params.getParam(i).getDefaultValue() instanceof Integer) {
121
                                        alpha = ((Integer) params.getParam(i).getDefaultValue()).intValue();
122
                                }
123
                        }
124

    
125
                        if (paramsUI != null) {
126
                                for (int i = 0; i < paramsUI.getNumParams(); i++) {
127
                                        if (paramsUI.getParam(i).getId().equals("rois"))
128
                                                rois = (ArrayList<ROI>) paramsUI.getParam(i).getDefaultValue();
129
                                        if (paramsUI.getParam(i).getId().equals("inverse"))
130
                                                inverse = (Boolean) paramsUI.getParam(i).getDefaultValue();
131
                                }
132
                        }
133
                        addRegionAlphaFilter(rois, alpha, inverse);
134
                }
135
        }
136

    
137
        public int createFilterListFromStrings(List<String> filters, String fil, int filteri) throws FilterTypeException {
138
                return filteri;
139
        }
140

    
141
        public List<String> getStringsFromFilterList(List<String> filterList, RasterFilter rf) {
142
                return filterList;
143
        }
144
        
145
        public RasterFilterList getFilterList() {
146
                return filterList;
147
        }
148
        
149
        public void setFilterList(RasterFilterList filterList) {
150
                this.filterList = filterList;
151
        }
152
}