AbstractGraphSpace.java
package org.opentrafficsim.draw.graphs;
import java.util.Iterator;
import java.util.List;
/**
* Common functionality between a cross-section and a path.
* <p>
* Copyright (c) 2013-2024 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
* BSD-style license. See <a href="https://opentrafficsim.org/docs/license.html">OpenTrafficSim License</a>.
* </p>
* @author <a href="https://github.com/averbraeck">Alexander Verbraeck</a>
* @author <a href="https://tudelft.nl/staff/p.knoppers-1">Peter Knoppers</a>
* @author <a href="https://github.com/wjschakel">Wouter Schakel</a>
* @param <S> underlying type of path sections
*/
public abstract class AbstractGraphSpace<S> implements Iterable<S>
{
/** Series names. */
private final List<String> seriesNames;
/**
* Constructor.
* @param seriesNames List<String>; names of series
*/
public AbstractGraphSpace(final List<String> seriesNames)
{
this.seriesNames = seriesNames;
}
/**
* Returns the name of the series.
* @param series int; series
* @return String; name of the series
*/
public String getName(final int series)
{
return this.seriesNames.get(series);
}
/**
* Returns the number of series.
* @return int; number of series
*/
public int getNumberOfSeries()
{
return this.seriesNames.size();
}
/**
* Returns an iterator over the sources on the given series.
* @param series int; number of the series
* @return Iterator<S>; iterator over the sources on the given series
*/
abstract Iterator<S> iterator(int series);
}