- Timestamp:
- 2020-03-19T21:52:26+01:00 (5 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/org/openstreetmap/josm/actions/OrthogonalizeAction.java
r16119 r16175 210 210 final int nodesCount = nodeList.size(); 211 211 if (wayDataList.isEmpty() && nodesCount > 2) { 212 final WayData data = new WayData(nodeList); 213 final Collection<Command> commands = orthogonalize(Collections.singletonList(data), Collections.<Node>emptyList()); 214 return new SequenceCommand(tr("Orthogonalize"), commands); 215 } else if (wayDataList.isEmpty()) { 216 throw new InvalidUserInputException("usage"); 217 } else { 218 if (nodesCount <= 2) { 219 OrthogonalizeAction.rememberMovements.clear(); 220 final Collection<Command> commands = new LinkedList<>(); 221 222 if (nodesCount == 2) { // fixed direction, or single node to move 223 commands.addAll(orthogonalize(wayDataList, nodeList)); 224 } else if (nodesCount == 1) { 225 commands.add(orthogonalize(wayDataList, nodeList.get(0))); 226 } else if (nodesCount == 0) { 227 for (List<WayData> g : buildGroups(wayDataList)) { 228 commands.addAll(orthogonalize(g, nodeList)); 229 } 230 } 231 212 return new SequenceCommand(tr("Orthogonalize"), 213 orthogonalize(Collections.singletonList(new WayData(nodeList)), Collections.<Node>emptyList())); 214 } else if (!wayDataList.isEmpty() && nodesCount <= 2) { 215 OrthogonalizeAction.rememberMovements.clear(); 216 final Collection<Command> commands = new LinkedList<>(); 217 218 if (nodesCount == 2) { // fixed direction, or single node to move 219 commands.addAll(orthogonalize(wayDataList, nodeList)); 220 } else if (nodesCount == 1) { 221 commands.add(orthogonalize(wayDataList, nodeList.get(0))); 222 } else if (nodesCount == 0) { 223 for (List<WayData> g : buildGroups(wayDataList)) { 224 commands.addAll(orthogonalize(g, nodeList)); 225 } 226 } 227 228 if (!commands.isEmpty()) { 232 229 return new SequenceCommand(tr("Orthogonalize"), commands); 233 234 } else { 235 throw new InvalidUserInputException("usage"); 236 } 237 } 230 } 231 } 232 throw new InvalidUserInputException("usage"); 238 233 } 239 234
Note:
See TracChangeset
for help on using the changeset viewer.