
com.graphhopper.util.EdgeIterator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of graphhopper Show documentation
Show all versions of graphhopper Show documentation
GraphHopper with some modifications
The newest version!
/*
* Licensed to GraphHopper GmbH under one or more contributor
* license agreements. See the NOTICE file distributed with this work for
* additional information regarding copyright ownership.
*
* GraphHopper GmbH licenses this file to you under the Apache License,
* Version 2.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.graphhopper.util;
/**
* Iterates through all edges of one node. Avoids object creation in-between via direct access
* methods. If you want to access some properties of an 'edge' (i.e. the current state) for later
* usage store it via edgeIterator.detach() or edgeIterator.getEdge() instead of the iterator
* itself. Usage:
*
* EdgeExplorer explorer = graph.createEdgeExplorer();
* EdgeIterator iter = explorer.setBaseNode(nodeId);
* // calls to iter.getAdjNode(), getDistance() without calling next() will cause undefined behaviour!
* while(iter.next()) {
* int baseNodeId = iter.getBaseNode(); // equal to nodeId
* int adjacentNodeId = iter.getAdjNode(); // this is the node where this edge state is "pointing to"
* ...
* }
*
*
*
* @author Peter Karich
* @see EdgeIteratorState
* @see EdgeExplorer
*/
public interface EdgeIterator extends EdgeIteratorState {
/**
* integer value to indicate if an edge is valid or not which then would be initialized with
* this value
*/
int NO_EDGE = -1;
/**
* To be called to go to the next edge state.
*
*
* @return true if an edge state is available
*/
boolean next();
class Edge {
public static boolean isValid(int edgeId) {
return edgeId > NO_EDGE;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy