Ignore:
Timestamp:
2016-08-08T23:25:04+02:00 (8 years ago)
Author:
darya
Message:

Key listener added to select fix variant

Location:
applications/editors/josm/plugins/pt_assistant/src/org/openstreetmap/josm/plugins/pt_assistant
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/pt_assistant/src/org/openstreetmap/josm/plugins/pt_assistant/gui/PTAssistantLayer.java

    r32776 r32784  
    5050                Main.getLayerManager().addLayerChangeListener(this);
    5151                layer = this;
    52 
    5352        }
    5453       
     
    7473       
    7574        /**
    76          * Adds fix variants to be displayed in the pt_assistant layer
     75         * Adds the first 5 fix variants to be displayed in the pt_assistant layer
    7776         * @param fixVariants
    7877         */
     
    8180                for (int i = 0; i < fixVariants.size(); i++) {
    8281                        if (i < 5) {
    83                                 List<PTWay> fixVariant = fixVariants.get(0);
     82                                List<PTWay> fixVariant = fixVariants.get(i);
    8483                                this.fixVariants.put(alphabet, fixVariant);
    8584                                alphabet++;
    8685                        }
    8786                }
    88                
    89 //              for (List<PTWay> fixVariant: fixVariants) {
    90 //                     
    91 //                      this.fixVariants.put(alphabet, fixVariant);
    92 //                      alphabet++;
    93 //              }
    9487        }
    9588       
  • applications/editors/josm/plugins/pt_assistant/src/org/openstreetmap/josm/plugins/pt_assistant/gui/PTAssistantPaintVisitor.java

    r32776 r32784  
    405405
    406406                int colorIndex = 0;
    407                
     407
    408408                double letterX = Main.map.mapView.getBounds().getMinX() + 20;
    409409                double letterY = Main.map.mapView.getBounds().getMinY() + 100;
     
    412412                        if (fixVariants.get(c) != null) {
    413413                                drawFixVariant(fixVariants.get(c), colors[colorIndex % 5]);
    414                                 drawFixVariantLetter(fixVariants.get(c), c, colors[colorIndex%5], letterX, letterY);
     414                                drawFixVariantLetter(c.toString(), colors[colorIndex % 5], letterX, letterY);
    415415                                colorIndex++;
    416416                                letterY = letterY + 60;
    417417                        }
    418418                }
    419                
    420                
     419
     420                // display the "Esc" label:
     421                if (!fixVariants.isEmpty()) {
     422                        drawFixVariantLetter("Esc", Color.WHITE, letterX, letterY);
     423                }
    421424        }
    422425
     
    436439        }
    437440       
    438         private void drawFixVariantLetter(List<PTWay> fixVariant, Character letter, Color color, double letterX, double letterY) {
     441        /**
     442         *
     443         * @param n1
     444         * @param n2
     445         * @param color
     446         */
     447        protected void drawSegmentWithParallelLines(Node n1, Node n2, Color color) {
     448                if (!n1.isDrawable() || !n2.isDrawable() || !isSegmentVisible(n1, n2)) {
     449                                return;
     450                }
     451               
     452                Point p1 = mv.getPoint(n1);
     453                Point p2 = mv.getPoint(n2);
     454
     455                double t = Math.atan2((double) p2.x - p1.x, (double) p2.y - p1.y);
     456                double cosT = 9 * Math.cos(t);
     457                double sinT = 9 * Math.sin(t);
     458
     459                int[] xPoints = { (int) (p1.x + cosT), (int) (p2.x + cosT), (int) (p2.x - cosT), (int) (p1.x - cosT) };
     460                int[] yPoints = { (int) (p1.y - sinT), (int) (p2.y - sinT), (int) (p2.y + sinT), (int) (p1.y + sinT) };
     461                g.setColor(color);
     462                g.fillPolygon(xPoints, yPoints, 4);
     463                g.fillOval((int) (p1.x - 9), (int) (p1.y - 9), 18, 18);
     464                g.fillOval((int) (p2.x - 9), (int) (p2.y - 9), 18, 18);
     465        }
     466
     467        private void drawFixVariantLetter(String letter, Color color, double letterX, double letterY) {
    439468                g.setColor(color);
    440469                Font stringFont = new Font("SansSerif", Font.PLAIN, 50);
    441470                g.setFont(stringFont);
    442                 g.drawString(letter.toString(), (int) letterX, (int) letterY);
    443                 g.drawString(letter.toString(), (int) letterX, (int) letterY);
     471                g.drawString(letter, (int) letterX, (int) letterY);
     472                g.drawString(letter, (int) letterX, (int) letterY);
    444473        }
    445474
  • applications/editors/josm/plugins/pt_assistant/src/org/openstreetmap/josm/plugins/pt_assistant/validation/Checker.java

    r32616 r32784  
    22
    33import java.util.ArrayList;
     4import java.util.Collection;
    45import java.util.List;
    56
     7import javax.swing.SwingUtilities;
     8
     9import org.openstreetmap.josm.Main;
     10import org.openstreetmap.josm.actions.AutoScaleAction;
     11import org.openstreetmap.josm.command.Command;
     12import org.openstreetmap.josm.command.SelectCommand;
    613import org.openstreetmap.josm.data.osm.Node;
     14import org.openstreetmap.josm.data.osm.OsmPrimitive;
    715import org.openstreetmap.josm.data.osm.Relation;
    816import org.openstreetmap.josm.data.osm.RelationMember;
    917import org.openstreetmap.josm.data.validation.Test;
    1018import org.openstreetmap.josm.data.validation.TestError;
     19import org.openstreetmap.josm.gui.dialogs.relation.GenericRelationEditor;
     20import org.openstreetmap.josm.gui.dialogs.relation.RelationEditor;
     21import org.openstreetmap.josm.gui.layer.OsmDataLayer;
     22import org.openstreetmap.josm.plugins.pt_assistant.gui.PTAssistantLayer;
    1123import org.openstreetmap.josm.plugins.pt_assistant.utils.RouteUtils;
    1224
     
    114126                return resultList;
    115127        }
     128       
     129        /**
     130         *
     131         * @param testError
     132         * @return
     133         */
     134        protected static Command fixErrorByZooming(TestError testError) {
     135
     136                if (testError.getCode() != PTAssistantValidatorTest.ERROR_CODE_STOP_BY_STOP) {
     137                        return null;
     138                }
     139
     140                Collection<? extends OsmPrimitive> primitives = testError.getPrimitives();
     141                Relation originalRelation = (Relation) primitives.iterator().next();
     142                ArrayList<OsmPrimitive> primitivesToZoom = new ArrayList<>();
     143                for (Object primitiveToZoom : testError.getHighlighted()) {
     144                        primitivesToZoom.add((OsmPrimitive) primitiveToZoom);
     145                }
     146
     147                SelectCommand command = new SelectCommand(primitivesToZoom);
     148
     149                List<OsmDataLayer> listOfLayers = Main.getLayerManager().getLayersOfType(OsmDataLayer.class);
     150                for (OsmDataLayer osmDataLayer : listOfLayers) {
     151                        if (osmDataLayer.data == originalRelation.getDataSet()) {
     152
     153                                final OsmDataLayer layerParameter = osmDataLayer;
     154                                final Relation relationParameter = originalRelation;
     155                                final Collection<OsmPrimitive> zoomParameter = primitivesToZoom;
     156
     157                                if (SwingUtilities.isEventDispatchThread()) {
     158
     159                                        showRelationEditorAndZoom(layerParameter, relationParameter, zoomParameter);
     160
     161                                } else {
     162
     163                                        SwingUtilities.invokeLater(new Runnable() {
     164                                                @Override
     165                                                public void run() {
     166
     167                                                        showRelationEditorAndZoom(layerParameter, relationParameter, zoomParameter);
     168
     169                                                }
     170                                        });
     171
     172                                }
     173
     174                                return command;
     175                        }
     176                }
     177
     178                return null;
     179
     180        }
     181
     182        private static void showRelationEditorAndZoom(OsmDataLayer layer, Relation r, Collection<OsmPrimitive> primitives) {
     183
     184                // zoom to problem:
     185                AutoScaleAction.zoomTo(primitives);
     186
     187                // put stop-related members to the front and edit roles if necessary:
     188                List<RelationMember> sortedRelationMembers = listStopMembers(r);
     189                sortedRelationMembers.addAll(listNotStopMembers(r));
     190                r.setMembers(sortedRelationMembers);
     191
     192                // create editor:
     193                GenericRelationEditor editor = (GenericRelationEditor) RelationEditor.getEditor(layer, r,
     194                                r.getMembersFor(primitives));
     195
     196                // open editor:
     197                editor.setVisible(true);
     198
     199                // make the current relation purple in the pt_assistant layer:
     200                PTAssistantLayer.getLayer().repaint(r);
     201
     202        }
    116203
    117204}
  • applications/editors/josm/plugins/pt_assistant/src/org/openstreetmap/josm/plugins/pt_assistant/validation/SegmentChecker.java

    r32776 r32784  
    33import static org.openstreetmap.josm.tools.I18n.tr;
    44
    5 import java.lang.reflect.InvocationTargetException;
     5import java.awt.event.KeyEvent;
     6import java.awt.event.KeyListener;
    67import java.util.ArrayList;
    78import java.util.Collection;
     
    910import java.util.List;
    1011
    11 import javax.swing.JOptionPane;
    1212import javax.swing.SwingUtilities;
    1313
     
    1616import org.openstreetmap.josm.command.ChangeCommand;
    1717import org.openstreetmap.josm.command.Command;
    18 import org.openstreetmap.josm.command.SelectCommand;
    1918import org.openstreetmap.josm.data.coor.LatLon;
    2019import org.openstreetmap.josm.data.osm.Node;
    2120import org.openstreetmap.josm.data.osm.OsmPrimitive;
    22 import org.openstreetmap.josm.data.osm.OsmPrimitiveType;
    2321import org.openstreetmap.josm.data.osm.Relation;
    2422import org.openstreetmap.josm.data.osm.RelationMember;
     
    2725import org.openstreetmap.josm.data.validation.Test;
    2826import org.openstreetmap.josm.data.validation.TestError;
    29 import org.openstreetmap.josm.gui.dialogs.relation.GenericRelationEditor;
    30 import org.openstreetmap.josm.gui.dialogs.relation.RelationEditor;
    31 import org.openstreetmap.josm.gui.layer.OsmDataLayer;
     27import org.openstreetmap.josm.gui.Notification;
    3228import org.openstreetmap.josm.plugins.pt_assistant.data.PTRouteDataManager;
    3329import org.openstreetmap.josm.plugins.pt_assistant.data.PTRouteSegment;
     
    3531import org.openstreetmap.josm.plugins.pt_assistant.data.PTWay;
    3632import org.openstreetmap.josm.plugins.pt_assistant.gui.PTAssistantLayer;
    37 import org.openstreetmap.josm.plugins.pt_assistant.utils.RouteUtils;
    3833import org.openstreetmap.josm.plugins.pt_assistant.utils.StopToWayAssigner;
    3934
     
    535530
    536531        /**
     532         * Finds the next ways for the route stop-by-stop parsing procedure
    537533         *
    538534         * @param way
     
    693689        protected static Command fixError(TestError testError) {
    694690
     691                // if fix options for another route are displayed in the pt_assistant
     692                // layer, clear them:
     693                ((PTAssistantValidatorTest) testError.getTester()).clearFixVariants();
     694
    695695                PTRouteSegment wrongSegment = wrongSegments.get(testError);
    696696
     
    706706                if (!correctSegmentsForThisError.isEmpty()) {
    707707
    708                         List<PTWay> fix = null;
    709 
    710708                        if (correctSegmentsForThisError.size() > 1) {
    711                                 fix = displayCorrectSegmentVariants(correctSegmentsForThisError, testError);
    712                                 if (fix == null) {
    713                                         return null;
    714                                 }
    715                         } else {
    716                                 fix = correctSegmentsForThisError.get(0).getPTWays();
    717                                 final Collection<OsmPrimitive> waysToZoom = new ArrayList<>();
    718                                 for (Object highlightedPrimitive: testError.getHighlighted()) {
    719                                         waysToZoom.add((OsmPrimitive)highlightedPrimitive);
    720                                 }
    721                                 if (SwingUtilities.isEventDispatchThread()) {
    722                                         AutoScaleAction.zoomTo(waysToZoom);
    723                                 } else {
    724                                         SwingUtilities.invokeLater(new Runnable() {
    725                                                 @Override
    726                                                 public void run() {
    727                                                         AutoScaleAction.zoomTo(waysToZoom);
    728                                                 }
    729                                         });
    730                                 }
    731                                 synchronized(SegmentChecker.class) {
    732                                         try {
    733                                                 SegmentChecker.class.wait(2000);
    734                                         } catch (InterruptedException e) {
    735                                                 // TODO Auto-generated catch block
    736                                                 e.printStackTrace();
    737                                         }
    738                                 }
    739                         }
    740 
    741                         Relation originalRelation = (Relation) testError.getPrimitives().iterator().next();
    742                         Relation modifiedRelation = new Relation(originalRelation);
    743                         List<RelationMember> originalRelationMembers = originalRelation.getMembers();
    744                         List<RelationMember> modifiedRelationMembers = new ArrayList<>();
    745 
    746                         // copy stops first:
    747                         for (RelationMember rm : originalRelationMembers) {
    748                                 if (RouteUtils.isPTStop(rm)) {
    749                                         if (rm.getRole().equals("stop_position")) {
    750                                                 if (rm.getType().equals(OsmPrimitiveType.NODE)) {
    751                                                         RelationMember newMember = new RelationMember("stop", rm.getNode());
    752                                                         modifiedRelationMembers.add(newMember);
    753                                                 } else { // if it is a way:
    754                                                         RelationMember newMember = new RelationMember("stop", rm.getWay());
    755                                                         modifiedRelationMembers.add(newMember);
    756                                                 }
    757                                         } else {
    758                                                 // if the relation member does not have the role
    759                                                 // "stop_position":
    760                                                 modifiedRelationMembers.add(rm);
    761                                         }
    762                                 }
    763                         }
    764 
    765                         // copy PTWays next:
    766                         List<RelationMember> waysOfOriginalRelation = new ArrayList<>();
    767                         for (RelationMember rm : originalRelation.getMembers()) {
    768                                 if (RouteUtils.isPTWay(rm)) {
    769                                         waysOfOriginalRelation.add(rm);
    770                                 }
    771                         }
    772 
    773                         for (int i = 0; i < waysOfOriginalRelation.size(); i++) {
    774                                 if (waysOfOriginalRelation.get(i).getWay() == wrongSegment.getPTWays().get(0).getWays().get(0)) {
    775                                         for (PTWay ptway : fix) {
    776                                                 if (ptway.getRole().equals("forward") || ptway.getRole().equals("backward")) {
    777                                                         modifiedRelationMembers.add(new RelationMember("", ptway.getMember()));
    778                                                 } else {
    779                                                         modifiedRelationMembers.add(ptway);
    780                                                 }
    781                                         }
    782                                         i = i + wrongSegment.getPTWays().size() - 1;
    783                                 } else {
    784                                         if (waysOfOriginalRelation.get(i).getRole().equals("forward")
    785                                                         || waysOfOriginalRelation.get(i).getRole().equals("backward")) {
    786                                                 modifiedRelationMembers.add(new RelationMember("", waysOfOriginalRelation.get(i).getMember()));
    787                                         } else {
    788                                                 modifiedRelationMembers.add(waysOfOriginalRelation.get(i));
    789                                         }
    790                                 }
    791                         }
    792 
    793                         modifiedRelation.setMembers(modifiedRelationMembers);
    794                         // TODO: change the data model too
    795                         wrongSegments.remove(testError);
    796                         ChangeCommand changeCommand = new ChangeCommand(originalRelation, modifiedRelation);
    797                         return changeCommand;
     709                                List<List<PTWay>> fixVariants = new ArrayList<>();
     710                                for (PTRouteSegment segment : correctSegmentsForThisError) {
     711                                        fixVariants.add(segment.getPTWays());
     712                                }
     713                                displayFixVariants(fixVariants, testError);
     714                                return null;
     715                        }
     716
     717                        return carryOutSingleFix(testError, correctSegmentsForThisError.get(0).getPTWays());
    798718
    799719                } else if (!wrongSegment.getFixVariants().isEmpty()) {
    800 
    801                         List<PTWay> fix = null;
    802 
     720                        // 2) try to fix using the sorting and removal of existing ways
     721                        // of the wrong segment:
    803722                        if (wrongSegment.getFixVariants().size() > 1) {
    804                                 fix = displayFixVariants(wrongSegment.getFixVariants(), testError);
    805                                 if (fix == null) {
    806                                         return null;
    807                                 }
    808                         } else {
    809                                 fix = wrongSegment.getFixVariants().get(0);
    810                                 final Collection<OsmPrimitive> waysToZoom = new ArrayList<>();
    811                                 for (Object highlightedPrimitive: testError.getHighlighted()) {
    812                                         waysToZoom.add((OsmPrimitive)highlightedPrimitive);
    813                                 }
    814                                 if (SwingUtilities.isEventDispatchThread()) {
    815                                         AutoScaleAction.zoomTo(waysToZoom);
    816                                 } else {
    817                                         SwingUtilities.invokeLater(new Runnable() {
    818                                                 @Override
    819                                                 public void run() {
    820                                                         AutoScaleAction.zoomTo(waysToZoom);
    821                                                 }
    822                                         });
    823                                 }
    824                                 synchronized(SegmentChecker.class) {
    825                                         try {
    826                                                 SegmentChecker.class.wait(2000);
    827                                         } catch (InterruptedException e) {
    828                                                 // TODO Auto-generated catch block
    829                                                 e.printStackTrace();
    830                                         }
    831                                 }
    832                         }
    833 
    834                         // 2) try to fix by using the sort & remove method:
    835                         // TODO: ask user if the change should be undertaken
    836                         Relation originalRelation = (Relation) testError.getPrimitives().iterator().next();
    837                         Relation modifiedRelation = new Relation(originalRelation);
    838                         List<RelationMember> originalRelationMembers = originalRelation.getMembers();
    839                         List<RelationMember> modifiedRelationMembers = new ArrayList<>();
    840 
    841                         // copy stops first:
    842                         for (RelationMember rm : originalRelationMembers) {
    843                                 if (RouteUtils.isPTStop(rm)) {
    844                                         if (rm.getRole().equals("stop_position")) {
    845                                                 if (rm.getType().equals(OsmPrimitiveType.NODE)) {
    846                                                         RelationMember newMember = new RelationMember("stop", rm.getNode());
    847                                                         modifiedRelationMembers.add(newMember);
    848                                                 } else { // if it is a way:
    849                                                         RelationMember newMember = new RelationMember("stop", rm.getWay());
    850                                                         modifiedRelationMembers.add(newMember);
    851                                                 }
    852                                         } else {
    853                                                 // if the relation member does not have the role
    854                                                 // "stop_position":
    855                                                 modifiedRelationMembers.add(rm);
    856                                         }
    857                                 }
    858                         }
    859 
    860                         // copy PTWays next:
    861                         List<RelationMember> waysOfOriginalRelation = new ArrayList<>();
    862                         for (RelationMember rm : originalRelation.getMembers()) {
    863                                 if (RouteUtils.isPTWay(rm)) {
    864                                         waysOfOriginalRelation.add(rm);
    865                                 }
    866                         }
    867 
    868                         for (int i = 0; i < waysOfOriginalRelation.size(); i++) {
    869                                 if (waysOfOriginalRelation.get(i).getWay() == wrongSegment.getPTWays().get(0).getWays().get(0)) {
    870                                         for (PTWay ptway : fix) {
    871                                                 if (ptway.getRole().equals("forward") || ptway.getRole().equals("backward")) {
    872                                                         modifiedRelationMembers.add(new RelationMember("", ptway.getMember()));
    873                                                 } else {
    874                                                         modifiedRelationMembers.add(ptway);
    875                                                 }
    876                                         }
    877                                         i = i + wrongSegment.getPTWays().size() - 1;
    878                                 } else {
    879                                         if (waysOfOriginalRelation.get(i).getRole().equals("forward")
    880                                                         || waysOfOriginalRelation.get(i).getRole().equals("backward")) {
    881                                                 modifiedRelationMembers.add(new RelationMember("", waysOfOriginalRelation.get(i).getMember()));
    882                                         } else {
    883                                                 modifiedRelationMembers.add(waysOfOriginalRelation.get(i));
    884                                         }
    885                                 }
    886                         }
    887 
    888                         modifiedRelation.setMembers(modifiedRelationMembers);
    889                         // TODO: change the data model too
    890                         wrongSegments.remove(testError);
    891                         wrongSegment.setPTWays(wrongSegment.getFixVariants().get(0));
    892                         addCorrectSegment(wrongSegment);
    893                         ChangeCommand changeCommand = new ChangeCommand(originalRelation, modifiedRelation);
    894                         return changeCommand;
    895 
     723                                displayFixVariants(wrongSegment.getFixVariants(), testError);
     724                                return null;
     725                        }
     726
     727                        return carryOutSingleFix(testError, wrongSegment.getFixVariants().get(0));
    896728                }
    897729
     
    902734
    903735        /**
    904          *
    905          * @param segments
    906          */
    907         private static List<PTWay> displayCorrectSegmentVariants(List<PTRouteSegment> segments, TestError testError) {
    908                 List<List<PTWay>> fixVariantList = new ArrayList<>();
    909                 for (PTRouteSegment segment : segments) {
    910                         fixVariantList.add(segment.getPTWays());
    911                 }
    912                 return displayFixVariants(fixVariantList, testError);
    913         }
    914 
    915         /**
     736         * This is largely a copy of the displayFixVariants() method, adapted for
     737         * use with the key listener
    916738         *
    917739         * @param fixVariants
    918          */
    919         private static List<PTWay> displayFixVariants(List<List<PTWay>> fixVariants, TestError testError) {
     740         * @param testError
     741         */
     742        private static void displayFixVariants(List<List<PTWay>> fixVariants, TestError testError) {
    920743                // find the letters of the fix variants:
    921744                char alphabet = 'A';
    922                 List<Character> allowedCharacters = new ArrayList<>();
     745                final List<Character> allowedCharacters = new ArrayList<>();
    923746                for (int i = 0; i < fixVariants.size(); i++) {
    924747                        allowedCharacters.add(alphabet);
     
    928751                // zoom to problem:
    929752                final Collection<OsmPrimitive> waysToZoom = new ArrayList<>();
    930 //              for (List<PTWay> fix : fixVariants) {
    931 //                      for (PTWay ptway : fix) {
    932 //                              waysToZoom.addAll(ptway.getWays());
    933 //                      }
    934 //              }
    935                 for (Object highlightedPrimitive: testError.getHighlighted()) {
    936                         waysToZoom.add((OsmPrimitive)highlightedPrimitive);
     753                for (Object highlightedPrimitive : testError.getHighlighted()) {
     754                        waysToZoom.add((OsmPrimitive) highlightedPrimitive);
    937755                }
    938756                if (SwingUtilities.isEventDispatchThread()) {
     
    948766
    949767                // display the fix variants:
    950                 PTAssistantValidatorTest test = (PTAssistantValidatorTest) testError.getTester();
     768                final PTAssistantValidatorTest test = (PTAssistantValidatorTest) testError.getTester();
    951769                test.addFixVariants(fixVariants);
    952770                PTAssistantLayer.getLayer().repaint((Relation) testError.getPrimitives().iterator().next());
    953771
    954                 // get user input:
    955                 Character userInput = getUserInput(allowedCharacters);
    956                 if (userInput == null) {
    957                         test.clearFixVariants();
    958                         return null;
    959                 }
    960                 List<PTWay> selectedFix = test.getFixVariant(userInput);
    961                 test.clearFixVariants();
    962                 return selectedFix;
    963         }
    964 
    965         /**
    966          * Asks user to choose the fix variant and returns the choice
    967          *
    968          * @param allowedCharacters
    969          * @return
    970          */
    971         private static Character getUserInput(List<Character> allowedCharacters) {
    972                 final String[] userInput = { "" };
    973 
    974                 while (userInput[0] == null || userInput[0].length() != 1 || userInput[0].equals("")
    975                                 || !allowedCharacters.contains(userInput[0].toUpperCase().toCharArray()[0])) {
    976                         if (SwingUtilities.isEventDispatchThread()) {
    977 
    978                                 userInput[0] = JOptionPane.showInputDialog("Enter a letter to select the fix variant: ");
    979 
     772                // prepare the variables for the key listener:
     773                final TestError testErrorParameter = testError;
     774
     775                // add the key listener:
     776                Main.map.mapView.requestFocus();
     777                Main.map.mapView.addKeyListener(new KeyListener() {
     778
     779                        @Override
     780                        public void keyTyped(KeyEvent e) {
     781                                // TODO Auto-generated method stub
     782                        }
     783
     784                        @Override
     785                        public void keyPressed(KeyEvent e) {
     786                                Character typedKey = e.getKeyChar();
     787                                Character typedKeyUpperCase = typedKey.toString().toUpperCase().toCharArray()[0];
     788                                if (allowedCharacters.contains(typedKeyUpperCase)) {
     789                                        Main.map.mapView.removeKeyListener(this);
     790                                        List<PTWay> selectedFix = test.getFixVariant(typedKeyUpperCase);
     791                                        test.clearFixVariants();
     792                                        carryOutSelectedFix(testErrorParameter, selectedFix);
     793                                }
     794                                if (e.getKeyCode() == KeyEvent.VK_ESCAPE) {
     795                                        Main.map.mapView.removeKeyListener(this);
     796                                        test.clearFixVariants();
     797                                }
     798                        }
     799
     800                        @Override
     801                        public void keyReleased(KeyEvent e) {
     802                                // TODO Auto-generated method stub
     803                        }
     804                });
     805
     806                // display the notification:
     807                if (SwingUtilities.isEventDispatchThread()) {
     808                        Notification notification = new Notification(
     809                                        tr("Type letter to select the fix variant or press Escape for no fix"));
     810                        notification.show();
     811                } else {
     812                        SwingUtilities.invokeLater(new Runnable() {
     813                                @Override
     814                                public void run() {
     815                                        Notification notification = new Notification(
     816                                                        tr("Type letter to select the fix variant or press Escape for no fix"));
     817                                        notification.show();
     818                                }
     819                        });
     820                }
     821        }
     822
     823        /**
     824         * Carries out the fix (i.e. modifies the route) after the user has picked
     825         * the fix from several fix variants.
     826         *
     827         * @param testError
     828         *            test error to be fixed
     829         * @param fix
     830         *            the fix variant to be adopted
     831         */
     832        private static void carryOutSelectedFix(TestError testError, List<PTWay> fix) {
     833                Relation route = (Relation) testError.getPrimitives().iterator().next();
     834                route.setMembers(getModifiedRelationMembers(testError, fix));
     835                PTRouteSegment wrongSegment = wrongSegments.get(testError);
     836                wrongSegments.remove(testError);
     837                wrongSegment.setPTWays(wrongSegment.getFixVariants().get(0));
     838                addCorrectSegment(wrongSegment);
     839        }
     840
     841        /**
     842         * Carries out the fix (i.e. modifies the route) when there is only one fix
     843         * variant.
     844         *
     845         * @param testError
     846         * @param fix
     847         */
     848        private static Command carryOutSingleFix(TestError testError, List<PTWay> fix) {
     849                // Zoom to the problematic ways:
     850                final Collection<OsmPrimitive> waysToZoom = new ArrayList<>();
     851                for (Object highlightedPrimitive : testError.getHighlighted()) {
     852                        waysToZoom.add((OsmPrimitive) highlightedPrimitive);
     853                }
     854                if (SwingUtilities.isEventDispatchThread()) {
     855                        AutoScaleAction.zoomTo(waysToZoom);
     856                } else {
     857                        SwingUtilities.invokeLater(new Runnable() {
     858                                @Override
     859                                public void run() {
     860                                        AutoScaleAction.zoomTo(waysToZoom);
     861                                }
     862                        });
     863                }
     864
     865                // wait:
     866                synchronized (SegmentChecker.class) {
     867                        try {
     868                                SegmentChecker.class.wait(1500);
     869                        } catch (InterruptedException e) {
     870                                // TODO Auto-generated catch block
     871                                e.printStackTrace();
     872                        }
     873                }
     874
     875                // modify the route:
     876                Relation originalRelation = (Relation) testError.getPrimitives().iterator().next();
     877                Relation modifiedRelation = new Relation(originalRelation);
     878                modifiedRelation.setMembers(getModifiedRelationMembers(testError, fix));
     879                wrongSegments.remove(testError);
     880                return new ChangeCommand(originalRelation, modifiedRelation);
     881
     882        }
     883
     884        /**
     885         * Returns a list of the modified relation members. This list can be used by
     886         * the calling method (relation.setMemers()) to modify the modify the route
     887         * relation. The route relation is not modified by this method. The lists of
     888         * wrong and correct segments are not updated.
     889         *
     890         * @param testError
     891         *            test error to be fixed
     892         * @param fix
     893         *            the fix variant to be adopted
     894         * @return List of modified relation members to be applied to the route
     895         *         relation
     896         */
     897        private static List<RelationMember> getModifiedRelationMembers(TestError testError, List<PTWay> fix) {
     898                PTRouteSegment wrongSegment = wrongSegments.get(testError);
     899                Relation originalRelation = (Relation) testError.getPrimitives().iterator().next();
     900
     901                // copy stops first:
     902                List<RelationMember> modifiedRelationMembers = listStopMembers(originalRelation);
     903
     904                // copy PTWays last:
     905                List<RelationMember> waysOfOriginalRelation = listNotStopMembers(originalRelation);
     906                for (int i = 0; i < waysOfOriginalRelation.size(); i++) {
     907                        if (waysOfOriginalRelation.get(i).getWay() == wrongSegment.getPTWays().get(0).getWays().get(0)) {
     908                                modifiedRelationMembers.addAll(fix);
     909                                i = i + wrongSegment.getPTWays().size() - 1;
    980910                        } else {
    981 
    982                                 try {
    983                                         SwingUtilities.invokeAndWait(new Runnable() {
    984                                                 @Override
    985                                                 public void run() {
    986 
    987                                                         userInput[0] = JOptionPane.showInputDialog("Enter a letter to select the fix variant: ");
    988 
    989                                                 }
    990                                         });
    991                                 } catch (InvocationTargetException | InterruptedException e1) {
    992                                         break;
    993                                 }
    994 
    995                         }
    996                         if (userInput[0] == null) {
    997                                 break;
    998                         }
    999                 }
    1000 
    1001                 if (userInput[0] == null) {
    1002                         return null;
    1003                 }
    1004                 return userInput[0].toCharArray()[0];
    1005 
    1006         }
    1007 
    1008         /**
    1009          *
    1010          * @param testError
    1011          * @return
    1012          */
    1013         protected static Command fixErrorByZooming(TestError testError) {
    1014 
    1015                 if (testError.getCode() != PTAssistantValidatorTest.ERROR_CODE_STOP_BY_STOP) {
    1016                         return null;
    1017                 }
    1018 
    1019                 Collection<? extends OsmPrimitive> primitives = testError.getPrimitives();
    1020                 Relation originalRelation = (Relation) primitives.iterator().next();
    1021                 ArrayList<OsmPrimitive> primitivesToZoom = new ArrayList<>();
    1022                 for (Object primitiveToZoom : testError.getHighlighted()) {
    1023                         primitivesToZoom.add((OsmPrimitive) primitiveToZoom);
    1024                 }
    1025 
    1026                 SelectCommand command = new SelectCommand(primitivesToZoom);
    1027 
    1028                 List<OsmDataLayer> listOfLayers = Main.getLayerManager().getLayersOfType(OsmDataLayer.class);
    1029                 for (OsmDataLayer osmDataLayer : listOfLayers) {
    1030                         if (osmDataLayer.data == originalRelation.getDataSet()) {
    1031 
    1032                                 final OsmDataLayer layerParameter = osmDataLayer;
    1033                                 final Relation relationParameter = originalRelation;
    1034                                 final Collection<OsmPrimitive> zoomParameter = primitivesToZoom;
    1035 
    1036                                 if (SwingUtilities.isEventDispatchThread()) {
    1037 
    1038                                         showRelationEditorAndZoom(layerParameter, relationParameter, zoomParameter);
    1039 
    1040                                 } else {
    1041 
    1042                                         SwingUtilities.invokeLater(new Runnable() {
    1043                                                 @Override
    1044                                                 public void run() {
    1045 
    1046                                                         showRelationEditorAndZoom(layerParameter, relationParameter, zoomParameter);
    1047 
    1048                                                 }
    1049                                         });
    1050 
    1051                                 }
    1052 
    1053                                 return command;
    1054                         }
    1055                 }
    1056 
    1057                 return null;
    1058 
    1059         }
    1060 
    1061         private static void showRelationEditorAndZoom(OsmDataLayer layer, Relation r, Collection<OsmPrimitive> primitives) {
    1062 
    1063                 // zoom to problem:
    1064                 AutoScaleAction.zoomTo(primitives);
    1065 
    1066                 // put stop-related members to the front and edit roles if necessary:
    1067                 List<RelationMember> sortedRelationMembers = listStopMembers(r);
    1068                 sortedRelationMembers.addAll(listNotStopMembers(r));
    1069                 r.setMembers(sortedRelationMembers);
    1070 
    1071                 // create editor:
    1072                 GenericRelationEditor editor = (GenericRelationEditor) RelationEditor.getEditor(layer, r,
    1073                                 r.getMembersFor(primitives));
    1074 
    1075                 // open editor:
    1076                 editor.setVisible(true);
    1077 
    1078                 // make the current relation purple in the pt_assistant layer:
    1079                 PTAssistantLayer.getLayer().repaint(r);
    1080 
     911                                modifiedRelationMembers.add(waysOfOriginalRelation.get(i));
     912                        }
     913                }
     914
     915                return modifiedRelationMembers;
    1081916        }
    1082917
  • applications/editors/josm/plugins/pt_assistant/src/org/openstreetmap/josm/plugins/pt_assistant/validation/WayChecker.java

    r32783 r32784  
    99import java.util.Set;
    1010
    11 import javax.swing.SwingUtilities;
    12 
    13 import org.openstreetmap.josm.Main;
    14 import org.openstreetmap.josm.actions.AutoScaleAction;
    1511import org.openstreetmap.josm.command.ChangeCommand;
    1612import org.openstreetmap.josm.command.Command;
    17 import org.openstreetmap.josm.command.SelectCommand;
    1813import org.openstreetmap.josm.data.osm.Node;
    1914import org.openstreetmap.josm.data.osm.OsmPrimitive;
     
    2520import org.openstreetmap.josm.data.validation.Test;
    2621import org.openstreetmap.josm.data.validation.TestError;
    27 import org.openstreetmap.josm.gui.dialogs.relation.GenericRelationEditor;
    28 import org.openstreetmap.josm.gui.dialogs.relation.RelationEditor;
    29 import org.openstreetmap.josm.gui.layer.OsmDataLayer;
    30 import org.openstreetmap.josm.plugins.pt_assistant.gui.PTAssistantLayer;
    3122import org.openstreetmap.josm.plugins.pt_assistant.utils.RouteUtils;
    3223
     
    230221
    231222        /**
    232          * Checks if the current way touches its neighbouring was correctly
     223         * Checks if the current way touches its neighboring ways correctly
    233224         *
    234225         * @param prev
     
    451442        }
    452443
    453         protected static Command fixErrorByZooming(TestError testError) {
    454 
    455                 if (testError.getCode() != PTAssistantValidatorTest.ERROR_CODE_DIRECTION) {
    456                         return null;
    457                 }
    458 
    459                 Collection<? extends OsmPrimitive> primitives = testError.getPrimitives();
    460                 Relation originalRelation = (Relation) primitives.iterator().next();
    461                 ArrayList<OsmPrimitive> primitivesToZoom = new ArrayList<>();
    462                 for (Object primitiveToZoom : testError.getHighlighted()) {
    463                         primitivesToZoom.add((OsmPrimitive) primitiveToZoom);
    464                 }
    465 
    466                 SelectCommand command = new SelectCommand(primitivesToZoom);
    467 
    468                 List<OsmDataLayer> listOfLayers = Main.getLayerManager().getLayersOfType(OsmDataLayer.class);
    469                 for (OsmDataLayer osmDataLayer : listOfLayers) {
    470                         if (osmDataLayer.data == originalRelation.getDataSet()) {
    471 
    472                                 final OsmDataLayer layerParameter = osmDataLayer;
    473                                 final Relation relationParameter = originalRelation;
    474                                 final Collection<OsmPrimitive> zoomParameter = primitivesToZoom;
    475 
    476                                 if (SwingUtilities.isEventDispatchThread()) {
    477 
    478                                         showRelationEditorAndZoom(layerParameter, relationParameter, zoomParameter);
    479 
    480                                 } else {
    481 
    482                                         SwingUtilities.invokeLater(new Runnable() {
    483                                                 @Override
    484                                                 public void run() {
    485 
    486                                                         showRelationEditorAndZoom(layerParameter, relationParameter, zoomParameter);
    487 
    488                                                 }
    489                                         });
    490 
    491                                 }
    492 
    493                                 return command;
    494                         }
    495                 }
    496 
    497                 return null;
    498 
    499         }
    500 
    501         private static void showRelationEditorAndZoom(OsmDataLayer layer, Relation r, Collection<OsmPrimitive> primitives) {
    502 
    503                 // zoom to problem:
    504                 AutoScaleAction.zoomTo(primitives);
    505 
    506                 // put stop-related members to the front and edit roles if necessary:
    507                 List<RelationMember> sortedRelationMembers = listStopMembers(r);
    508                 sortedRelationMembers.addAll(listNotStopMembers(r));
    509                 r.setMembers(sortedRelationMembers);
    510 
    511                 // create editor:
    512                 GenericRelationEditor editor = (GenericRelationEditor) RelationEditor.getEditor(layer, r,
    513                                 r.getMembersFor(primitives));
    514 
    515                 // open editor:
    516                 editor.setVisible(true);
    517 
    518                 // make the current relation purple in the pt_assistant layer:
    519                 PTAssistantLayer.getLayer().repaint(r);
    520 
    521         }
    522 
    523444}
Note: See TracChangeset for help on using the changeset viewer.