001    /*
002     *    GeoAPI - Java interfaces for OGC/ISO standards
003     *    http://www.geoapi.org
004     *
005     *    Copyright (C) 2009-2012 Open Geospatial Consortium, Inc.
006     *    All Rights Reserved. http://www.opengeospatial.org/ogc/legal
007     *
008     *    Permission to use, copy, and modify this software and its documentation, with
009     *    or without modification, for any purpose and without fee or royalty is hereby
010     *    granted, provided that you include the following on ALL copies of the software
011     *    and documentation or portions thereof, including modifications, that you make:
012     *
013     *    1. The full text of this NOTICE in a location viewable to users of the
014     *       redistributed or derivative work.
015     *    2. Notice of any changes or modifications to the OGC files, including the
016     *       date changes were made.
017     *
018     *    THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE
019     *    NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
020     *    TO, WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT
021     *    THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY
022     *    PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS.
023     *
024     *    COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR
025     *    CONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION.
026     *
027     *    The name and trademarks of copyright holders may NOT be used in advertising or
028     *    publicity pertaining to the software without specific, written prior permission.
029     *    Title to copyright in this software and any associated documentation will at all
030     *    times remain with copyright holders.
031     */
032    package org.opengis.metadata.acquisition;
033    
034    import org.opengis.annotation.UML;
035    import org.opengis.util.InternationalString;
036    
037    import static org.opengis.annotation.Obligation.*;
038    import static org.opengis.annotation.Specification.*;
039    
040    
041    /**
042     * Information about the environmental conditions during the acquisition.
043     *
044     * @author  Cédric Briançon (Geomatys)
045     * @version 3.0
046     * @since   2.3
047     */
048    @UML(identifier="MI_EnvironmentalRecord", specification=ISO_19115_2)
049    public interface EnvironmentalRecord {
050        /**
051         * Average air temperature along the flight pass during the photo flight.
052         * <p>
053         * <TABLE WIDTH="80%" ALIGN="center" CELLPADDING="18" BORDER="4" BGCOLOR="#FFE0B0">
054         *   <TR><TD>
055         *     <P align="justify"><B>Warning:</B> The return type of this method may change in GeoAPI
056         *     3.1. It may be replaced by the {@link javax.measure.quantity.Temperature} type in order
057         *     to provide unit of measurement together with the value.</P>
058         *   </TD></TR>
059         * </TABLE>
060         *
061         * @return Average air temperature along the flight pass during the photo flight.
062         */
063        @UML(identifier="averageAirTemperature", obligation=MANDATORY, specification=ISO_19115_2)
064        Double getAverageAirTemperature();
065    
066        /**
067         * Maximum relative humidity along the flight pass during the photo flight.
068         * <p>
069         * <TABLE WIDTH="80%" ALIGN="center" CELLPADDING="18" BORDER="4" BGCOLOR="#FFE0B0">
070         *   <TR><TD>
071         *     <P align="justify"><B>Warning:</B> The return type of this method may change in GeoAPI
072         *     3.1. It may be replaced by the {@link javax.measure.quantity.Dimensionless} type in
073         *     order to provide unit of measurement (typically a percentage) together with the value.</P>
074         *   </TD></TR>
075         * </TABLE>
076         *
077         * @return Maximum relative humidity along the flight pass during the photo flight.
078         */
079        @UML(identifier="maxRelativeHumidity", obligation=MANDATORY, specification=ISO_19115_2)
080        Double getMaxRelativeHumidity();
081    
082        /**
083         * Maximum altitude during the photo flight.
084         * <p>
085         * <TABLE WIDTH="80%" ALIGN="center" CELLPADDING="18" BORDER="4" BGCOLOR="#FFE0B0">
086         *   <TR><TD>
087         *     <P align="justify"><B>Warning:</B> The return type of this method may change in GeoAPI
088         *     3.1. It may be replaced by the {@link javax.measure.quantity.Length} type in order to
089         *     provide unit of measurement together with the value.</P>
090         *   </TD></TR>
091         * </TABLE>
092         *
093         * @return Maximum altitude during the photo flight.
094         */
095        @UML(identifier="maxAltitude", obligation=MANDATORY, specification=ISO_19115_2)
096        Double getMaxAltitude();
097    
098        /**
099         * Meteorological conditions in the photo flight area, in particular clouds, snow and wind.
100         *
101         * @return Meteorological conditions in the photo flight area.
102         */
103        @UML(identifier="meteorologicalConditions", obligation=MANDATORY, specification=ISO_19115_2)
104        InternationalString getMeteorologicalConditions();
105    }