diff --git a/src/org/openstreetmap/josm/data/validation/tests/SharpAngles.java b/src/org/openstreetmap/josm/data/validation/tests/SharpAngles.java
index 676eb47f10..48c152a7fc 100644
|
a
|
b
|
import static org.openstreetmap.josm.tools.I18n.tr;
|
| 5 | 5 | |
| 6 | 6 | import java.util.Arrays; |
| 7 | 7 | import java.util.Collection; |
| | 8 | import java.util.Collections; |
| 8 | 9 | import java.util.TreeSet; |
| 9 | 10 | |
| 10 | 11 | import org.openstreetmap.josm.data.coor.EastNorth; |
| … |
… |
import org.openstreetmap.josm.data.preferences.sources.ValidatorPrefHelper;
|
| 16 | 17 | import org.openstreetmap.josm.data.validation.Severity; |
| 17 | 18 | import org.openstreetmap.josm.data.validation.Test; |
| 18 | 19 | import org.openstreetmap.josm.data.validation.TestError; |
| | 20 | import org.openstreetmap.josm.spi.preferences.Config; |
| 19 | 21 | import org.openstreetmap.josm.tools.Geometry; |
| 20 | 22 | import org.openstreetmap.josm.tools.bugreport.BugReport; |
| 21 | 23 | |
| … |
… |
public class SharpAngles extends Test {
|
| 28 | 30 | private static final int SHARPANGLESCODE = 3800; |
| 29 | 31 | /** The code for a sharp angle */ |
| 30 | 32 | private static final int SHARP_ANGLES = SHARPANGLESCODE + 0; |
| 31 | | /** The maximum angle for sharp angles */ |
| 32 | | private double maxAngle = 45.0; // degrees |
| 33 | | /** The length that at least one way segment must be shorter than */ |
| 34 | | private double maxLength = 10.0; // meters |
| | 33 | /** The maximum angle for sharp angles (degrees) */ |
| | 34 | private double maxAngle; |
| | 35 | /** The length that at least one way segment must be shorter than (meters) */ |
| | 36 | private double maxLength; |
| 35 | 37 | /** Specific highway types to ignore */ |
| 36 | | private final Collection<String> ignoreHighways = new TreeSet<>( |
| 37 | | Arrays.asList("platform", "rest_area", "services", "via_ferrata")); |
| | 38 | private final Collection<String> ignoreHighways; |
| | 39 | /** Specific railway types to ignore */ |
| | 40 | private final Collection<String> ignoreRailway; |
| 38 | 41 | |
| 39 | 42 | /** |
| 40 | 43 | * Construct a new {@code IntersectionIssues} object |
| 41 | 44 | */ |
| 42 | 45 | public SharpAngles() { |
| 43 | | super(tr("Sharp angles"), tr("Check for sharp angles on roads")); |
| | 46 | super(tr("Sharp angles"), tr("Check for sharp angles on man made transportation ways")); |
| | 47 | this.maxLength = Config.getPref().getDouble("validator.sharpangles.maxlength", 10.0); // meters |
| | 48 | this.maxAngle = Config.getPref().getDouble("validator.sharpangles.maxlength", 45.0); // degrees |
| | 49 | this.ignoreRailway = Collections.unmodifiableCollection(new TreeSet<>( |
| | 50 | Config.getPref().getList("validator.sharpangles.ignorerailway", |
| | 51 | Arrays.asList("crossing_box", "loading_ramp", "platform", "roundhouse", "signal_box", "station", |
| | 52 | "traverser", "wash", "workshop")))); |
| | 53 | // TODO make immutable when addIgnoredHighway is removed |
| | 54 | this.ignoreHighways = new TreeSet<>( |
| | 55 | Config.getPref().getList("validator.sharpangles.ignorehighway", |
| | 56 | Arrays.asList("platform", "rest_area", "services", "via_ferrata")) |
| | 57 | ); |
| 44 | 58 | } |
| 45 | 59 | |
| 46 | 60 | @Override |
| … |
… |
public class SharpAngles extends Test {
|
| 61 | 75 | * @return {@code true} if the way should be checked. |
| 62 | 76 | */ |
| 63 | 77 | public boolean shouldBeTestedForSharpAngles(Way way) { |
| 64 | | return (way.hasKey("highway") && !way.hasTag("area", "yes") && !way.hasKey("via_ferrata_scale") && |
| 65 | | !ignoreHighways.contains(way.get("highway"))); |
| | 78 | return !way.hasTag("area", "yes") && |
| | 79 | ((way.hasKey("highway") && !way.hasKey("via_ferrata_scale") && !ignoreHighways.contains(way.get("highway"))) |
| | 80 | || (way.hasKey("railway") && !ignoreRailway.contains(way.get("railway")))); |
| 66 | 81 | } |
| 67 | 82 | |
| 68 | 83 | /** |
| … |
… |
public class SharpAngles extends Test {
|
| 139 | 154 | /** |
| 140 | 155 | * Add a highway to ignore |
| 141 | 156 | * @param highway The highway type to ignore (e.g., if you want to ignore residential roads, use "residential") |
| | 157 | * @since xxx (deprecated) |
| | 158 | * @deprecated Not known to be used. Please use config preference "validator.sharpangles.ignorehighway" instead. |
| 142 | 159 | */ |
| | 160 | @Deprecated |
| 143 | 161 | public void addIgnoredHighway(String highway) { |
| | 162 | // Don't forget to make ignoreHighways immutable when this method is removed |
| 144 | 163 | ignoreHighways.add(highway); |
| 145 | 164 | } |
| 146 | 165 | |