Package com.lightcrafts.mediax.jai

Source Code of com.lightcrafts.mediax.jai.CRIFImpl

/*
* $RCSfile: CRIFImpl.java,v $
*
* Copyright (c) 2005 Sun Microsystems, Inc. All rights reserved.
*
* Use is subject to license terms.
*
* $Revision: 1.1 $
* $Date: 2005/02/11 04:57:05 $
* $State: Exp $
*/
package com.lightcrafts.mediax.jai;
import java.awt.RenderingHints;
import java.awt.geom.Rectangle2D;
import java.awt.image.RenderedImage;
import java.awt.image.renderable.ContextualRenderedImageFactory;
import java.awt.image.renderable.ParameterBlock;
import java.awt.image.renderable.RenderableImage;
import java.awt.image.renderable.RenderContext;
import com.lightcrafts.mediax.jai.JAI;
import com.lightcrafts.mediax.jai.RenderedOp;
import com.lightcrafts.mediax.jai.registry.RenderedRegistryMode;
import com.lightcrafts.mediax.jai.util.ImagingListener;
import com.lightcrafts.media.jai.util.ImageUtil;

/**
* A utility class to minimize in most cases the effort required to implement
* the <code>ContextualRenderedImageFactory</code> (CRIF) of an operation.
* An extender of this class is required to implement only the method
* <code>RenderedImage create(ParameterBlock, RenderingHints)</code>
* defined in the <code>RenderedImageFactory</code> interface.  The remaining
* methods may be overridden insofar as this is necessary to obtain behavior
* different from that provided by default.
*
* @see java.awt.image.renderable.ContextualRenderedImageFactory
* @see java.awt.image.renderable.RenderedImageFactory
* @since JAI 1.1
*/
// This class was actually added in JAI EA2 but was then in
// com.lightcrafts.media.jai.opimage. It was moved to the public API in JAI 1.1.
public abstract class CRIFImpl implements ContextualRenderedImageFactory {

    /**
     * If non-<code>null</code>, this name will be used as a parameter to
     * <code>JAI.create()</code> in
     * <code>create(RenderContext,ParameterBlock)</code>; otherwise the RIF
     * <code>create(ParameterBlock,RenderingHints)</code> method implemented
     * in the extending class will be invoked.
     */
    protected String operationName = null;

    /**
     * Default constructor.  The operation name is set to <code>null</code>.
     */
    public CRIFImpl() {
        this.operationName = null;
    }

    /**
     * Constructor.  The operation name is set to the specified value
     * which may be <code>null</code>.
     */
    public CRIFImpl(String operationName) {
        this.operationName = operationName;
    }

    /**
     * The <code>RenderedImageFactory</code> <code>create()</code> method
     * which must be implemented by concrete subclasses.
     */
    public abstract RenderedImage create(ParameterBlock paramBlock,
                                         RenderingHints renderHints);

    /**
     * Creates a <code>RenderedImage</code> from the renderable layer.
     *
     * <p> If <code>operationName</code> is non-<code>null</code>,
     * <code>JAI.create()</code> will be invoked using the supplied
     * <code>ParameterBlock</code> and the <code>RenderingHints</code>
     * contained in the <code>RenderContext</code>.  If
     * <code>operationName</code> is <code>null</code>, or
     * <code>JAI.create()</code> returns <code>null</code>, the
     * <code>create(ParameterBlock,RenderingHints)</code> method defined
     * in the extending class will be invoked.
     *
     * @param renderContext The rendering information associated with
     *        this rendering.
     * @param paramBlock The parameters used to create the image.
     * @return A <code>RenderedImage</code>.
     */
    public RenderedImage create(RenderContext renderContext,
                                ParameterBlock paramBlock) {
        RenderingHints renderHints = renderContext.getRenderingHints();
        if (operationName != null) {
            OperationRegistry registry =
                renderHints == null ? null :
                (OperationRegistry)renderHints.get(JAI.KEY_OPERATION_REGISTRY);

            RenderedImage rendering;

            if(registry == null) {
                // Call the JAI.create method to get the best implementation
                rendering =
                    JAI.create(operationName, paramBlock, renderHints);
            } else { // registry != null
                // NB: This section is lifted pretty much verbatim from
                // JAI.createNS().

                // Get the OperationDescriptor registered under the
                // specified name.
                OperationDescriptor odesc = (OperationDescriptor)
                    registry.getDescriptor(OperationDescriptor.class,
                                           operationName);
                if (odesc == null) {
                    throw new IllegalArgumentException(operationName + ": " +
                                                       JaiI18N.getString("JAI0"));
                }

                // Does this operation support rendered mode?
                if (!odesc.isModeSupported(RenderedRegistryMode.MODE_NAME)) {
                    throw new IllegalArgumentException(operationName + ": " +
                                                       JaiI18N.getString("JAI1"));
                }

                // Check the destination image type.
                if (!RenderedImage.class.isAssignableFrom(odesc.getDestClass(RenderedRegistryMode.MODE_NAME))) {
                    throw new IllegalArgumentException(operationName + ": " +
                                                       JaiI18N.getString("JAI2"));
                }

                // Validate input arguments. The ParameterBlock is cloned here
                // because OperationDescriptor.validateArguments() may change
                // its content.
                StringBuffer msg = new StringBuffer();
                paramBlock = (ParameterBlock)paramBlock.clone();
                if (!odesc.validateArguments(RenderedRegistryMode.MODE_NAME,
                                             paramBlock, msg)) {
                    throw new IllegalArgumentException(msg.toString());
                }

                // Create the rendered operation node.
                rendering = new RenderedOp(registry, operationName,
                                           paramBlock, renderHints);
            }

            // Return the rendering if possible.
            if(rendering != null) {
                // If the rendering is a rendered chain, replace it by its
                // rendering which will likely be an OpImage chain.
                if(rendering instanceof RenderedOp) {
                    try {
                        rendering = ((RenderedOp)rendering).getRendering();
                    } catch (Exception e) {
                        ImagingListener listener =
                            ImageUtil.getImagingListener(renderHints);
                        String message =
                            JaiI18N.getString("CRIFImpl0") + operationName;
                        listener.errorOccurred(message, e, this, false);
//                        e.printStackTrace();
                    }
                }
                return rendering;
            }
        }

        // Call the RIF create method of the extending class
        return create(paramBlock, renderHints);
    }

    /**
     * Maps the destination <code>RenderContext</code> into a
     * <code>RenderContext</code> for each source.  The
     * implementation in this class simply returns the
     * <code>RenderContext</code> passed in by the caller.
     *
     * @param i The index of the source image.
     * @param renderContext The <code>RenderContext</code> being applied to
     *        the operation.
     * @param paramBlock A <code>ParameterBlock</code> containing the
     *        sources and parameters of the operation.
     * @param image The <code>RenderableImage</code> being rendered.
     *
     * @return The <code>RenderContext</code> to be used to render the
     *         given source.
     */
    public RenderContext mapRenderContext(int i,
                                          RenderContext renderContext,
                                          ParameterBlock paramBlock,
                                          RenderableImage image) {
        return renderContext;
    }

    /**
     * Returns the bounding box for the output of the operation.  The
     * implementation in this class computes the bounding box as the
     * intersection the bounding boxes of all the (renderable sources).
     *
     * @param paramBlock A <code>ParameterBlock</code> containing the
     *        sources and parameters of the operation.
     * @return A <code>Rectangle2D</code> specifying the bounding box.
     */
    public Rectangle2D getBounds2D(ParameterBlock paramBlock) {
        int numSources = paramBlock.getNumSources();

        if (numSources == 0) {
            return null;
        }

        RenderableImage src = paramBlock.getRenderableSource(0);
        Rectangle2D.Float box1 = new Rectangle2D.Float(src.getMinX(),
                                                       src.getMinY(),
                                                       src.getWidth(),
                                                       src.getHeight());

        for (int i = 1; i < numSources; i++) {
            src  = paramBlock.getRenderableSource(i);
            Rectangle2D.Float box2 =
                new Rectangle2D.Float(src.getMinX(), src.getMinY(),
                                      src.getWidth(), src.getHeight());
            box1 = (Rectangle2D.Float)box1.createIntersection(box2);
            if(box1.isEmpty()) {
                break;
            }
        }

        return box1;
    }

    /**
     * Returns the appropriate instance of the property with the indicated
     * name.
     *
     * <p> The implementation in this class always returns
     * <code>java.awt.Image.UndefinedProperty</code> since
     * no properties are defined by default.
     *
     * @param paramBlock A <code>ParameterBlock</code> containing the
     *        sources and parameters of the operation.
     * @param name A <code>String</code> containing the desired property name.
     *
     * @return the value <code>java.awt.Image.UndefinedProperty</code>
     *         indicating that the property is undefined.
     */
    public Object getProperty(ParameterBlock paramBlock,
                              String name) {
        return java.awt.Image.UndefinedProperty;
    }

    /**
     * Returns the valid property names for the operation.  The
     * implementation in this class always returns <code>null</code>
     * since no properties are associated with the operation by
     * default.
     *
     * @return <code>null</code> indicating that no properties are defined.
     */
    public String[] getPropertyNames() {
        return null;
    }

    /**
     * Returns <code>true</code> if successive renderings with the same
     * arguments may produce different results.  The implementation in this
     * class always returns <code>false</code> so as to enable caching
     * of renderings by default.  CRIFs that do implement dynamic
     * rendering behavior must override this method.
     *
     * @return <code>false</code> indicating that the rendering is static.
     */
    public boolean isDynamic() {
        return false;
    }
}
TOP

Related Classes of com.lightcrafts.mediax.jai.CRIFImpl

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.