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;
}
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);
}
Aggregations