Statistics
| Revision:

gvsig-raster / org.gvsig.raster.tools / trunk / org.gvsig.raster.tools / org.gvsig.raster.tools.app.basic / src / main / java / org / gvsig / raster / tools / app / basic / tool / filter / regionalpha / RegionAlphaListManager.java @ 2125

History | View | Annotate | Download (5.54 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
        /*
108
         * (non-Javadoc)
109
         * @see org.gvsig.raster.grid.filter.IRasterFilterListManager#addFilter(java.lang.Class, org.gvsig.raster.dataset.Params)
110
         */
111
        @SuppressWarnings("unchecked")
112
        public void addFilter(Class classFilter, Params params) throws FilterTypeException {
113
                if (classFilter.equals(RegionAlphaFilter.class)) {
114
                        ArrayList<ROI> rois = new ArrayList<ROI>();
115
                        Boolean inverse = new Boolean(false);
116
                        int alpha = 255;
117

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

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

    
141
        public int createFilterListFromStrings(List<String> filters, String fil, int filteri) throws FilterTypeException {
142
                return filteri;
143
        }
144

    
145
        public List<String> getStringsFromFilterList(List<String> filterList, RasterFilter rf) {
146
                return filterList;
147
        }
148
        
149
        public RasterFilterList getFilterList() {
150
                return filterList;
151
        }
152
        
153
        public void setFilterList(RasterFilterList filterList) {
154
                this.filterList = filterList;
155
        }
156
}