All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.imajine.image.jai.PadPeriodicPlanarJAIOp Maven / Gradle / Ivy

/***********************************************************************************************************************
 *
 * Mistral - open source imaging engine
 * Copyright (C) 2003-2012 by Tidalwave s.a.s.
 *
 ***********************************************************************************************************************
 *
 * 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.
 *
 ***********************************************************************************************************************
 *
 * WWW: http://mistral.imajine.org
 * SCM: https://bitbucket.org/tidalwave/mistral-src
 *
 **********************************************************************************************************************/
package org.imajine.image.jai;

import java.awt.image.renderable.ParameterBlock;
import javax.media.jai.PlanarImage;
import javax.media.jai.BorderExtender;
import javax.media.jai.JAI;
import javax.media.jai.RenderedOp;
import org.imajine.image.EditableImage;
import org.imajine.image.op.OperationImplementation;
import org.imajine.image.op.PadPeriodicPlanarOp;
import lombok.extern.slf4j.Slf4j;

/***********************************************************************************************************************
 *
 * @author  Emmanuele Sordini
 * @author  Fabrizio Giudici
 * @version $Id: PadPeriodicPlanarJAIOp.java,v 20e39e8c9fac 2012/02/02 16:35:02 fabrizio $
 *
 **********************************************************************************************************************/
@Slf4j
public class PadPeriodicPlanarJAIOp extends OperationImplementation
  {
    @Override
    protected PlanarImage execute (PadPeriodicPlanarOp operation, final EditableImage image, PlanarImage planarImage)
      {
        /*
        int oldWidth = planarImage.getData().getWidth();
        int oldHeight = planarImage.getData().getHeight();

        int newWidth = JAIUtils.closestPower2Size(oldWidth);
        int newHeight = JAIUtils.closestPower2Size(oldHeight);
        int padx = (newWidth - oldWidth) / 2;
        int pady = (newHeight - oldHeight) / 2;

        // ADD TRANSLATE

        ParameterBlock pb = new ParameterBlock();
        pb.addSource(planarImage);
        pb.add(padx);
        pb.add(padx);
        pb.add(pady);
        pb.add(pady);
        pb.add(BorderExtender.createInstance(BorderExtender.BORDER_WRAP));
        RenderedOp border = JAI.create("border", pb);

        ImageLayout il = new ImageLayout();
        il.setMinX(0);
        il.setMinY(0);
        il.setWidth(newWidth);
        il.setHeight(newHeight);
        il.setTileGridXOffset(0);
        il.setTileGridYOffset(0);
        il.setTileHeight(newWidth);
        il.setTileWidth(newHeight);
        RenderingHints hints = new RenderingHints(JAI.KEY_IMAGE_LAYOUT, il);

        pb = new ParameterBlock();
        pb.addSource(border);

        planarImage = JAI.create("null", pb, hints);*/
        ParameterBlock pb = new ParameterBlock();
        int oldWidth = planarImage.getData().getWidth();
        int oldHeight = planarImage.getData().getHeight();

        int newWidth = JAIUtils.closestPower2Size(oldWidth);
        int newHeight = JAIUtils.closestPower2Size(oldHeight);
        int padx = (newWidth - oldWidth) / 2;
        int pady = (newHeight - oldHeight) / 2;

        pb.addSource(planarImage);
        pb.add((float)padx);
        pb.add((float)pady);

        RenderedOp trans = JAI.create("translate", pb);

        pb = new ParameterBlock();
        pb.addSource(trans);
        pb.add(padx);
        pb.add(padx);
        pb.add(pady);
        pb.add(pady);
        pb.add(BorderExtender.createInstance(BorderExtender.BORDER_WRAP));
        planarImage = JAI.create("border", pb);

        JAIUtils.logImage(log, ">>>> PadPeriodicPlanarOp returning", planarImage);

        return planarImage;
      }
  }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy