/*

   Licensed to the Apache Software Foundation (ASF) under one or more
   contributor license agreements.  See the NOTICE file distributed with
   this work for additional information regarding copyright ownership.
   The ASF licenses this file to You 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.

 */
package org.apache.batik.ext.awt.image.renderable;

import java.awt.color.ColorSpace;
import java.awt.image.RenderedImage;
import java.util.List;
import java.util.Map;

import org.apache.batik.ext.awt.image.GraphicsUtil;
import org.apache.batik.ext.awt.image.rendered.CachableRed;

This is an abstract base class that adds the ability to specify the Color Space that the operation should take place in (linear sRGB or gamma corrected sRBG).
Author:Thomas DeWeese
Version:$Id: AbstractColorInterpolationRable.java 1733416 2016-03-03 07:07:13Z gadams $
/** * This is an abstract base class that adds the ability to specify the * Color Space that the operation should take place in (linear sRGB or * gamma corrected sRBG). * * @author <a href="mailto:Thomas.DeWeeese@Kodak.com">Thomas DeWeese</a> * @version $Id: AbstractColorInterpolationRable.java 1733416 2016-03-03 07:07:13Z gadams $ */
public abstract class AbstractColorInterpolationRable extends AbstractRable {
Indicates if the operation should be done in linear or gamma corrected sRGB.
/** * Indicates if the operation should be done in linear or gamma * corrected sRGB. */
protected boolean csLinear = true;
void constructor. The subclass must call one of the flavors of init before the object becomes usable. This is useful when the proper parameters to the init method need to be computed in the subclasses constructor.
/** * void constructor. The subclass must call one of the * flavors of init before the object becomes usable. * This is useful when the proper parameters to the init * method need to be computed in the subclasses constructor. */
protected AbstractColorInterpolationRable() { super(); }
Construct an Abstract Rable from src.
Params:
  • src – will be the first (and only) member of the srcs Vector. The bounds of src are also used to set the bounds of this renderable.
/** * Construct an Abstract Rable from src. * @param src will be the first (and only) member of the srcs * Vector. The bounds of src are also used to set the bounds of * this renderable. */
protected AbstractColorInterpolationRable(Filter src) { super(src); }
Construct an Abstract Rable from src and props.
Params:
  • src – will also be set as the first (and only) member of the srcs Vector.
  • props – use to initialize the properties on this renderable image.
/** * Construct an Abstract Rable from src and props. * @param src will also be set as the first (and only) member of * the srcs Vector. * @param props use to initialize the properties on this renderable image. */
protected AbstractColorInterpolationRable(Filter src, Map props) { super(src, props); }
Construct an Abstract Rable from a list of sources.
Params:
  • srcs – This is used to initialize the srcs Vector. The bounds of this renderable will be the union of the bounds of all the sources in srcs. All the members of srcs must be CachableRable otherwise an error will be thrown.
/** * Construct an Abstract Rable from a list of sources. * @param srcs This is used to initialize the srcs Vector. * The bounds of this renderable will be the union of the bounds * of all the sources in srcs. All the members of srcs must be * CachableRable otherwise an error will be thrown. */
protected AbstractColorInterpolationRable(List srcs) { super(srcs); }
Construct an Abstract Rable from a list of sources, and bounds.
Params:
  • srcs – This is used to initialize the srcs Vector. All the members of srcs must be CachableRable otherwise an error will be thrown.
  • props – use to initialize the properties on this renderable image.
/** * Construct an Abstract Rable from a list of sources, and bounds. * @param srcs This is used to initialize the srcs Vector. All * the members of srcs must be CachableRable otherwise an error * will be thrown. * @param props use to initialize the properties on this renderable image. */
protected AbstractColorInterpolationRable(List srcs, Map props) { super(srcs, props); }
Returns true if this operation is to be performed in the linear sRGB colorspace, returns false if the operation is performed in gamma corrected sRGB.
/** * Returns true if this operation is to be performed in * the linear sRGB colorspace, returns false if the * operation is performed in gamma corrected sRGB. */
public boolean isColorSpaceLinear() { return csLinear; }
Sets the colorspace the operation will be performed in.
Params:
  • csLinear – if true this operation will be performed in the linear sRGB colorspace, if false the operation will be performed in gamma corrected sRGB.
/** * Sets the colorspace the operation will be performed in. * @param csLinear if true this operation will be performed in the * linear sRGB colorspace, if false the operation will be performed in * gamma corrected sRGB. */
public void setColorSpaceLinear(boolean csLinear) { touch(); this.csLinear = csLinear; } public ColorSpace getOperationColorSpace() { if (csLinear) return ColorSpace.getInstance(ColorSpace.CS_LINEAR_RGB); else return ColorSpace.getInstance(ColorSpace.CS_sRGB); } protected CachableRed convertSourceCS(CachableRed cr) { if (csLinear) return GraphicsUtil.convertToLsRGB(cr); else return GraphicsUtil.convertTosRGB(cr); } protected CachableRed convertSourceCS(RenderedImage ri) { return convertSourceCS(GraphicsUtil.wrap(ri)); } }