/* JAI-Ext - OpenSource Java Advanced Image Extensions Library * http://www.geo-solutions.it/ * Copyright 2014 GeoSolutions * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.apache.org/licenses/LICENSE-2.0 * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package it.geosolutions.jaiext.convolve; import it.geosolutions.jaiext.range.Range; import java.awt.RenderingHints; import java.awt.image.DataBuffer; import java.awt.image.RenderedImage; import java.awt.image.renderable.ParameterBlock; import java.awt.image.renderable.RenderedImageFactory; import javax.media.jai.BorderExtender; import javax.media.jai.ImageLayout; import javax.media.jai.KernelJAI; import javax.media.jai.ROI; import com.sun.media.jai.opimage.RIFUtil; public class ConvolveRIF implements RenderedImageFactory { public ConvolveRIF() { } public RenderedImage create(ParameterBlock pb, RenderingHints hints) { // Getting the Layout ImageLayout l = RIFUtil.getImageLayoutHint(hints); // Get BorderExtender from renderHints if present. BorderExtender extender = RIFUtil.getBorderExtenderHint(hints); // Getting source RenderedImage img = pb.getRenderedSource(0); // Getting parameters KernelJAI kernel = (KernelJAI) pb.getObjectParameter(0); ROI roi = (ROI) pb.getObjectParameter(1); Range nodata = (Range) pb.getObjectParameter(2); double destinationNoData = pb.getDoubleParameter(3); boolean skipNoData = (Boolean) pb.getObjectParameter(4); kernel = kernel.getRotatedKernel(); int dataType = pb.getRenderedSource(0).getSampleModel().getDataType(); boolean dataTypeOk = (dataType == DataBuffer.TYPE_BYTE || dataType == DataBuffer.TYPE_SHORT || dataType == DataBuffer.TYPE_INT); if (kernel.getWidth() == 3 && kernel.getHeight() == 3 && kernel.getXOrigin() == 1 && kernel.getYOrigin() == 1 && dataTypeOk) { return new Convolve3x3OpImage(img, extender, hints, l, kernel, roi, nodata, destinationNoData, skipNoData); } return new ConvolveGeneralOpImage(img, extender, hints, l, kernel, roi, nodata, destinationNoData, skipNoData); // if (kernel.getWidth() == 3 && kernel.getHeight() == 3 && // kernel.getXOrigin() == 1 && kernel.getYOrigin() == 1 && // dataTypeOk) { // return new Convolve3x3OpImage(img, // extender, // hints, // l, // kernel); // } else if (kernel.isSeparable()) { // return new SeparableConvolveOpImage(img, // extender, // hints, // l, // kernel); // // } else { // return new ConvolveOpImage(img, // extender, // hints, // l, // kernel); // } } }