Package com.lightcrafts.jai.opimage

Source Code of com.lightcrafts.jai.opimage.RedMaskBlackener

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

package com.lightcrafts.jai.opimage;

import com.lightcrafts.mediax.jai.PointOpImage;
import com.lightcrafts.mediax.jai.ImageLayout;

import java.awt.image.*;
import java.awt.color.ColorSpace;
import java.awt.*;
import java.util.Map;

import sun.awt.image.ShortInterleavedRaster;
import sun.awt.image.ByteInterleavedRaster;

/**
* Copyright (C) 2007 Light Crafts, Inc.
* User: fabio
* Date: Mar 14, 2007
* Time: 5:31:50 PM
*/
public class RedMaskBlackener extends PointOpImage {
    private static short powTable[] = new short[0x10000];

    static {
        for (int i = 0; i < 0x10000; i++)
            powTable[i] = (short) (0xffff * Math.pow(i / (double) 0xffff, 1.4D));
    }

    public RedMaskBlackener(RenderedImage source, RenderedImage mask, Map config) {
        super(source, mask, new ImageLayout(source), config, true);
        permitInPlaceOperation();
    }

    protected void computeRect(Raster[] sources,
                               WritableRaster dest,
                               Rectangle destRect) {
        ushortLoop((ShortInterleavedRaster) sources[0], (ByteInterleavedRaster) sources[1], (ShortInterleavedRaster) dest);
    }

    protected void ushortLoop(ShortInterleavedRaster src, ByteInterleavedRaster mask, ShortInterleavedRaster dst) {
        int width = src.getWidth();
        int height = src.getHeight();

        short dstData[] = dst.getDataStorage();
        int dstBandOffsets[] = dst.getDataOffsets();
        int dstLineStride = dst.getScanlineStride();
        int dstPixelStride = dst.getPixelStride();

        short srcData[] = src.getDataStorage();
        int srcBandOffsets[] = src.getDataOffsets();
        int srcLineStride = src.getScanlineStride();
        int srcPixelStride = src.getPixelStride();

        byte maskData[] = mask.getDataStorage();
        int maskBandOffsets[] = mask.getDataOffsets();
        int maskLineStride = mask.getScanlineStride();
        int maskPixelStride = mask.getPixelStride();

        int srcROffset = srcBandOffsets[0];
        int srcGOffset = srcBandOffsets[1];
        int srcBOffset = srcBandOffsets[2];

        int dstROffset = dstBandOffsets[0];
        int dstGOffset = dstBandOffsets[1];
        int dstBOffset = dstBandOffsets[2];

        int maskOffset = maskBandOffsets[0];

        for (int row = 0; row < height; row++) {
            for (int col = 0; col < width; col++) {
                short r = srcData[srcPixelStride * col + row * srcLineStride + srcROffset];
                short g = srcData[srcPixelStride * col + row * srcLineStride + srcGOffset];
                short b = srcData[srcPixelStride * col + row * srcLineStride + srcBOffset];

                int m = 0xff & maskData[col + row * maskLineStride + maskOffset];

                if (m == 0) {
                    dstData[dstPixelStride * col + row * dstLineStride + dstROffset] = r;
                    dstData[dstPixelStride * col + row * dstLineStride + dstGOffset] = g;
                    dstData[dstPixelStride * col + row * dstLineStride + dstBOffset] = b;
                } else {
                    int gg = powTable[0xffff & g];

                    int r1 = ((255 - m) * (0xffff & r) + m * gg) / 255;
                    int g1 = ((255 - m) * (0xffff & g) + m * gg) / 255;
                    int b1 = ((255 - m) * (0xffff & b) + m * gg) / 255;

                    dstData[dstPixelStride * col + row * dstLineStride + dstROffset] = (short) r1;
                    dstData[dstPixelStride * col + row * dstLineStride + dstGOffset] = (short) g1;
                    dstData[dstPixelStride * col + row * dstLineStride + dstBOffset] = (short) b1;
                }
            }
        }
    }
}
TOP

Related Classes of com.lightcrafts.jai.opimage.RedMaskBlackener

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.