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

src.gov.nasa.worldwind.ogc.kml.KMLMultiGeometry Maven / Gradle / Ivy

Go to download

World Wind is a collection of components that interactively display 3D geographic information within Java applications or applets.

There is a newer version: 2.0.0-986
Show newest version
/*
 * Copyright (C) 2012 United States Government as represented by the Administrator of the
 * National Aeronautics and Space Administration.
 * All Rights Reserved.
 */

package gov.nasa.worldwind.ogc.kml;

import gov.nasa.worldwind.util.*;
import gov.nasa.worldwind.util.xml.XMLEventParserContext;

import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.XMLEvent;
import java.util.*;

/**
 * Represents the KML MultiGeometry element and provides access to its contents.
 *
 * @author tag
 * @version $Id: KMLMultiGeometry.java 1171 2013-02-11 21:45:02Z dcollins $
 */
public class KMLMultiGeometry extends KMLAbstractGeometry
{
    protected List geometries = new ArrayList();

    /**
     * Construct an instance.
     *
     * @param namespaceURI the qualifying namespace URI. May be null to indicate no namespace qualification.
     */
    public KMLMultiGeometry(String namespaceURI)
    {
        super(namespaceURI);
    }

    @Override
    protected void doAddEventContent(Object o, XMLEventParserContext ctx, XMLEvent event, Object... args)
        throws XMLStreamException
    {
        if (o instanceof KMLAbstractGeometry)
            this.addGeometry((KMLAbstractGeometry) o);
        else
            super.doAddEventContent(o, ctx, event, args);
    }

    protected void addGeometry(KMLAbstractGeometry o)
    {
        this.geometries.add(o);
    }

    public List getGeometries()
    {
        return this.geometries;
    }

    @Override
    public void applyChange(KMLAbstractObject sourceValues)
    {
        if (!(sourceValues instanceof KMLMultiGeometry))
        {
            String message = Logging.getMessage("nullValue.SourceIsNull");
            Logging.logger().warning(message);
            throw new IllegalArgumentException(message);
        }

        KMLMultiGeometry multiGeometry = (KMLMultiGeometry) sourceValues;

        if (multiGeometry.getGeometries() != null && multiGeometry.getGeometries().size() > 0)
            this.mergeGeometries(multiGeometry);

        super.applyChange(sourceValues);
    }

    /**
     * Merge a list of incoming geometries with the current list. If an incoming geometry has the same ID as
     * an existing one, replace the existing one, otherwise just add the incoming one.
     *
     * @param sourceMultiGeometry the incoming geometries.
     */
    protected void mergeGeometries(KMLMultiGeometry sourceMultiGeometry)
    {
        // Make a copy of the existing list so we can modify it as we traverse the copy.
        List geometriesCopy = new ArrayList(this.getGeometries().size());
        Collections.copy(geometriesCopy, this.getGeometries());

        for (KMLAbstractGeometry sourceGeometry : sourceMultiGeometry.getGeometries())
        {
            String id = sourceGeometry.getId();
            if (!WWUtil.isEmpty(id))
            {
                for (KMLAbstractGeometry existingGeometry : geometriesCopy)
                {
                    String currentId = existingGeometry.getId();
                    if (!WWUtil.isEmpty(currentId) && currentId.equals(id))
                    {
                        this.getGeometries().remove(existingGeometry);
                    }
                }
            }

            this.getGeometries().add(sourceGeometry);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy