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

org.opengis.geometry.primitive.Solid Maven / Gradle / Ivy

/*
 *    GeoTools - The Open Source Java GIS Toolkit
 *    http://geotools.org
 *
 *    (C) 2011, Open Source Geospatial Foundation (OSGeo)
 *    (C) 2003-2005, Open Geospatial Consortium Inc.
 *
 *    All Rights Reserved. http://www.opengis.org/legal/
 */
package org.opengis.geometry.primitive;

import static org.opengis.annotation.Obligation.*;
import static org.opengis.annotation.Specification.*;

import org.opengis.annotation.Association;
import org.opengis.annotation.UML;

/**
 * Basis for 3-dimensional geometry. The extent of a solid is defined by the boundary surfaces.
 *
 * @version ISO 19107
 * @author Martin Desruisseaux (IRD)
 * @since GeoAPI 1.0
 * @see PrimitiveFactory#createSolid
 * @todo Some associations are commented out for now.
 */
@UML(identifier = "GM_Solid", specification = ISO_19107)
public interface Solid extends Primitive {
    /**
     * Returns a sequence of sets of {@linkplain Surface surfaces} that limit the extent of this
     * {@code Solid}. These surfaces shall be organized into one set of surfaces for each boundary
     * component of this {@code Solid}. Each of these shells shall be a cycle (closed composite
     * surface without boundary).
     *
     * 
* * NOTE: The exterior shell of a solid is defined only because * the embedding coordinate space is always a 3D Euclidean one. In general, a solid in a bounded * 3-dimensional manifold has no distinguished exterior boundary. In cases where "exterior" * boundary is not well defined, all the shells of the {@linkplain SolidBoundary solid boundary} * shall be listed as "interior". * *
* * The {@linkplain OrientableSurface orientable surfaces} that bound a solid shall be oriented * outward - that is, the "top" of each {@linkplain Surface surface} as defined by its * orientation shall face away from the interior of the solid. Each {@linkplain Shell shell}, * when viewed as a composite surface, shall be a cycle. * * @return The sets of positions on the boundary. */ @UML(identifier = "boundary", obligation = MANDATORY, specification = ISO_19107) SolidBoundary getBoundary(); /** * Returns the sum of the surface areas of all of the boundary components of a solid. * * @return The area of this solid. * @todo In UML diagram, this operation has an {@code Area} return type. */ @UML(identifier = "area", obligation = MANDATORY, specification = ISO_19107) double getArea(); /** * Returns the volume of this solid. This is the volume interior to the exterior boundary shell * minus the sum of the volumes interior to any interior boundary shell. * * @return The volume of this solid. * @todo In UML diagram, this operation has a {@code Volume} return type. */ @UML(identifier = "volume", obligation = MANDATORY, specification = ISO_19107) double getVolume(); /** * Returns always {@code null}, since solids have no proxy. * * @issue http://jira.codehaus.org/browse/GEO-63 */ @Association("Oriented") @UML(identifier = "proxy", obligation = FORBIDDEN, specification = ISO_19107) OrientablePrimitive[] getProxy(); // public org.opengis.geometry.complex.GM_CompositeSolid[] getComposite() { return null; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy