com.graphhopper.routing.ev.RoadEnvironment Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of graphhopper-core Show documentation
Show all versions of graphhopper-core Show documentation
GraphHopper is a fast and memory efficient Java road routing engine
working seamlessly with OpenStreetMap data.
/*
* 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.routing.ev;
import com.graphhopper.util.Helper;
/**
* This enum the road environment of an edge. Currently road, ferry, tunnel, ford, bridge. All edges
* that do not fit get "other" as value.
*/
public enum RoadEnvironment {
OTHER, ROAD, FERRY, TUNNEL, BRIDGE, FORD;
public static final String KEY = "road_environment";
public static EnumEncodedValue create() {
return new EnumEncodedValue<>(RoadEnvironment.KEY, RoadEnvironment.class);
}
@Override
public String toString() {
return Helper.toLowerCase(super.toString());
}
public static RoadEnvironment find(String name) {
if (name == null)
return OTHER;
try {
return RoadEnvironment.valueOf(Helper.toUpperCase(name));
} catch (IllegalArgumentException ex) {
return OTHER;
}
}
}