Package com.lightcrafts.model.ImageEditor

Source Code of com.lightcrafts.model.ImageEditor.RedEyesOperation

/* Copyright (C) 2005-2011 Fabio Riccardi */

package com.lightcrafts.model.ImageEditor;

import com.lightcrafts.model.SliderConfig;
import com.lightcrafts.model.OperationType;
import com.lightcrafts.model.Operation;
import com.lightcrafts.model.RedEyeOperation;
import com.lightcrafts.jai.utils.Transform;
import com.lightcrafts.jai.utils.Functions;
import com.lightcrafts.jai.opimage.RedMaskOpImage;
import com.lightcrafts.jai.opimage.RedMaskBlackener;
import com.lightcrafts.jai.operator.LCMSColorConvertDescriptor;

import com.lightcrafts.mediax.jai.PlanarImage;
import com.lightcrafts.mediax.jai.JAI;
import com.lightcrafts.mediax.jai.KernelJAI;
import com.lightcrafts.utils.LCMS;
import com.lightcrafts.utils.LCMS_ColorSpace;
import com.lightcrafts.ui.editor.EditorMode;

import java.text.DecimalFormat;
import java.awt.image.renderable.ParameterBlock;
import java.awt.image.RenderedImage;

/**
* Copyright (C) 2007 Light Crafts, Inc.
* User: fabio
* Date: Apr 7, 2005
* Time: 7:41:47 AM
*/

public class RedEyesOperation extends BlendedOperation implements RedEyeOperation {
    private final double step = 0.01;

    public RedEyesOperation(Rendering rendering) {
        super(rendering, type);
        addSliderKey("Tolerance");

        DecimalFormat format = new DecimalFormat("0.00");

        setSliderConfig("Tolerance", new SliderConfig(0.5, 1.5, tolerance, step, false, format));
    }

    public boolean neutralDefault() {
        return false;
    }

    static final OperationType type = new OperationTypeImpl("Red Eyes");

    private double tolerance = 1;

    public EditorMode getPreferredMode() {
        return EditorMode.REGION;
    }

    public void setSliderValue(String key, double value) {
        value = roundValue(key, value);

        if (key == "Tolerance" && tolerance != value) {
            tolerance = value;
        } else
            return;

        super.setSliderValue(key, value);
    }

    private class GaussMask extends BlendedTransform {
        Operation op;

        GaussMask(PlanarImage source, Operation op) {
            super(source);
            this.op = op;
        }

        public PlanarImage setFront() {
            if (hasMask()) {
                PlanarImage labImage = Functions.toColorSpace(back, new LCMS_ColorSpace(new LCMS.LABProfile()),
                                                              LCMSColorConvertDescriptor.RELATIVE_COLORIMETRIC, null);
                // PlanarImage labImage = Functions.toColorSpace(back, JAIContext.labColorSpace, null);

                RenderedImage redMask = new RedMaskOpImage(labImage, tolerance, null);

                ParameterBlock pb;

                KernelJAI morphKernel = new KernelJAI(3, 3, new float[] {1, 1, 1, 1, 0, 1, 1, 1, 1});
                pb = new ParameterBlock();
                pb.addSource(redMask);
                pb.add(morphKernel);
                redMask = JAI.create("dilate", pb, null);

                /* pb = new ParameterBlock();
                pb.addSource(redMask);
                pb.add(morphKernel);
                redMask = JAI.create("erode", pb, null); */

                KernelJAI blurKernel = Functions.getGaussKernel(4 * scale);
                pb = new ParameterBlock();
                pb.addSource(redMask);
                pb.add(blurKernel);
                redMask = JAI.create("LCSeparableConvolve", pb, null);

                return new RedMaskBlackener(back, redMask, null);

                // return Functions.fromByteToUShort(redMask, null);
            } else
                return back;
        }
    }

    protected void updateOp(Transform op) {
        op.update();
    }

    protected BlendedTransform createBlendedOp(PlanarImage source) {
        return new GaussMask(source, this);
    }

    public OperationType getType() {
        return type;
    }

    public boolean hasFooter() {
        return false;
    }
}
TOP

Related Classes of com.lightcrafts.model.ImageEditor.RedEyesOperation

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.