Search in sources :

Example 1 with DefaultCoordinateSystemAxis

use of org.apache.sis.referencing.cs.DefaultCoordinateSystemAxis in project sis by apache.

the class MetadataTest method createHardCoded.

/**
 * Programmatically creates the metadata to marshall, or to compare against the unmarshalled metadata.
 *
 * @return the hard-coded representation of {@code "Metadata.xml"} content.
 */
private DefaultMetadata createHardCoded() {
    final DefaultMetadata metadata = new DefaultMetadata();
    metadata.setMetadataIdentifier(new DefaultIdentifier("Apache SIS/Metadata test"));
    metadata.setLanguages(singleton(Locale.ENGLISH));
    metadata.setCharacterSets(singleton(StandardCharsets.UTF_8));
    metadata.setMetadataScopes(singleton(new DefaultMetadataScope(ScopeCode.DATASET, "Common Data Index record")));
    metadata.setDateInfo(singleton(new DefaultCitationDate(TestUtilities.date("2009-01-01 04:00:00"), DateType.CREATION)));
    /*
         * Contact information for the author. The same party will be used for custodian and distributor,
         * with only the role changed. Note that we need to create an instance of the deprecated class,
         * because this is what will be unmarshalled from the XML document.
         */
    @SuppressWarnings("deprecation") final DefaultResponsibleParty author = new DefaultResponsibleParty(Role.AUTHOR);
    // Non-public SIS class.
    final Anchor country = new Anchor(URI.create("SDN:C320:2:FR"), "France");
    {
        final DefaultOnlineResource online = new DefaultOnlineResource(URI.create("http://www.ifremer.fr/sismer/"));
        online.setProtocol("http");
        final DefaultContact contact = new DefaultContact(online);
        contact.getIdentifierMap().putSpecialized(IdentifierSpace.ID, "IFREMER");
        contact.setPhones(Arrays.asList(telephone("+33 (0)2 xx.xx.xx.x6", "VOICE"), telephone("+33 (0)2 xx.xx.xx.x4", "FACSIMILE")));
        final DefaultAddress address = new DefaultAddress();
        address.setDeliveryPoints(singleton("Brest institute"));
        address.setCity(new SimpleInternationalString("Plouzane"));
        address.setPostalCode("29280");
        address.setCountry(country);
        address.setElectronicMailAddresses(singleton("xx@xx.fr"));
        contact.setAddresses(singleton(address));
        author.setParties(singleton(new DefaultOrganisation("Marine institutes", null, null, contact)));
        metadata.setContacts(singleton(author));
    }
    /*
         * Data indentification.
         */
    {
        final DefaultCitation citation = new DefaultCitation("90008411.ctd");
        citation.setAlternateTitles(singleton(new SimpleInternationalString("42292_5p_19900609195600")));
        citation.setDates(Arrays.asList(new DefaultCitationDate(TestUtilities.date("1990-06-04 22:00:00"), DateType.REVISION), new DefaultCitationDate(TestUtilities.date("1979-08-02 22:00:00"), DateType.CREATION)));
        {
            @SuppressWarnings("deprecation") final DefaultResponsibleParty originator = new DefaultResponsibleParty(Role.ORIGINATOR);
            final DefaultOnlineResource online = new DefaultOnlineResource(URI.create("http://www.com.univ-mrs.fr/LOB/"));
            online.setProtocol("http");
            final DefaultContact contact = new DefaultContact(online);
            contact.setPhones(Arrays.asList(telephone("+33 (0)4 xx.xx.xx.x5", "VOICE"), telephone("+33 (0)4 xx.xx.xx.x8", "FACSIMILE")));
            final DefaultAddress address = new DefaultAddress();
            address.setDeliveryPoints(singleton("Oceanology institute"));
            address.setCity(new SimpleInternationalString("Marseille"));
            address.setPostalCode("13288");
            address.setCountry(country);
            contact.setAddresses(singleton(address));
            originator.setParties(singleton(new DefaultOrganisation("Oceanology laboratory", null, null, contact)));
            citation.setCitedResponsibleParties(singleton(originator));
        }
        final DefaultDataIdentification identification = new DefaultDataIdentification(// Citation
        citation, // Abstract
        "CTD NEDIPROD VI 120", // Language,
        Locale.ENGLISH, // Topic category
        TopicCategory.OCEANS);
        {
            @SuppressWarnings("deprecation") final DefaultResponsibleParty custodian = new DefaultResponsibleParty((DefaultResponsibility) author);
            custodian.setRole(Role.CUSTODIAN);
            identification.setPointOfContacts(singleton(custodian));
        }
        /*
             * Data indentification / Keywords.
             */
        {
            final DefaultKeywords keyword = new DefaultKeywords(new Anchor(URI.create("SDN:P021:35:ATTN"), "Transmittance and attenuance of the water column"));
            keyword.setType(KeywordType.THEME);
            final DefaultCitation thesaurus = new DefaultCitation("BODC Parameter Discovery Vocabulary");
            thesaurus.setAlternateTitles(singleton(new SimpleInternationalString("P021")));
            thesaurus.setDates(singleton(new DefaultCitationDate(TestUtilities.date("2008-11-25 23:00:00"), DateType.REVISION)));
            thesaurus.setEdition(new Anchor(URI.create("SDN:C371:1:35"), "35"));
            thesaurus.setIdentifiers(singleton(new ImmutableIdentifier(null, null, "http://www.seadatanet.org/urnurl/")));
            keyword.setThesaurusName(thesaurus);
            identification.setDescriptiveKeywords(singleton(keyword));
        }
        /*
             * Data indentification / Browse graphic.
             */
        {
            final DefaultBrowseGraphic g = new DefaultBrowseGraphic(URI.create("file:///thumbnail.png"));
            g.setFileDescription(new SimpleInternationalString("Arbitrary thumbnail for this test only."));
            identification.setGraphicOverviews(singleton(g));
        }
        /*
             * Data indentification / Resource constraint.
             */
        {
            final DefaultLegalConstraints constraint = new DefaultLegalConstraints();
            constraint.setAccessConstraints(singleton(Restriction.LICENSE));
            identification.setResourceConstraints(singleton(constraint));
        }
        /*
             * Data indentification / Aggregate information.
             */
        {
            @SuppressWarnings("deprecation") final DefaultAggregateInformation aggregateInfo = new DefaultAggregateInformation();
            final DefaultCitation name = new DefaultCitation("MEDIPROD VI");
            name.setAlternateTitles(singleton(new SimpleInternationalString("90008411")));
            name.setDates(singleton(new DefaultCitationDate(TestUtilities.date("1990-06-04 22:00:00"), DateType.REVISION)));
            aggregateInfo.setName(name);
            aggregateInfo.setInitiativeType(InitiativeType.CAMPAIGN);
            // There is a typo ("WORD" → "WORK"), but we have to use the wrong spelling for this branch.
            aggregateInfo.setAssociationType(AssociationType.LARGER_WORD_CITATION);
            identification.setAggregationInfo(singleton(aggregateInfo));
        }
        /*
             * Data indentification / Extent.
             */
        {
            final DefaultCoordinateSystemAxis axis = new DefaultCoordinateSystemAxis(singletonMap(DefaultCoordinateSystemAxis.NAME_KEY, new NamedIdentifier(null, "Depth")), "d", AxisDirection.DOWN, Units.METRE);
            final DefaultVerticalCS cs = new DefaultVerticalCS(singletonMap(DefaultVerticalCS.NAME_KEY, new NamedIdentifier(null, "Depth")), axis);
            final DefaultVerticalDatum datum = new DefaultVerticalDatum(singletonMap(DefaultVerticalDatum.NAME_KEY, new NamedIdentifier(null, "D28")), VerticalDatumType.OTHER_SURFACE);
            final DefaultVerticalCRS vcrs = new DefaultVerticalCRS(singletonMap(DefaultVerticalCRS.NAME_KEY, new NamedIdentifier(null, "Depth below D28")), datum, cs);
            final DefaultTemporalExtent temporal = new DefaultTemporalExtent();
            setTemporalBounds(temporal, "1990-06-05", "1990-07-02");
            identification.setExtents(singleton(new DefaultExtent(null, new DefaultGeographicBoundingBox(1.1667, 1.1667, 36.6, 36.6), new DefaultVerticalExtent(Double.NaN, Double.NaN, vcrs), temporal)));
        }
        /*
             * Data identification / Environmental description and Supplemental information.
             */
        {
            identification.setEnvironmentDescription(new SimpleInternationalString("Possibly cloudy."));
            identification.setSupplementalInformation(new SimpleInternationalString("This metadata has been modified with dummy values."));
        }
        metadata.setIdentificationInfo(singleton(identification));
    }
    /*
         * Information about spatial representation.
         */
    {
        final DefaultVectorSpatialRepresentation rep = new DefaultVectorSpatialRepresentation();
        final DefaultGeometricObjects geoObj = new DefaultGeometricObjects(GeometricObjectType.POINT);
        rep.setGeometricObjects(singleton(geoObj));
        metadata.setSpatialRepresentationInfo(singleton(rep));
    }
    /*
         * Information about Coordinate Reference System.
         */
    {
        final DefaultCitation citation = new DefaultCitation("A geographic coordinate reference frames");
        citation.setAlternateTitles(singleton(new SimpleInternationalString("L101")));
        citation.setIdentifiers(singleton(new ImmutableIdentifier(null, null, "http://www.seadatanet.org/urnurl/")));
        citation.setEdition(new Anchor(URI.create("SDN:C371:1:2"), "2"));
        metadata.setReferenceSystemInfo(singleton(new ReferenceSystemMetadata(new ImmutableIdentifier(citation, "L101", "EPSG:4326"))));
    }
    /*
         * Information about content.
         */
    {
        final DefaultImageDescription contentInfo = new DefaultImageDescription();
        contentInfo.setCloudCoverPercentage(50.0);
        metadata.setContentInfo(singleton(contentInfo));
    }
    /*
         * Extension to metadata.
         */
    {
        final DefaultMetadataExtensionInformation extensionInfo = new DefaultMetadataExtensionInformation();
        extensionInfo.setExtendedElementInformation(singleton(new DefaultExtendedElementInformation(// Name
        "SDN:EDMO::", // Definition
        "http://www.seadatanet.org/urnurl/", // Condition
        null, // Data type
        Datatype.CODE_LIST, // Parent entity
        "SeaDataNet", // Rule
        null, // Source
        null)));
        metadata.setMetadataExtensionInfo(singleton(extensionInfo));
    }
    /*
         * Distribution information.
         */
    {
        @SuppressWarnings("deprecation") final DefaultResponsibleParty distributor = new DefaultResponsibleParty((DefaultResponsibility) author);
        final DefaultDistribution distributionInfo = new DefaultDistribution();
        distributor.setRole(Role.DISTRIBUTOR);
        distributionInfo.setDistributors(singleton(new DefaultDistributor(distributor)));
        final DefaultFormat format = new DefaultFormat();
        final DefaultCitation specification = new DefaultCitation();
        specification.setAlternateTitles(singleton(new Anchor(URI.create("SDN:L241:1:MEDATLAS"), "MEDATLAS ASCII")));
        specification.setEdition(new SimpleInternationalString("1.0"));
        format.setFormatSpecificationCitation(specification);
        distributionInfo.setDistributionFormats(singleton(format));
        final DefaultDigitalTransferOptions transfer = new DefaultDigitalTransferOptions();
        transfer.setTransferSize(2.431640625);
        final DefaultOnlineResource onlines = new DefaultOnlineResource(URI.create("http://www.ifremer.fr/data/something"));
        onlines.setDescription(new SimpleInternationalString("CTDF02"));
        onlines.setFunction(OnLineFunction.DOWNLOAD);
        onlines.setProtocol("http");
        transfer.setOnLines(singleton(onlines));
        distributionInfo.setTransferOptions(singleton(transfer));
        metadata.setDistributionInfo(distributionInfo);
    }
    return metadata;
}
Also used : DefaultVerticalCS(org.apache.sis.referencing.cs.DefaultVerticalCS) NamedIdentifier(org.apache.sis.referencing.NamedIdentifier) DefaultCoordinateSystemAxis(org.apache.sis.referencing.cs.DefaultCoordinateSystemAxis) Anchor(org.apache.sis.internal.jaxb.gcx.Anchor) DefaultVerticalCRS(org.apache.sis.referencing.crs.DefaultVerticalCRS) SimpleInternationalString(org.apache.sis.util.iso.SimpleInternationalString) ReferenceSystemMetadata(org.apache.sis.internal.jaxb.metadata.replace.ReferenceSystemMetadata) DefaultVerticalDatum(org.apache.sis.referencing.datum.DefaultVerticalDatum)

