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

org.jpedal.parser.image.mask.SMask Maven / Gradle / Ivy

There is a newer version: 7.15.25
Show newest version
/*
 * ===========================================
 * Java Pdf Extraction Decoding Access Library
 * ===========================================
 *
 * Project Info:  http://www.idrsolutions.com
 * Help section for developers at http://www.idrsolutions.com/support/
 *
 * (C) Copyright 1997-2017 IDRsolutions and Contributors.
 *
 * This file is part of JPedal/JPDF2HTML5
 *
 @LICENSE@
 *
 * ---------------
 * SMask.java
 * ---------------
 */
package org.jpedal.parser.image.mask;

import java.awt.Graphics2D;
import java.awt.RenderingHints;
import java.awt.image.BufferedImage;
import java.awt.image.DataBufferInt;

import org.jpedal.io.ColorSpaceConvertor;

/**
 *
 */
public class SMask {

    public static BufferedImage applyLuminosityMask(BufferedImage image, BufferedImage smask, final int[] tr, final boolean hasBC, final int bc) {

        if (smask == null) {
            return image;
        }

        if (smask.getType() != BufferedImage.TYPE_INT_ARGB) {
            smask = ColorSpaceConvertor.convertToARGB(smask);
        }
        if (image.getType() != BufferedImage.TYPE_INT_ARGB) {
            image = ColorSpaceConvertor.convertToARGB(image);
        }

        final int iw = image.getWidth();
        final int ih = image.getHeight();
        final int imageDim = iw * ih;

        final int sw = smask.getWidth();
        final int sh = smask.getHeight();
        final int smaskDim = sw * sh;

        if (imageDim < smaskDim) {
            image = scaleImage(image, sw, sh, BufferedImage.TYPE_INT_ARGB);
        } else if (smaskDim < imageDim) {
            smask = scaleImage(smask, iw, ih, BufferedImage.TYPE_INT_ARGB);
        }

        final int[] imagePixels = ((DataBufferInt) image.getRaster().getDataBuffer()).getData();
        final int[] maskPixels = ((DataBufferInt) smask.getRaster().getDataBuffer()).getData();

        int ip, mp, r, g, b, resA, y, a;
        final int r0 = (bc >> 16) & 0xff;
        final int g0 = (bc >> 8) & 0xff;
        final int b0 = bc & 0xff;
        for (int i = 0; i < imagePixels.length; i++) {
            mp = maskPixels[i];
            a = mp >>> 24;
            r = (mp >> 16) & 0xff;
            g = (mp >> 8) & 0xff;
            b = mp & 0xff;
            if (hasBC) {
                if (a == 0) {
                    r = r0;
                    g = g0;
                    b = b0;
                } else if (a < 255) {
                    final int a_ = 255 - a;
                    r = (r * a + r0 * a_) >> 8;
                    g = (g * a + g0 * a_) >> 8;
                    b = (b * a + b0 * a_) >> 8;
                }
            }

            y = (r * 77) + (g * 152) + (b * 28);
            ip = imagePixels[i];
            resA = (ip >> 24) & 0xff;
            resA = tr != null ? (resA * tr[y >> 8]) >> 8 : (resA * y) >> 16;
            imagePixels[i] = (resA << 24) | (ip & 0xffffff);
        }

        return image;
    }


    public static BufferedImage applyAlphaMask(BufferedImage image, BufferedImage smask) {

        if (smask == null) {
            return image;
        }

        if (smask.getType() != BufferedImage.TYPE_INT_ARGB) {
            smask = ColorSpaceConvertor.convertToARGB(smask);
        }
        if (image.getType() != BufferedImage.TYPE_INT_ARGB) {
            image = ColorSpaceConvertor.convertToARGB(image);
        }

        final int iw = image.getWidth();
        final int ih = image.getHeight();
        final int imageDim = iw * ih;

        final int sw = smask.getWidth();
        final int sh = smask.getHeight();
        final int smaskDim = sw * sh;

        if (imageDim < smaskDim) {
            image = scaleImage(image, sw, sh, BufferedImage.TYPE_INT_ARGB);
        } else if (smaskDim < imageDim) {
            smask = scaleImage(smask, iw, ih, BufferedImage.TYPE_INT_ARGB);
        }

        final int[] imagePixels = ((DataBufferInt) image.getRaster().getDataBuffer()).getData();
        final int[] maskPixels = ((DataBufferInt) smask.getRaster().getDataBuffer()).getData();

        int ip, mp, ia, ma, a;
        final float sc = 1 / 255f;
        for (int i = 0; i < imagePixels.length; i++) {
            mp = maskPixels[i];
            ip = imagePixels[i];
            ia = (ip >> 24) & 0xff;
            ma = (mp >> 24) & 0xff;
            a = (int) (ia * ma * sc);
            imagePixels[i] = (a << 24) | (ip & 0xffffff);
        }
        return image;
    }

    private static BufferedImage scaleImage(final BufferedImage src, final int w, final int h, final int imageType) {
        final BufferedImage dimg = new BufferedImage(w, h, imageType);
        final Graphics2D g = dimg.createGraphics();
        g.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BILINEAR);
        g.drawImage(src, 0, 0, w, h, null);
        g.dispose();
        return dimg;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy