Statistics
| Revision:

svn-gvsig-desktop / trunk / libraries / libRaster / src / org / gvsig / raster / grid / filter / bands / HSLToRGBFilter.java @ 27361

History | View | Annotate | Download (4.09 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2007 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
package org.gvsig.raster.grid.filter.bands;
20

    
21
import org.gvsig.raster.buffer.RasterBuffer;
22
import org.gvsig.raster.dataset.IBuffer;
23
import org.gvsig.raster.dataset.Params;
24
import org.gvsig.raster.grid.filter.RasterFilter;
25
import org.gvsig.raster.util.ColorConversion;
26
/**
27
 * <P>
28
 * Clase base para los filtros de conversi?n de HSL a RGB. La entrada ser? 
29
 * siempre un raster de 3 bandas que ser?n tomadas como HSL.
30
 * </P>
31
 *
32
 * @version 06/06/2007
33
 * @author Nacho Brodin (nachobrodin@gmail.com)
34
 */
35
public class HSLToRGBFilter extends RasterFilter {
36
        protected IBuffer          rasterAlpha      = null;
37
        public static String[]     names            = new String[] { "hsltorgb" };
38
        protected ColorConversion  colorConversion  = null;
39
        protected int[]            renderBands      = null;
40

    
41
        /**
42
         * Constructor
43
         */
44
        public HSLToRGBFilter() {
45
                super();
46
                setName(names[0]);
47
        }
48

    
49
        /*
50
         * (non-Javadoc)
51
         * @see org.gvsig.raster.grid.filter.RasterFilter#pre()
52
         */
53
        public void pre() {
54
                exec = true;
55
                raster = (RasterBuffer) params.get("raster");
56
                int[] rb = (int[]) params.get("renderBands");
57
                
58
                switch (raster.getBandCount()) {
59
                case 1:renderBands = new int[]{0, 0, 0}; break;
60
                case 2:renderBands = rb; break;
61
                case 3:renderBands = new int[]{0, 1, 2}; break;
62
                }
63
                //Mantenemos los valores de -1 ya que esas bandas no se procesan
64
                for(int i = 0; i < renderBands.length; i++)
65
                        if(rb[i] == -1)
66
                                renderBands[i] = -1;
67
                
68
                if(raster != null) {
69
                        height = raster.getHeight();
70
                        width = raster.getWidth();
71
                        if(raster.getBandCount() >= 3)
72
                                rasterResult = RasterBuffer.getBuffer(IBuffer.TYPE_BYTE, raster.getWidth(), raster.getHeight(), raster.getBandCount(), true);
73
                        else
74
                                rasterResult = RasterBuffer.getBuffer(IBuffer.TYPE_BYTE, raster.getWidth(), raster.getHeight(), 3, true);
75
                }
76
                if(colorConversion == null)
77
                        colorConversion = new ColorConversion();
78
        }
79

    
80
        /*
81
         * (non-Javadoc)
82
         * @see org.gvsig.raster.grid.filter.RasterFilter#getGroup()
83
         */
84
        public String getGroup() {
85
                return "colores";
86
        }
87

    
88
        /*
89
         * (non-Javadoc)
90
         * @see org.gvsig.raster.grid.filter.RasterFilter#getNames()
91
         */
92
        public String[] getNames() {
93
                return names;
94
        }
95

    
96
        /*
97
         * (non-Javadoc)
98
         * @see org.gvsig.raster.grid.filter.RasterFilter#getResult(java.lang.String)
99
         */
100
        public Object getResult(String name) {
101
                if (name.equals("raster"))
102
                        return (Object) this.rasterResult;
103
                return null;
104
        }
105

    
106
        /*
107
         * (non-Javadoc)
108
         * @see org.gvsig.raster.grid.filter.RasterFilter#getUIParams(java.lang.String)
109
         */
110
        public Params getUIParams(String nameFilter) {
111
                Params params = new Params();
112
                return params;
113
        }
114

    
115
        public void post() {
116
        
117
        }
118

    
119
        public void process(int x, int y) throws InterruptedException {
120
        }
121

    
122
        /*
123
         * (non-Javadoc)
124
         * @see org.gvsig.raster.grid.filter.RasterFilter#getOutRasterDataType()
125
         */
126
        public int getOutRasterDataType() {
127
                return IBuffer.TYPE_BYTE;
128
        }
129

    
130
        /*
131
         * (non-Javadoc)
132
         * @see org.gvsig.raster.grid.filter.RasterFilter#isVisible()
133
         */
134
        public boolean isVisible() {
135
                //IRasterDataSource datasource = (IRasterDataSource)getEnv().get("MultiRasterDataset");
136
                //return (datasource != null && datasource.getBandCount() >= 3);
137
                return true;
138
        }
139

    
140
        /*
141
         * (non-Javadoc)
142
         * @see org.gvsig.raster.grid.filter.RasterFilter#getInRasterDataType()
143
         */
144
        public int getInRasterDataType() {
145
                return IBuffer.TYPE_BYTE;
146
        }
147
}