Example 2 with DefaultCoordinateSystemAxis

use of org.apache.sis.referencing.cs.DefaultCoordinateSystemAxis in project sis by apache.

the class StandardDefinitions method createAxis.

/**
 * Creates an axis from hard-coded values for the given code.
 *
 * @param  code  the EPSG code.
 * @return the coordinate system axis for the given code.
 */
static CoordinateSystemAxis createAxis(final short code) {
    final String name, abrv;
    Unit<?> unit = Units.METRE;
    double min = Double.NEGATIVE_INFINITY;
    double max = Double.POSITIVE_INFINITY;
    RangeMeaning rm = null;
    final AxisDirection dir;
    switch(code) {
        case 1:
            name = "Easting";
            abrv = "E";
            dir = AxisDirection.EAST;
            break;
        case 2:
            name = "Northing";
            abrv = "N";
            dir = AxisDirection.NORTH;
            break;
        case 60:
            name = "Spherical latitude";
            // See HardCodedAxes.SPHERICAL_LATITUDE in tests.
            abrv = "φ′";
            unit = Units.DEGREE;
            dir = AxisDirection.NORTH;
            min = Latitude.MIN_VALUE;
            max = Latitude.MAX_VALUE;
            rm = RangeMeaning.EXACT;
            break;
        case 61:
            name = "Spherical longitude";
            // See HardCodedAxes.SPHERICAL_LONGITUDE in tests.
            abrv = "θ";
            unit = Units.DEGREE;
            dir = AxisDirection.EAST;
            min = Longitude.MIN_VALUE;
            max = Longitude.MAX_VALUE;
            rm = RangeMeaning.WRAPAROUND;
            break;
        case 62:
            name = "Geocentric radius";
            // See HardCodedAxes.GEOCENTRIC_RADIUS in tests.
            abrv = "R";
            dir = AxisDirection.UP;
            rm = RangeMeaning.EXACT;
            min = 0;
            break;
        // Used in Ellipsoidal 3D.
        case 108:
        case 106:
            name = AxisNames.GEODETIC_LATITUDE;
            abrv = "φ";
            unit = Units.DEGREE;
            dir = AxisDirection.NORTH;
            min = Latitude.MIN_VALUE;
            max = Latitude.MAX_VALUE;
            rm = RangeMeaning.EXACT;
            break;
        // Used in Ellipsoidal 3D.
        case 109:
        case 107:
            name = AxisNames.GEODETIC_LONGITUDE;
            abrv = "λ";
            unit = Units.DEGREE;
            dir = AxisDirection.EAST;
            min = Longitude.MIN_VALUE;
            max = Longitude.MAX_VALUE;
            rm = RangeMeaning.WRAPAROUND;
            break;
        case 110:
            name = AxisNames.ELLIPSOIDAL_HEIGHT;
            abrv = "h";
            dir = AxisDirection.UP;
            break;
        case 114:
            name = AxisNames.GRAVITY_RELATED_HEIGHT;
            abrv = "H";
            dir = AxisDirection.UP;
            break;
        case 113:
            name = AxisNames.DEPTH;
            abrv = "D";
            dir = AxisDirection.DOWN;
            break;
        case 115:
            name = AxisNames.GEOCENTRIC_X;
            abrv = "X";
            dir = AxisDirection.GEOCENTRIC_X;
            break;
        case 116:
            name = AxisNames.GEOCENTRIC_Y;
            abrv = "Y";
            dir = AxisDirection.GEOCENTRIC_Y;
            break;
        case 117:
            name = AxisNames.GEOCENTRIC_Z;
            abrv = "Z";
            dir = AxisDirection.GEOCENTRIC_Z;
            break;
        // Actually no axis allocated by EPSG here, but createCoordinateSystem(1027) needs this number.
        case 1057:
        case 1056:
            name = "Easting";
            abrv = "E";
            dir = CoordinateSystems.directionAlongMeridian(AxisDirection.NORTH, 90);
            break;
        case 1058:
            name = "Northing";
            abrv = "N";
            dir = CoordinateSystems.directionAlongMeridian(AxisDirection.NORTH, 0);
            break;
        case 1065:
            name = "Easting";
            abrv = "E";
            dir = CoordinateSystems.directionAlongMeridian(AxisDirection.SOUTH, 90);
            break;
        case 1066:
            name = "Northing";
            abrv = "N";
            dir = CoordinateSystems.directionAlongMeridian(AxisDirection.SOUTH, 180);
            break;
        default:
            throw new AssertionError(code);
    }
    final Map<String, Object> properties = properties(code, name, null, false);
    properties.put(DefaultCoordinateSystemAxis.MINIMUM_VALUE_KEY, min);
    properties.put(DefaultCoordinateSystemAxis.MAXIMUM_VALUE_KEY, max);
    properties.put(DefaultCoordinateSystemAxis.RANGE_MEANING_KEY, rm);
    return new DefaultCoordinateSystemAxis(properties, abrv, dir, unit);
}
Also used : RangeMeaning(org.opengis.referencing.cs.RangeMeaning) AxisDirection(org.opengis.referencing.cs.AxisDirection) DefaultCoordinateSystemAxis(org.apache.sis.referencing.cs.DefaultCoordinateSystemAxis)

Aggregations

DefaultCoordinateSystemAxis (org.apache.sis.referencing.cs.DefaultCoordinateSystemAxis)2 Anchor (org.apache.sis.internal.jaxb.gcx.Anchor)1 ReferenceSystemMetadata (org.apache.sis.internal.jaxb.metadata.replace.ReferenceSystemMetadata)1 NamedIdentifier (org.apache.sis.referencing.NamedIdentifier)1 DefaultVerticalCRS (org.apache.sis.referencing.crs.DefaultVerticalCRS)1 DefaultVerticalCS (org.apache.sis.referencing.cs.DefaultVerticalCS)1 DefaultVerticalDatum (org.apache.sis.referencing.datum.DefaultVerticalDatum)1 SimpleInternationalString (org.apache.sis.util.iso.SimpleInternationalString)1 AxisDirection (org.opengis.referencing.cs.AxisDirection)1 RangeMeaning (org.opengis.referencing.cs.RangeMeaning)1