Search in sources :

Example 1 with Colorizer

use of org.apache.sis.internal.coverage.j2d.Colorizer in project sis by apache.

the class ImageRenderer method createImage.

/**
 * Creates an image with the data specified by the last call to a {@code setData(…)} method.
 * The image upper-left corner is located at the position given by {@link #getBounds()}.
 * The two-dimensional {@linkplain #getImageGeometry(int) image geometry} is stored as
 * a property associated to the {@value org.apache.sis.image.PlanarImage#GRID_GEOMETRY_KEY} key.
 *
 * <p>The default implementation returns an instance of {@link java.awt.image.WritableRenderedImage}
 * if the {@link #createRaster()} return value is an instance of {@link WritableRaster}, or a read-only
 * {@link RenderedImage} otherwise.</p>
 *
 * @return the image.
 * @throws IllegalStateException if no {@code setData(…)} method has been invoked before this method call.
 * @throws RasterFormatException if a call to a {@link Raster} factory method failed.
 * @throws ArithmeticException if a property of the image to construct exceeds the capacity of 32 bits integers.
 *
 * @since 1.1
 */
@SuppressWarnings("UseOfObsoleteCollectionType")
public RenderedImage createImage() {
    final Raster raster = createRaster();
    final Colorizer colorizer = new Colorizer(colors);
    final ColorModel colors;
    if (colorizer.initialize(bands[visibleBand]) || colorizer.initialize(raster.getSampleModel(), visibleBand)) {
        colors = colorizer.createColorModel(buffer.getDataType(), bands.length, visibleBand);
    } else {
        colors = Colorizer.NULL_COLOR_MODEL;
    }
    SliceGeometry supplier = null;
    if (imageGeometry == null) {
        if (isSameGeometry(GridCoverage2D.BIDIMENSIONAL)) {
            imageGeometry = geometry;
        } else {
            supplier = new SliceGeometry(geometry, sliceExtent, gridDimensions, mtFactory);
        }
    }
    final WritableRaster wr = (raster instanceof WritableRaster) ? (WritableRaster) raster : null;
    if (wr != null && colors != null && (imageX | imageY) == 0) {
        return new Untiled(colors, wr, properties, imageGeometry, supplier);
    }
    if (properties == null) {
        properties = new Hashtable<>();
    }
    properties.putIfAbsent(GRID_GEOMETRY_KEY, (supplier != null) ? new DeferredProperty(supplier) : imageGeometry);
    if (wr != null) {
        return new WritableTiledImage(properties, colors, width, height, 0, 0, wr);
    } else {
        return new TiledImage(properties, colors, width, height, 0, 0, raster);
    }
}
Also used : DeferredProperty(org.apache.sis.internal.coverage.j2d.DeferredProperty) ColorModel(java.awt.image.ColorModel) WritableRaster(java.awt.image.WritableRaster) Raster(java.awt.image.Raster) WritableRaster(java.awt.image.WritableRaster) WritableTiledImage(org.apache.sis.internal.coverage.j2d.WritableTiledImage) WritableTiledImage(org.apache.sis.internal.coverage.j2d.WritableTiledImage) TiledImage(org.apache.sis.internal.coverage.j2d.TiledImage) Colorizer(org.apache.sis.internal.coverage.j2d.Colorizer)

Example 2 with Colorizer

use of org.apache.sis.internal.coverage.j2d.Colorizer in project sis by apache.

the class GridCoverageBuilder method build.

/**
 * Creates the grid coverage from the domain, ranges and values given to setter methods.
 * The returned coverage is often a {@link GridCoverage2D} instance, but not necessarily.
 *
 * @return grid coverage created from specified domain, ranges and sample values.
 * @throws IllegalStateException if some properties are inconsistent, for example
 *         {@linkplain GridGeometry#getExtent() grid extent} not matching image size or
 *         {@linkplain #setRanges(SampleDimension...) number of sample dimensions} not matching
 *         the number of bands. This exception often wraps an {@link IllegalGridGeometryException},
 *         {@link IllegalArgumentException} or {@link org.apache.sis.util.NullArgumentException}.
 */
