org.geotoolkit.referencing.cs.DefaultCompoundCS Maven / Gradle / Ivy
/*
* Geotoolkit.org - An Open Source Java GIS Toolkit
* http://www.geotoolkit.org
*
* (C) 2004-2012, Open Source Geospatial Foundation (OSGeo)
* (C) 2009-2012, Geomatys
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* This package contains documentation from OpenGIS specifications.
* OpenGIS consortium's work is fully acknowledged here.
*/
package org.geotoolkit.referencing.cs;
import java.util.List;
import java.util.Arrays;
import java.util.Collections;
import net.jcip.annotations.Immutable;
import org.opengis.referencing.cs.CoordinateSystem;
import org.opengis.referencing.cs.CoordinateSystemAxis;
import org.geotoolkit.util.ComparisonMode;
import static org.geotoolkit.util.Utilities.deepEquals;
import static org.geotoolkit.util.ArgumentChecks.ensureNonNull;
/**
* A coordinate system made of two or more independent coordinate systems.
*
*
* Used with CRS type(s)
*
* {@link org.geotoolkit.referencing.crs.DefaultCompoundCRS Compound}
*
*
* @author Martin Desruisseaux (IRD, Geomatys)
* @version 3.20
*
* @since 2.0
* @module
*/
@Immutable
public class DefaultCompoundCS extends AbstractCS {
/**
* Serial number for inter-operability with different versions.
*/
private static final long serialVersionUID = -5726410275278843373L;
/**
* The coordinate systems.
*/
private final CoordinateSystem[] components;
/**
* An immutable view of {@link #components} as a list. Will be created only when first needed.
*/
private transient List asList;
/**
* Constructs a compound coordinate system. A name for this CS will
* be automatically constructed from the name of all specified CS.
*
* @param components The set of coordinate system.
*/
public DefaultCompoundCS(CoordinateSystem... components) {
super(getName(components=clone(components)), getAxis(components));
this.components = components;
}
/**
* Returns a clone of the specified array. This method would be bundle right
* into the constructor if RFE #4093999 was fixed.
*/
private static CoordinateSystem[] clone(CoordinateSystem[] components) {
ensureNonNull("components", components);
components = components.clone();
for (int i=0; i getCoordinateSystems() {
return getComponents();
}
/**
* Returns all coordinate systems in this compound CS.
*
* @return All coordinate systems in this compound CS.
*
* @since 3.20
*/
public synchronized List getComponents() {
if (asList == null) {
asList = Collections.unmodifiableList(Arrays.asList(components));
}
return asList;
}
/**
* Compares this coordinate system with the specified object for equality.
*
* @param object The object to compare to {@code this}.
* @param mode {@link ComparisonMode#STRICT STRICT} for performing a strict comparison, or
* {@link ComparisonMode#IGNORE_METADATA IGNORE_METADATA} for comparing only properties
* relevant to transformations.
* @return {@code true} if both objects are equal.
*/
@Override
public boolean equals(final Object object, final ComparisonMode mode) {
if (object == this) {
return true; // Slight optimization.
}
if (object instanceof DefaultCompoundCS && super.equals(object, mode)) {
final DefaultCompoundCS that = (DefaultCompoundCS) object;
return deepEquals(this.components, that.components, mode);
}
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy