org.opengis.coverage.grid.GridCoverage Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gt-opengis Show documentation
Show all versions of gt-opengis Show documentation
Standard interfaces implemented throughout the library.
/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 2011, Open Source Geospatial Foundation (OSGeo)
* (C) 2005 Open Geospatial Consortium Inc.
*
* All Rights Reserved. http://www.opengis.org/legal/
*/
package org.opengis.coverage.grid;
import static org.opengis.annotation.Obligation.MANDATORY;
import static org.opengis.annotation.Obligation.OPTIONAL;
import static org.opengis.annotation.Specification.OGC_01004;
import java.awt.image.RenderedImage;
import java.util.List;
import org.opengis.annotation.UML;
import org.opengis.coverage.Coverage;
/**
* Represent the basic implementation which provides access to grid coverage data. A {@code
* GridCoverage} implementation may provide the ability to update grid values.
*
* @version Grid Coverage specification 1.0
* @author Martin Desruisseaux (IRD)
* @since GeoAPI 1.0
* @see RenderedImage
* @see javax.media.jai.PixelAccessor
*/
@UML(identifier = "CV_GridCoverage", specification = OGC_01004)
public interface GridCoverage extends Coverage {
/**
* Returns {@code true} if grid data can be edited.
*
* @return {@code true} if grid data can be edited.
*/
@UML(identifier = "dataEditable", obligation = MANDATORY, specification = OGC_01004)
boolean isDataEditable();
/**
* Information for the grid coverage geometry. Grid geometry includes the valid range of grid
* coordinates and the georeferencing.
*
* @return The information for the grid coverage geometry.
*/
@UML(identifier = "gridGeometry", obligation = MANDATORY, specification = OGC_01004)
GridGeometry getGridGeometry();
/**
* Optimal size to use for each dimension when accessing grid values. These values together give
* the optimal block size to use when retrieving grid coverage values. For example, a client
* application can achieve better performance for a 2-D grid coverage by reading blocks of 128
* by 128 if the grid is tiled into blocks of this size. The sequence is ordered by dimension.
* If the implementation does not have optimal sizes, the sequence will be {@code null}.
*
* @return The optimal size to use for each dimension when accessing grid values, or {@code
* null} if none.
*/
@UML(identifier = "optimalDataBlockSizes", obligation = OPTIONAL, specification = OGC_01004)
int[] getOptimalDataBlockSizes();
/**
* Number of predetermined overviews for the grid.
*
* @return The number of predetermined overviews for the grid.
*/
@UML(identifier = "numOverviews", obligation = MANDATORY, specification = OGC_01004)
int getNumOverviews();
/**
* Returns the grid geometry for an overview.
*
* @param index Overview index for which to retrieve grid geometry. Indices start at 0.
* @return The grid geometry for an overview.
* @throws IndexOutOfBoundsException if {@code overviewIndex} is out of bounds.
*/
@UML(identifier = "getOverviewGridGeometry", obligation = MANDATORY, specification = OGC_01004)
GridGeometry getOverviewGridGeometry(int index) throws IndexOutOfBoundsException;
/**
* Returns a pre-calculated overview for a grid coverage. The overview indices are numbered from
* 0 to {@linkplain #getNumOverviews numberOverviews}-1
. The overviews are ordered
* from highest (index 0) to lowest ({@linkplain #getNumOverviews numberOverviews}-1
*
) resolution. Overview grid coverages will have overviews which are the overviews for
* the grid coverage with lower resolution than the overview. For example, a 1 meter grid
* coverage with 3, 9, and 27 meter overviews will be ordered as in the left side below. The 3
* meter overview will have 2 overviews as in the right side below:
*
*
*
*
*
* 1 meter GC
* 3 meter overview
*
*
*
* Index resolution
* 0 3
* 1 9
* 2 27
*
*
*
* Index resolution
* 0 9
* 1 27
*
*
*
*
*
* @param index Index of grid coverage overview to retrieve. Indexes start at 0.
* @return A pre-calculated overview for a grid coverage.
* @throws IndexOutOfBoundsException if {@code overviewIndex} is out of bounds.
*/
@UML(identifier = "getOverview", obligation = MANDATORY, specification = OGC_01004)
GridCoverage getOverview(int index) throws IndexOutOfBoundsException;
/**
* Returns the sources data for a grid coverage. If the {@code GridCoverage} was produced from
* an underlying dataset (by {@link GridCoverageReader#read read(...)} for instance), this
* method should returns an empty list.
*
* If the {@code GridCoverage} was produced using {link
* org.opengis.coverage.processing.GridCoverageProcessor} then it should return the source grid
* coverages of the one used as input to {@code GridCoverageProcessor}. In general this method
* is intended to return the original {@code GridCoverage} on which it depends.
*
*
This is intended to allow applications to establish what {@code GridCoverage}s will be
* affected when others are updated, as well as to trace back to the "raw data".
*
* @return The sources data for a grid coverage.
*/
List getSources();
/** Returns grid data as a rendered image. */
RenderedImage getRenderedImage();
}