public GridCoverage build() throws IllegalStateException {
    // May be replaced by an instance with extent.
    GridGeometry grid = domain;
    // May be replaced by a non-null value.
    List<? extends SampleDimension> bands = ranges;
    /*
         * If not already done, create the image from the raster. We try to create the most standard objects
         * when possible: a BufferedImage (from Java2D), then later a GridCoverage2D (from SIS public API).
         * An exception to this rule is the DataBuffer case: we use a dedicated BufferedGridCoverage class
         * instead.
         */
    try {
        if (image == null) {
            if (raster == null) {
                if (buffer == null) {
                    throw new IllegalStateException(missingProperty("values"));
                }
                if (size != null) {
                    grid = GridCoverage2D.addExtentIfAbsent(grid, new Rectangle(size));
                    verifyGridExtent(grid.getExtent(), size.width, size.height);
                } else if (grid == null) {
                    throw new IncompleteGridGeometryException(missingProperty("size"));
                }
                bands = GridCoverage2D.defaultIfAbsent(bands, null, buffer.getNumBanks());
                return new BufferedGridCoverage(domainWithAxisFlips(grid), bands, buffer);
            }
            /*
                 * If the band list is null, create a default list of bands because we need
                 * them for creating the color model. Note that we shall not do that when a
                 * RenderedImage has been specified because GridCoverage2D constructor will
                 * will infer better names.
                 */
            bands = GridCoverage2D.defaultIfAbsent(bands, null, raster.getNumBands());
            final SampleModel sm = raster.getSampleModel();
            final Colorizer colorizer = new Colorizer(Colorizer.GRAYSCALE);
            final ColorModel colors;
            if (colorizer.initialize(bands.get(visibleBand)) || colorizer.initialize(sm, visibleBand)) {
                colors = colorizer.createColorModel(ImageUtilities.getBandType(sm), bands.size(), visibleBand);
            } else {
                colors = Colorizer.NULL_COLOR_MODEL;
            }
            /*
                 * Create an image from the raster. We favor BufferedImage instance when possible,
                 * and fallback on TiledImage only if the BufferedImage can not be created.
                 */
            if (raster instanceof WritableRaster) {
                final WritableRaster wr = (WritableRaster) raster;
                if (colors != null && (wr.getMinX() | wr.getMinY()) == 0) {
                    image = new BufferedImage(colors, wr, false, properties);
                } else {
                    image = new WritableTiledImage(properties, colors, wr.getWidth(), wr.getHeight(), 0, 0, wr);
                }
            } else {
                image = new TiledImage(properties, colors, raster.getWidth(), raster.getHeight(), 0, 0, raster);
            }
        }
        /*
             * At this point `image` shall be non-null but `bands` may still be null (it is okay).
             */
        return new GridCoverage2D(domainWithAxisFlips(grid), bands, image);
    } catch (TransformException | NullPointerException | IllegalArgumentException | ArithmeticException e) {
        throw new IllegalStateException(Resources.format(Resources.Keys.CanNotBuildGridCoverage), e);
    }
}
Also used : Rectangle(java.awt.Rectangle) TransformException(org.opengis.referencing.operation.TransformException) BufferedImage(java.awt.image.BufferedImage) Colorizer(org.apache.sis.internal.coverage.j2d.Colorizer) SampleModel(java.awt.image.SampleModel) ColorModel(java.awt.image.ColorModel) WritableRaster(java.awt.image.WritableRaster) WritableTiledImage(org.apache.sis.internal.coverage.j2d.WritableTiledImage) WritableTiledImage(org.apache.sis.internal.coverage.j2d.WritableTiledImage) TiledImage(org.apache.sis.internal.coverage.j2d.TiledImage)

Example 3 with Colorizer

use of org.apache.sis.internal.coverage.j2d.Colorizer in project sis by apache.

the class GridCoverage method convert.

/**
 * Creates a new image of the given data type which will compute values using the given converters.
 *
 * @param  source      the image for which to convert sample values.
 * @param  bandType    the type of data in the bands resulting from conversion of given image.
 * @param  converters  the transfer functions to apply on each band of the source image.
 * @return the image which compute converted values from the given source.
 */
final RenderedImage convert(final RenderedImage source, final DataType bandType, final MathTransform1D[] converters) {
    final int visibleBand = Math.max(0, ImageUtilities.getVisibleBand(source));
    final Colorizer colorizer = new Colorizer(Colorizer.GRAYSCALE);
    final ColorModel colors;
    if (colorizer.initialize(sampleDimensions[visibleBand]) || colorizer.initialize(source.getColorModel())) {
        colors = colorizer.createColorModel(bandType.toDataBufferType(), sampleDimensions.length, visibleBand);
    } else {
        colors = Colorizer.NULL_COLOR_MODEL;
    }
    return Lazy.PROCESSOR.convert(source, getRanges(), converters, bandType, colors);
}
Also used : ColorModel(java.awt.image.ColorModel) Colorizer(org.apache.sis.internal.coverage.j2d.Colorizer)

Aggregations

ColorModel (java.awt.image.ColorModel)3 Colorizer (org.apache.sis.internal.coverage.j2d.Colorizer)3 WritableRaster (java.awt.image.WritableRaster)2 TiledImage (org.apache.sis.internal.coverage.j2d.TiledImage)2 WritableTiledImage (org.apache.sis.internal.coverage.j2d.WritableTiledImage)2 Rectangle (java.awt.Rectangle)1 BufferedImage (java.awt.image.BufferedImage)1 Raster (java.awt.image.Raster)1 SampleModel (java.awt.image.SampleModel)1 DeferredProperty (org.apache.sis.internal.coverage.j2d.DeferredProperty)1 TransformException (org.opengis.referencing.operation.TransformException)1